Adv search now redirects to a cleaner results view with a 'search again' button, PEP8 cleanups, removed reduntant code

This commit is contained in:
Roberto Rosario
2011-06-22 01:42:07 -04:00
parent 604ef90f79
commit f9190829ae
6 changed files with 51 additions and 46 deletions

View File

@@ -4,7 +4,9 @@ from navigation.api import register_sidebar_template, register_links
search = {'text': _(u'search'), 'view': 'search', 'famfam': 'zoom'} search = {'text': _(u'search'), 'view': 'search', 'famfam': 'zoom'}
search_advanced = {'text': _(u'advanced search'), 'view': 'search_advanced', 'famfam': 'zoom_in'} search_advanced = {'text': _(u'advanced search'), 'view': 'search_advanced', 'famfam': 'zoom_in'}
search_again = {'text': _(u'search again'), 'view': 'search_again', 'famfam': 'arrow_undo'}
register_sidebar_template(['search', 'search_advanced'], 'search_help.html') register_sidebar_template(['search', 'search_advanced'], 'search_help.html')
register_links(['search', 'search_advanced'], [search, search_advanced], menu_name='form_header') register_links(['search', 'search_advanced'], [search, search_advanced], menu_name='form_header')
register_links(['results'], [search_again], menu_name='sidebar')

View File

@@ -1,6 +1,8 @@
from django import forms from django import forms
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from dynamic_search.api import registered_search_dict
class SearchForm(forms.Form): class SearchForm(forms.Form):
q = forms.CharField(max_length=128, label=_(u'Search terms')) q = forms.CharField(max_length=128, label=_(u'Search terms'))
@@ -8,12 +10,11 @@ class SearchForm(forms.Form):
class AdvancedSearchForm(forms.Form): class AdvancedSearchForm(forms.Form):
def __init__(self, *args, **kwargs): def __init__(self, *args, **kwargs):
search_fields = kwargs.pop('search_fields')
super(AdvancedSearchForm, self).__init__(*args, **kwargs) super(AdvancedSearchForm, self).__init__(*args, **kwargs)
#Set form fields initial values for model_name, values in registered_search_dict.items():
for search_field in search_fields: for field in values['fields']:
self.fields[search_field['name']] = forms.CharField( self.fields['%s__%s' % (model_name, field['name'])] = forms.CharField(
label=search_field['title'], label=field['title'],
required=False required=False
) )

View File

@@ -1,7 +1,8 @@
from django.conf.urls.defaults import patterns, url from django.conf.urls.defaults import patterns, url
urlpatterns = patterns('dynamic_search.views', urlpatterns = patterns('dynamic_search.views',
url(r'^search/$', 'search', (), 'search'), url(r'^$', 'search', (), 'search'),
url(r'^search/advanced/$', 'search', { 'advanced': True }, 'search_advanced'), url(r'^advanced/$', 'search', {'advanced': True}, 'search_advanced'),
url(r'^again/$', 'search_again', (), 'search_again'),
url(r'^results/$', 'results', (), 'results'), url(r'^results/$', 'results', (), 'results'),
) )

View File

@@ -1,28 +1,27 @@
import urlparse
from django.shortcuts import render_to_response from django.shortcuts import render_to_response
from django.template import RequestContext from django.template import RequestContext
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from django.contrib import messages from django.contrib import messages
from django.conf import settings from django.conf import settings
from django.http import HttpResponseRedirect
from django.core.urlresolvers import reverse
from dynamic_search.api import perform_search, registered_search_dict from dynamic_search.api import perform_search
from dynamic_search.forms import SearchForm, AdvancedSearchForm from dynamic_search.forms import SearchForm, AdvancedSearchForm
from dynamic_search.conf.settings import SHOW_OBJECT_TYPE from dynamic_search.conf.settings import SHOW_OBJECT_TYPE
from dynamic_search.conf.settings import LIMIT from dynamic_search.conf.settings import LIMIT
def results(request, extra_context=None): def results(request, extra_context=None):
query_string = ''
context = {} context = {}
context.update({ context.update({
'query_string': request.GET, 'query_string': request.GET,
'form_title': _(u'Search'),
#'hide_header': True, #'hide_header': True,
'form_hide_required_text': True,
'hide_links': True, 'hide_links': True,
'multi_select_as_buttons': True, 'multi_select_as_buttons': True,
'submit_label': _(u'Search'),
'submit_icon_famfam': 'zoom',
'search_results_limit': LIMIT, 'search_results_limit': LIMIT,
}) })
@@ -60,36 +59,38 @@ def results(request, extra_context=None):
def search(request, advanced=False): def search(request, advanced=False):
if advanced: if advanced:
search_fields = [] form = AdvancedSearchForm(data=request.GET)
for model_name, values in registered_search_dict.items(): return render_to_response('generic_form.html',
for field in values['fields']: {
search_fields.append(
{
'title': field['title'],
'name': '%s__%s' % (model_name, field['name'])
}
)
form = AdvancedSearchForm(
search_fields=search_fields,
data=request.GET
)
return results(request, extra_context={
'form': form, 'form': form,
'form_title': _(u'advanced search') 'title': _(u'advanced search'),
} 'form_action': reverse('results'),
'submit_method': 'GET',
'search_results_limit': LIMIT,
'submit_label': _(u'Search'),
'submit_icon_famfam': 'zoom',
},
context_instance=RequestContext(request)
) )
else: else:
extra_context = {
'submit_label': _(u'Search'),
'submit_icon_famfam': 'zoom',
'form_title': _(u'Search'),
'form_hide_required_text': True,
}
if ('q' in request.GET) and request.GET['q'].strip(): if ('q' in request.GET) and request.GET['q'].strip():
query_string = request.GET['q'] query_string = request.GET['q']
form = SearchForm(initial={'q': query_string}) form = SearchForm(initial={'q': query_string})
return results(request, extra_context={ extra_context.update({'form': form})
'form': form return results(request, extra_context=extra_context)
}
)
else: else:
form = SearchForm() form = SearchForm()
return results(request, extra_context={ extra_context.update({'form': form})
'form': form return results(request, extra_context=extra_context)
}
)
def search_again(request):
query = urlparse.urlparse(request.META.get('HTTP_REFERER', u'/')).query
return HttpResponseRedirect('%s?%s' % (reverse('search_advanced'), query))