Может помочь следующее: https://kuttler.eu/en/post/using-django-tables2-filters-crispy-forms-together/
Примечательно, что эти несколько строк:
Поскольку SingleTableView наследует от ListView Django, вы автоматически получаете объект Paginator в контексте шаблона как paginator.
Метод get_queryset () был изменен, чтобы применить фильтр и вернуть отфильтрованный набор запросов. Эти отфильтрованные данные попадают в таблицу в get_table () и попадают на страницу. После этого он добавляется в контекст шаблона вместе с фильтром.
Я использовал это в своем проекте для отображения отфильтрованной таблицы с разбивкой по страницам, используя в качестве базового класса следующее для моего представления: https://gist.github.com/craigderington/0a7ded018b8401bc42822b2eeaaff1cd
Вот так:
class PagedFilteredTableView(SingleTableView):
filter_class = None
formhelper_class = None
context_filter_name = 'filter'
paginator_class = LazyPaginator
def get_queryset(self, **kwargs):
qs = super(PagedFilteredTableView, self).get_queryset()
self.filter = self.filter_class(self.request.GET, queryset=qs)
self.filter.form.helper = self.formhelper_class()
return self.filter.qs
def get_context_data(self, **kwargs):
context = super(PagedFilteredTableView, self).get_context_data()
context[self.context_filter_name] = self.filter
return context
С моим классом просмотра:
class JobList(LoginRequiredMixin, PermissionRequiredMixin, ExportMixin, PagedFilteredTableView):
permission_required = 'jobs.view_job'
template_name = 'jobs/job_list.html'
model = Job
context_object_name = 'job_list'
table_class = JobTable
table_pagination = {'per_page': 20}
filter_class = JobListFilter
formhelper_class = forms.JobListFilterFormHelper
# Columns to exclude in the export
exclude_columns = ('duration', 'job_type', 'contact_name', 'job_status',)
def get_queryset(self):
qs = super(JobList, self).get_queryset()
...
self.filter.form.helper.add_input(
Submit('submit', 'Filter',
css_class='btn pmd-ripple-effect btn-lg btn-primary btn-block',
style='margin-top:10px;')
)
return qs
def get_context_data(self, **kwargs):
context = super(JobList, self).get_context_data(**kwargs)
search_query = self.get_queryset()
table = JobTable(search_query)
RequestConfig(self.request).configure(table)
context['table'] = table
return context
Итак, на ваш взгляд, вы можете добавить класс PagedFilteredTableView
к вашему *На 1022 * выше вашего Sites
класса, затем измените свой Sites
класс следующим образом:
class PagedFilteredTableView(SingleTableView):
filter_class = None
formhelper_class = None
context_filter_name = 'filter'
paginator_class = LazyPaginator
def get_queryset(self, **kwargs):
qs = super(PagedFilteredTableView, self).get_queryset()
self.filter = self.filter_class(self.request.GET, queryset=qs)
self.filter.form.helper = self.formhelper_class()
return self.filter.qs
def get_context_data(self, **kwargs):
context = super(PagedFilteredTableView, self).get_context_data()
context[self.context_filter_name] = self.filter
return context
class Sites(LoginRequiredMixin, ExportMixin, PagedFilteredTableView):
model = Site
table_class = SiteTable
template_name = "app_settings/table_view.html"
login_url = '/login/'
redirect_field_name = 'redirect_to'
filter_class = SiteFilterEx
exclude_columns = ("buttons", )
table_pagination = {'per_page': 20}
def dispatch(self, *args, **kwargs):
site_type = get_object_or_404(SiteType, pk=self.kwargs['site_type'])
site_state = 'Open' if self.kwargs['state'] else 'Closed'
self.site_type_name = '{} {}s'.format(site_state, site_type.site_type)
self.site_type_icon = 'fa {}'.format(site_type.icon)
return super(Sites, self).dispatch(*args, **kwargs)
def get_queryset(self):
site_type = self.kwargs['site_type']
subnet = Subquery(
DeviceCircuitSubnets.objects.filter(device__site_id=OuterRef('id'), \
active_link=True, \
circuit__decommissioned=False
).values('circuit__name')[:1])
active_circuit = Subquery(
DeviceCircuitSubnets.objects.filter(device__site_id=OuterRef('id'), \
active_link=True, \
circuit__decommissioned=False
).values('circuit__name')[:1])
if site_type:
return super(Sites, self).get_queryset().filter(
is_live=self.kwargs['state'], site_type_id=site_type
).annotate(
active_circuit=active_circuit
).prefetch_related('sitesupernet_set')
else:
return super(Sites, self).get_queryset().filter(
is_live=self.kwargs['state']
).annotate(
active_circuit=active_circuit
).prefetch_related('sitesupernet_set')
def get_context_data(self, **kwargs):
context = super().get_context_data(**kwargs)
context['page_icon']=self.site_type_icon
context['page_title']=self.site_type_name
return context