2012-08-10 09:35:25 +00:00
< ? php
2011-08-10 17:11:11 +00:00
/**
2011-09-04 00:02:44 +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
*
2012-08-14 17:37:50 +00:00
* @ author WooThemes
* @ category Widgets
* @ package WooCommerce / Widgets
* @ version 1.6 . 4
* @ extends WP_Widget
2011-09-04 00:02:44 +00:00
*/
2012-10-15 10:57:58 +00:00
if ( ! defined ( 'ABSPATH' ) ) exit ; // Exit if accessed directly
2011-08-10 17:11:11 +00:00
class WooCommerce_Widget_Price_Filter extends WP_Widget {
2011-08-26 21:28:55 +00:00
var $woo_widget_cssclass ;
var $woo_widget_description ;
var $woo_widget_idbase ;
var $woo_widget_name ;
2012-08-10 09:35:25 +00:00
2012-08-14 17:37:50 +00:00
/**
* constructor
*
* @ access public
* @ return void
*/
2011-08-10 17:11:11 +00:00
function WooCommerce_Widget_Price_Filter () {
2012-08-10 09:35:25 +00:00
2011-08-26 21:28:55 +00:00
/* Widget variable settings. */
$this -> woo_widget_cssclass = 'widget_price_filter' ;
2012-01-05 11:31:22 +00:00
$this -> woo_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' );
2011-08-26 21:28:55 +00:00
$this -> woo_widget_idbase = 'woocommerce_price_filter' ;
2012-10-16 09:45:33 +00:00
$this -> woo_widget_name = __ ( 'WooCommerce Price Filter' , 'woocommerce' );
2012-08-10 09:35:25 +00:00
2011-08-26 21:28:55 +00:00
/* Widget settings. */
$widget_ops = array ( 'classname' => $this -> woo_widget_cssclass , 'description' => $this -> woo_widget_description );
2012-08-10 09:35:25 +00:00
2011-08-26 21:28:55 +00:00
/* Create the widget. */
$this -> WP_Widget ( 'price_filter' , $this -> woo_widget_name , $widget_ops );
2011-08-10 17:11:11 +00:00
}
2012-08-14 17:37:50 +00:00
/**
* widget function .
*
* @ see WP_Widget
* @ access public
* @ param array $args
* @ param array $instance
* @ return void
*/
2011-08-10 17:11:11 +00:00
function widget ( $args , $instance ) {
extract ( $args );
2012-08-10 09:35:25 +00:00
2012-06-29 20:18:22 +00:00
global $_chosen_attributes , $wpdb , $woocommerce , $wp_query , $wp ;
2012-08-10 09:35:25 +00:00
2012-03-26 14:34:23 +00:00
if ( ! is_tax ( 'product_cat' ) && ! is_post_type_archive ( 'product' ) && ! is_tax ( 'product_tag' )) return ; // Not on product page - return
2012-08-10 09:35:25 +00:00
2012-03-26 14:34:23 +00:00
if ( sizeof ( $woocommerce -> query -> unfiltered_product_ids ) == 0 ) return ; // None shown - return
2012-08-10 09:35:25 +00:00
wp_enqueue_script ( 'wc-price-slider' );
wp_localize_script ( 'wc-price-slider' , 'woocommerce_price_slider_params' , array (
'currency_symbol' => get_woocommerce_currency_symbol (),
'currency_pos' => get_option ( 'woocommerce_currency_pos' ),
2012-09-07 18:28:27 +00:00
'min_price' => isset ( $woocommerce -> session -> min_price ) ? $woocommerce -> session -> min_price : '' ,
'max_price' => isset ( $woocommerce -> session -> max_price ) ? $woocommerce -> session -> max_price : ''
2012-08-10 09:35:25 +00:00
) );
2011-11-15 15:15:12 +00:00
2011-08-10 17:11:11 +00:00
$title = $instance [ 'title' ];
$title = apply_filters ( 'widget_title' , $title , $instance , $this -> id_base );
2012-08-10 09:35:25 +00:00
2011-08-10 17:11:11 +00:00
// Remember current filters/search
$fields = '' ;
2012-08-10 09:35:25 +00:00
2011-08-10 17:11:11 +00:00
if ( get_search_query ()) $fields = '<input type="hidden" name="s" value="' . get_search_query () . '" />' ;
2011-09-30 19:14:12 +00:00
if ( isset ( $_GET [ 'post_type' ])) $fields .= '<input type="hidden" name="post_type" value="' . esc_attr ( $_GET [ 'post_type' ] ) . '" />' ;
2012-01-13 11:28:23 +00:00
if ( isset ( $_GET [ 'product_cat' ])) $fields .= '<input type="hidden" name="product_cat" value="' . esc_attr ( $_GET [ 'product_cat' ] ) . '" />' ;
if ( isset ( $_GET [ 'product_tag' ])) $fields .= '<input type="hidden" name="product_tag" value="' . esc_attr ( $_GET [ 'product_tag' ] ) . '" />' ;
2012-08-10 09:35:25 +00:00
2011-11-15 15:15:12 +00:00
if ( $_chosen_attributes ) foreach ( $_chosen_attributes as $attribute => $data ) :
2012-08-10 09:35:25 +00:00
2011-11-15 15:15:12 +00:00
$fields .= '<input type="hidden" name="' . esc_attr ( str_replace ( 'pa_' , 'filter_' , $attribute ) ) . '" value="' . esc_attr ( implode ( ',' , $data [ 'terms' ]) ) . '" />' ;
if ( $data [ 'query_type' ] == 'or' ) $fields .= '<input type="hidden" name="' . esc_attr ( str_replace ( 'pa_' , 'query_type_' , $attribute ) ) . '" value="or" />' ;
2012-08-10 09:35:25 +00:00
2011-08-10 17:11:11 +00:00
endforeach ;
2012-08-10 09:35:25 +00:00
2011-12-02 11:43:15 +00:00
$min = $max = 0 ;
$post_min = $post_max = '' ;
2012-08-10 09:35:25 +00:00
2012-10-18 13:22:42 +00:00
if ( sizeof ( $woocommerce -> query -> layered_nav_product_ids ) != 0 ) {
$max = ceil ( $wpdb -> get_var (
$wpdb -> prepare ( '
SELECT max ( meta_value + 0 )
FROM % 1 $s
LEFT JOIN % 2 $s ON % 1 $s . ID = % 2 $s . post_id
WHERE meta_key = % 3 $s
'), $wpdb->posts, $wpdb->postmeta, ' _price '
) );
} else {
$max = ceil ( $wpdb -> get_var (
$wpdb -> prepare ( '
SELECT max ( meta_value + 0 )
FROM % 1 $s
LEFT JOIN % 2 $s ON % 1 $s . ID = % 2 $s . post_id
WHERE meta_key = % 3 $s
AND (
% 1 $s . ID IN ( % 4 $s )
OR (
% 1 $s . post_parent IN ( % 4 $s )
AND % 1 $s . post_parent != 0
)
)
'), $wpdb->posts, $wpdb->postmeta, ' _price ', implode( ' , ' , $woocommerce -> query -> layered_nav_product_ids )
) );
}
2012-08-10 09:35:25 +00:00
2012-03-26 09:34:04 +00:00
if ( $min == $max ) return ;
2012-08-10 09:35:25 +00:00
2012-09-07 18:28:27 +00:00
if ( isset ( $woocommerce -> session -> min_price ) ) $post_min = $woocommerce -> session -> min_price ;
if ( isset ( $woocommerce -> session -> max_price ) ) $post_max = $woocommerce -> session -> max_price ;
2012-03-29 14:50:20 +00:00
echo $before_widget . $before_title . $title . $after_title ;
2012-08-10 09:35:25 +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 ) ) );
else
$form_action = preg_replace ( '%\/page/[0-9]+%' , '' , home_url ( $wp -> request ) );
2012-08-10 09:35:25 +00:00
2012-06-29 20:18:22 +00:00
echo '<form method="get" action="' . $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 " >
2012-10-16 09:45:33 +00:00
< input type = " text " id = " min_price " name = " min_price " value = " '.esc_attr( $post_min ).' " data - min = " '.esc_attr( $min ).' " placeholder = " '.__('Min price', 'woocommerce' ).' " />
< input type = " text " id = " max_price " name = " max_price " value = " '.esc_attr( $post_max ).' " data - max = " '.esc_attr( $max ).' " placeholder = " '.__( 'Max price', 'woocommerce' ).' " />
< button type = " submit " class = " button " > '.__( ' Filter ', ' woocommerce ' ).' </ button >
2011-12-02 11:43:15 +00:00
< div class = " price_label " style = " display:none; " >
2012-10-16 09:45:33 +00:00
'.__( ' Price : ', ' woocommerce ' ).' < span class = " from " ></ span > & mdash ; < span class = " to " ></ span >
2011-12-02 11:43:15 +00:00
</ div >
2011-08-10 17:11:11 +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
2011-08-10 17:11:11 +00:00
echo $after_widget ;
}
2012-08-14 17:37:50 +00:00
/**
* update function .
*
* @ see WP_Widget -> update
* @ access public
* @ param array $new_instance
* @ param array $old_instance
* @ return array
*/
2011-08-10 17:11:11 +00:00
function update ( $new_instance , $old_instance ) {
2012-10-16 09:45:33 +00:00
if ( ! isset ( $new_instance [ 'title' ]) || empty ( $new_instance [ 'title' ])) $new_instance [ 'title' ] = __ ( 'Filter by price' , 'woocommerce' );
2011-08-10 17:11:11 +00:00
$instance [ 'title' ] = strip_tags ( stripslashes ( $new_instance [ 'title' ]));
return $instance ;
}
2012-08-14 17:37:50 +00:00
/**
* form function .
*
* @ see WP_Widget -> form
* @ access public
* @ param array $instance
* @ return void
*/
2011-08-10 17:11:11 +00:00
function form ( $instance ) {
global $wpdb ;
?>
2012-10-16 09:45:33 +00:00
< p >< label for = " <?php echo $this->get_field_id ('title'); ?> " >< ? php _e ( 'Title:' , 'woocommerce' ) ?> </label>
2011-09-19 06:01:26 +00:00
< input type = " text " class = " widefat " id = " <?php echo esc_attr( $this->get_field_id ('title') ); ?> " name = " <?php echo esc_attr( $this->get_field_name ('title') ); ?> " value = " <?php if (isset ( $instance['title'] )) { echo esc_attr( $instance['title'] );} ?> " /></ p >
2011-08-10 17:11:11 +00:00
< ? php
}
2012-08-14 17:37:50 +00:00
}
/**
* Price filter Init
*
2012-08-15 18:15:06 +00:00
* @ package WooCommerce / Widgets
2012-08-14 17:37:50 +00:00
* @ access public
* @ return void
*/
function woocommerce_price_filter_init () {
global $woocommerce ;
if ( is_active_widget ( false , false , 'price_filter' , true ) && ! is_admin () ) {
$suffix = defined ( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ? '' : '.min' ;
wp_register_script ( 'wc-price-slider' , $woocommerce -> plugin_url () . '/assets/js/frontend/price-slider' . $suffix . '.js' , array ( 'jquery-ui' ), '1.6' , true );
2012-09-07 18:28:27 +00:00
unset ( $woocommerce -> session -> min_price );
unset ( $woocommerce -> session -> max_price );
2012-08-14 17:37:50 +00:00
if ( isset ( $_GET [ 'min_price' ] ) )
2012-09-07 18:28:27 +00:00
$woocommerce -> session -> min_price = esc_attr ( $_GET [ 'min_price' ] );
2012-08-14 17:37:50 +00:00
if ( isset ( $_GET [ 'max_price' ] ) )
2012-09-07 18:28:27 +00:00
$woocommerce -> session -> max_price = esc_attr ( $_GET [ 'max_price' ] );
2012-08-14 17:37:50 +00:00
add_filter ( 'loop_shop_post_in' , 'woocommerce_price_filter' );
}
}
add_action ( 'init' , 'woocommerce_price_filter_init' );
/**
* Price Filter post filter
*
2012-08-15 18:15:06 +00:00
* @ package WooCommerce / Widgets
2012-08-14 17:37:50 +00:00
* @ access public
* @ param array $filtered_posts
* @ return array
*/
function woocommerce_price_filter ( $filtered_posts ) {
global $wpdb ;
if ( isset ( $_GET [ 'max_price' ] ) && isset ( $_GET [ 'min_price' ] ) ) {
$matched_products = array ();
$min = floatval ( $_GET [ 'min_price' ] );
$max = floatval ( $_GET [ 'max_price' ] );
$matched_products_query = $wpdb -> get_results ( $wpdb -> prepare ( "
SELECT DISTINCT ID , post_parent , post_type FROM $wpdb -> posts
INNER JOIN $wpdb -> postmeta ON ID = post_id
WHERE post_type IN ( 'product' , 'product_variation' ) AND post_status = 'publish' AND meta_key = % s AND meta_value BETWEEN % d AND % d
" , '_price', $min , $max ), OBJECT_K );
if ( $matched_products_query ) {
foreach ( $matched_products_query as $product ) {
if ( $product -> post_type == 'product' )
$matched_products [] = $product -> ID ;
if ( $product -> post_parent > 0 && ! in_array ( $product -> post_parent , $matched_products ) )
$matched_products [] = $product -> post_parent ;
}
}
// Filter the id's
if ( sizeof ( $filtered_posts ) == 0 ) {
$filtered_posts = $matched_products ;
$filtered_posts [] = 0 ;
} else {
$filtered_posts = array_intersect ( $filtered_posts , $matched_products );
$filtered_posts [] = 0 ;
}
}
return ( array ) $filtered_posts ;
}