Merge pull request #609 from pixeltrix/redirect-on-single-result

Redirect when there is a single search result
This commit is contained in:
Mike Jolley 2012-02-09 08:37:28 -08:00
commit 52001e3e26
2 changed files with 21 additions and 4 deletions

View File

@ -534,12 +534,21 @@ $woocommerce_settings['catalog'] = apply_filters('woocommerce_catalog_settings',
),
),
array(
'name' => __( 'Cart redirect', 'woocommerce' ),
array(
'name' => __( 'Redirects', 'woocommerce' ),
'desc' => __( 'Redirect to cart after adding a product to the cart (on single product pages)', 'woocommerce' ),
'id' => 'woocommerce_cart_redirect_after_add',
'std' => 'no',
'type' => 'checkbox'
'type' => 'checkbox',
'checkboxgroup' => 'start'
),
array(
'desc' => __( 'Redirect to the product page on a single matching search result', 'woocommerce' ),
'id' => 'woocommerce_redirect_on_single_search_result',
'std' => 'no',
'type' => 'checkbox',
'checkboxgroup' => 'end'
),
array( 'type' => 'sectionend', 'id' => 'catalog_options' ),

View File

@ -13,7 +13,7 @@
* Handle redirects before content is output - hooked into template_redirect so is_page works
**/
function woocommerce_redirects() {
global $woocommerce;
global $woocommerce, $wp_query;
// When default permalinks are enabled, redirect shop page to post type archive url
if ( isset($_GET['page_id']) && $_GET['page_id'] > 0 && get_option( 'permalink_structure' )=="" && $_GET['page_id'] == woocommerce_get_page_id('shop') ) :
@ -39,6 +39,14 @@ function woocommerce_redirects() {
exit;
endif;
// Redirect to the product page if we have a single product
if (is_search() && is_post_type_archive('product') && get_option('woocommerce_redirect_on_single_search_result')=='yes') {
if ($wp_query->post_count==1) {
$product = new WC_Product($wp_query->post->ID);
if ($product->is_visible()) wp_safe_redirect( get_permalink($product->id), 302 );
exit;
}
}
}
/**