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

@@ -1,31 +1,30 @@
import urlparse
from django.shortcuts import render_to_response
from django.template import RequestContext
from django.utils.translation import ugettext_lazy as _
from django.contrib import messages
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.conf.settings import SHOW_OBJECT_TYPE
from dynamic_search.conf.settings import LIMIT
def results(request, extra_context=None):
query_string = ''
context = {}
context.update({
'query_string': request.GET,
'form_title': _(u'Search'),
#'hide_header': True,
'form_hide_required_text': True,
'hide_links': True,
'multi_select_as_buttons': True,
'submit_label': _(u'Search'),
'submit_icon_famfam': 'zoom',
'search_results_limit': LIMIT,
})
if extra_context:
context.update(extra_context)
@@ -60,36 +59,38 @@ def results(request, extra_context=None):
def search(request, advanced=False):
if advanced:
search_fields = []
for model_name, values in registered_search_dict.items():
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 = AdvancedSearchForm(data=request.GET)
return render_to_response('generic_form.html',
{
'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:
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():
query_string = request.GET['q']
form = SearchForm(initial={'q': query_string})
return results(request, extra_context={
'form': form
}
)
extra_context.update({'form': form})
return results(request, extra_context=extra_context)
else:
form = SearchForm()
return results(request, extra_context={
'form': form
}
)
extra_context.update({'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))