woocommerce/widgets/widget-price_filter.php

197 lines
6.4 KiB
PHP
Raw Normal View History

2011-08-10 17:11:11 +00:00
<?php
/**
2011-09-04 00:02:44 +00:00
* Price Filter Widget and related functions
2011-08-10 17:11:11 +00:00
*
* Generates a range slider to filter products by price
*
* @package WooCommerce
* @category Widgets
* @author WooThemes
*/
2011-12-09 21:47:12 +00:00
2011-12-19 00:39:59 +00:00
if (is_active_widget( false, false, 'price_filter', 'true' ) && !is_admin()) :
2011-12-09 21:47:12 +00:00
add_action('init', 'woocommerce_price_filter_init');
add_filter('loop_shop_post_in', 'woocommerce_price_filter');
endif;
2011-09-04 00:02:44 +00:00
/**
* Price filter Init
*/
2011-08-10 17:11:11 +00:00
function woocommerce_price_filter_init() {
unset($_SESSION['min_price']);
unset($_SESSION['max_price']);
if (isset($_GET['min_price'])) :
$_SESSION['min_price'] = $_GET['min_price'];
endif;
if (isset($_GET['max_price'])) :
$_SESSION['max_price'] = $_GET['max_price'];
2011-09-04 00:02:44 +00:00
endif;
}
/**
* Price Filter post filter
*/
function woocommerce_price_filter( $filtered_posts ) {
if (isset($_GET['max_price']) && isset($_GET['min_price'])) :
$matched_products = array();
$matched_products_query = get_posts(array(
2011-11-18 00:14:08 +00:00
'post_type' => array(
'product_variation',
'product'
),
2011-09-04 00:02:44 +00:00
'post_status' => 'publish',
'posts_per_page' => -1,
'meta_query' => array(
array(
2011-12-24 17:05:51 +00:00
'key' => '_price',
2011-09-04 00:02:44 +00:00
'value' => array( $_GET['min_price'], $_GET['max_price'] ),
'type' => 'NUMERIC',
'compare' => 'BETWEEN'
)
)
));
if ($matched_products_query) :
foreach ($matched_products_query as $product) :
2011-11-18 00:14:08 +00:00
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;
2011-09-04 00:02:44 +00:00
endforeach;
endif;
// 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;
endif;
2011-08-10 17:11:11 +00:00
endif;
2011-09-04 00:02:44 +00:00
return (array) $filtered_posts;
2011-08-10 17:11:11 +00:00
}
2011-09-04 00:02:44 +00:00
/**
* Price Filter post Widget
*/
2011-08-10 17:11:11 +00:00
class WooCommerce_Widget_Price_Filter extends WP_Widget {
2011-08-26 21:28:55 +00:00
/** Variables to setup the widget. */
var $woo_widget_cssclass;
var $woo_widget_description;
var $woo_widget_idbase;
var $woo_widget_name;
2011-08-10 17:11:11 +00:00
/** constructor */
function WooCommerce_Widget_Price_Filter() {
2011-08-26 21:28:55 +00:00
/* Widget variable settings. */
$this->woo_widget_cssclass = 'widget_price_filter';
$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.', 'woothemes' );
$this->woo_widget_idbase = 'woocommerce_price_filter';
$this->woo_widget_name = __('WooCommerce Price Filter', 'woothemes' );
/* Widget settings. */
$widget_ops = array( 'classname' => $this->woo_widget_cssclass, 'description' => $this->woo_widget_description );
/* Create the widget. */
$this->WP_Widget('price_filter', $this->woo_widget_name, $widget_ops);
2011-08-10 17:11:11 +00:00
}
/** @see WP_Widget */
2011-08-10 17:11:11 +00:00
function widget( $args, $instance ) {
extract($args);
2011-11-14 01:20:07 +00:00
global $_chosen_attributes, $wpdb, $woocommerce, $wp_query;
2011-08-31 00:29:02 +00:00
if (!is_tax( 'product_cat' ) && !is_post_type_archive('product') && !is_tax( 'product_tag' )) return;
2011-08-10 17:11:11 +00:00
$title = $instance['title'];
$title = apply_filters('widget_title', $title, $instance, $this->id_base);
echo $before_widget . $before_title . $title . $after_title;
// Remember current filters/search
$fields = '';
if (get_search_query()) $fields = '<input type="hidden" name="s" value="'.get_search_query().'" />';
if (isset($_GET['post_type'])) $fields .= '<input type="hidden" name="post_type" value="'.esc_attr( $_GET['post_type'] ).'" />';
2011-08-10 17:11:11 +00:00
if ($_chosen_attributes) foreach ($_chosen_attributes as $attribute => $data) :
2011-08-10 17:11:11 +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" />';
2011-08-10 17:11:11 +00:00
endforeach;
$min = $max = 0;
$post_min = $post_max = '';
if (sizeof($woocommerce->query->layered_nav_product_ids)==0) :
2011-11-14 01:20:07 +00:00
$max = ceil($wpdb->get_var("SELECT max(meta_value + 0)
FROM $wpdb->posts
LEFT JOIN $wpdb->postmeta ON $wpdb->posts.ID = $wpdb->postmeta.post_id
2011-12-24 17:05:51 +00:00
WHERE meta_key = '_price'"));
else :
$max = ceil($wpdb->get_var("SELECT max(meta_value + 0)
FROM $wpdb->posts
LEFT JOIN $wpdb->postmeta ON $wpdb->posts.ID = $wpdb->postmeta.post_id
2011-12-24 17:05:51 +00:00
WHERE meta_key = '_price' AND (
$wpdb->posts.ID IN (".implode(',', $woocommerce->query->layered_nav_product_ids).")
OR (
$wpdb->posts.post_parent IN (".implode(',', $woocommerce->query->layered_nav_product_ids).")
AND $wpdb->posts.post_parent != 0
)
)"));
endif;
2011-08-10 17:11:11 +00:00
if (isset($_SESSION['min_price'])) $post_min = $_SESSION['min_price'];
if (isset($_SESSION['max_price'])) $post_max = $_SESSION['max_price'];
echo '<form method="get">
2011-08-10 17:11:11 +00:00
<div class="price_slider_wrapper">
<div class="price_slider" style="display:none;"></div>
2011-08-10 17:11:11 +00:00
<div class="price_slider_amount">
<input type="text" id="min_price" name="min_price" value="'.esc_attr( $post_min ).'" data-min="'.esc_attr( $min ).'" placeholder="'.__('Min price', 'woothemes').'" />
<input type="text" id="max_price" name="max_price" value="'.esc_attr( $post_max ).'" data-max="'.esc_attr( $max ).'" placeholder="'.__('Max price', 'woothemes').'" />
<button type="submit" class="button">'.__('Filter', 'woothemes').'</button>
<div class="price_label" style="display:none;">
'.__('Price:', 'woothemes').' <span></span>
</div>
2011-08-10 17:11:11 +00:00
'.$fields.'
<div class="clear"></div>
2011-08-10 17:11:11 +00:00
</div>
</div>
</form>';
echo $after_widget;
}
/** @see WP_Widget->update */
2011-08-10 17:11:11 +00:00
function update( $new_instance, $old_instance ) {
if (!isset($new_instance['title']) || empty($new_instance['title'])) $new_instance['title'] = __('Filter by price', 'woothemes');
$instance['title'] = strip_tags(stripslashes($new_instance['title']));
return $instance;
}
/** @see WP_Widget->form */
2011-08-10 17:11:11 +00:00
function form( $instance ) {
global $wpdb;
?>
<p><label for="<?php echo $this->get_field_id('title'); ?>"><?php _e('Title:', 'woothemes') ?></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
}
} // class WooCommerce_Widget_Price_Filter