From 7c68414fe75138dfd2e427d872faa65a9d5e60c6 Mon Sep 17 00:00:00 2001 From: Will Rossiter Date: Sat, 11 May 2013 19:29:47 +1200 Subject: [PATCH] FIX: Rename search locale variable to avoid conflicts with locale switcher. Fixes http://open.silverstripe.org/ticket/6204 --- code/search/SearchForm.php | 27 ++++++++++++++++++++------- 1 file changed, 20 insertions(+), 7 deletions(-) diff --git a/code/search/SearchForm.php b/code/search/SearchForm.php index f20054c1..8ee7b105 100644 --- a/code/search/SearchForm.php +++ b/code/search/SearchForm.php @@ -43,7 +43,7 @@ class SearchForm extends Form { } if(class_exists('Translatable') && singleton('SiteTree')->hasExtension('Translatable')) { - $fields->push(new HiddenField('locale', 'locale', Translatable::get_current_locale())); + $fields->push(new HiddenField('searchlocale', 'searchlocale', Translatable::get_current_locale())); } if(!$actions) { @@ -101,11 +101,18 @@ class SearchForm extends Form { if(!isset($data) || !is_array($data)) $data = $_REQUEST; // set language (if present) - if(class_exists('Translatable') && singleton('SiteTree')->hasExtension('Translatable') && isset($data['locale'])) { - $origLocale = Translatable::get_current_locale(); - Translatable::set_current_locale($data['locale']); + if(class_exists('Translatable')) { + if(singleton('SiteTree')->hasExtension('Translatable') && isset($data['searchlocale'])) { + if($data['searchlocale'] == "ALL") { + Translatable::disable_locale_filter(); + } else { + $origLocale = Translatable::get_current_locale(); + + Translatable::set_current_locale($data['searchlocale']); + } + } } - + $keywords = $data['Search']; $andProcessor = create_function('$matches',' @@ -137,8 +144,14 @@ class SearchForm extends Form { } // reset locale - if(class_exists('Translatable') && singleton('SiteTree')->hasExtension('Translatable') && isset($data['locale'])) { - Translatable::set_current_locale($origLocale); + if(class_exists('Translatable')) { + if(singleton('SiteTree')->hasExtension('Translatable') && isset($data['searchlocale'])) { + if($data['searchlocale'] == "ALL") { + Translatable::enable_locale_filter(); + } else { + Translatable::set_current_locale($origLocale); + } + } } return $results;