0

I have following function for bulk operation of the selected rows in a ListView. I am showing messages for success and error.

def archive_stores(view, queryset):
    if queryset.exists():
        queryset.update(archive=True)
        success_message = messages.success(view.request, 'Archived successfully.')
        return HttpResponseRedirect(reverse('stores_list', success_message))
    else: #The message is not shown when queryset of empty.
        error_message = messages.error(view.request, 'No success!.')
        return HttpResponseRedirect(reverse_lazy('stores_list', error_message))

The success message is being displayed correctly. But the Error message never appears. Please guide me what can be the reason?

Following is the ListView:

@method_decorator(login_required, name='dispatch')
class StoresListView(ActionViewMixin,ListFilteredMixin,ListView):
    template_name = 'stores_listing.html'
    model = Store
    filter_set = StoreFilter
    actions = [archive_stores, unarchive_stores, delete_stores, export_stores,]
    paginate_by = 25

Following is the messages template:

{% for message in messages %}
  <div class="alert {{ message.tags }} alert-dismissible" role="alert">
    <button type="button" class="close" data-dismiss="alert" aria-label="Close">
      <span aria-hidden="true">&times;</span>
    </button>
    {{ message | safe }}
  </div>
{% endfor %}

Thanks.

1 Answers1

0

Try this:

   def archive_stores(view, queryset):
      if queryset:
        queryset.update(archive=True)
        success_message = messages.success(view.request, 'Archived successfully.')
        return  HttpResponseRedirect(reverse('stores_list', success_message))
      else: #The message is not shown when queryset of empty.
         error_message = messages.error(view.request, 'No success!.')
         return HttpResponseRedirect(reverse_lazy('stores_list', error_message))

And I think you dont have to explicitly pass the message as a kwarg in reverse, since calling message.success() or message.error() alone will include the required message. You can update your view like this:

   def archive_stores(view, queryset):
      if queryset:
        queryset.update(archive=True)
        messages.success(view.request, 'Archived successfully.')
        return  HttpResponseRedirect(reverse('stores_list'))
      else: #The message is not shown when queryset of empty.
         messages.error(view.request, 'No success!.')
         return HttpResponseRedirect(reverse_lazy('stores_list'))
Ajmal Noushad
  • 926
  • 7
  • 18