Как отобразить только форму фильтра? - PullRequest
0 голосов
/ 21 апреля 2019

Итак, я установил фильтр для моей модели. Ниже работает просто отлично. Однако, когда я нажимаю фильтр (на home.html), он сначала извлекает и отображает всю базу данных под формой фильтра (см. Скриншот).

enter image description here

Я не хочу, чтобы программа сначала извлекала все данные из базы данных. Вместо этого мне бы хотелось, чтобы, когда я нажимал фильтр из home.html, отображал только форму фильтра, затем ждал ввода пользователя и отображал результат под формой.

views.py:

def search(request):
    option = option2019.objects.get_queryset()
    option_filter = optionFilter(request.GET, queryset=option)
    return render(request, 'option.html', {'filter':option_filter})

url.py

urlpatterns = [
path('simple_upload', views.simple_upload, name='simple_upload'),
path('search/', FilterView.as_view(filterset_class=optionFilter, template_name='option.html'), name='search'),
path('OptionUpdate/<int:id>', views.OptionUpdate.as_view(), name='OptionUpdate'),]

option.html:

{% extends 'base.html' %}

{% load widget_tweaks %}


{% block content %}
{% if user.is_authenticated %}
<form method="get">
    <div class="well container">
        <h4 style="margin-top: 0">Filter</h4>

        {{ filter.form.as_p }}

        <button type="submit" class="btn btn-primary"> Search </button>
    </div>
</form>



<div style="margin: 20px;">
    <h3>Demographics:</h3>
    <table class="table table-bordered">
        <thead class="thead-dark">
            <tr>
                <th>Last Name</th>
                <th>First Name</th>
                <th>DOB</th>
                <th>SSN</th>
                <th>Home Phone</th>
                <th>Phone1</th>
                <th>Phone2</th>
            </tr>
        </thead>

        <tbody>
            {% for hha in filter.qs %}
            <tr>
                <td>{{ hha.LastName }}</td>
                <td>{{ hha.FirstName }}</td>
                <td>{{ hha.dob }}</td>
                <td>{{ hha.SSN }}</td>
                <td>{{ hha.HomePhone}}</td>
                <td>{{ hha.Phone1}}</td>
                <td>{{ hha.Phone2}}</td>
            </tr>
            {% endfor %}
        </tbody>
    </table>
</div>


<div style="margin: 20px;">
    <h3>Records:</h3>
    <table class="table table-bordered">
        <thead class="thead-dark">
            <tr>

                <th>Option</th>
                <th>Medical Option</th>
                <th>WP Default</th>
                <th>TRN</th>
                <th>PKG</th>
                <th>CELL</th>
                <th>DCA</th>
                <th>HRP</th>
                <th>Remarks</th>
                <th>Option Changed</th>
                <th>Updated PP</th>
                <th>Updated By</th>
            </tr>
        </thead>

        <tbody>
            {% for hha in filter.qs %}
            <tr>

                <td style="background-color: #82b74b">{{ hha.option }}</td>
                <td>{{ hha.medical }}</td>
                <td>{{ hha.WPDefault }}</td>
                <td style="background-color:#b7d7e8">${{ hha.trn }}</td>
                <td style="background-color:#b7d7e8">${{ hha.pkg }}</td>
                <td style="background-color:#b7d7e8">${{ hha.cell }}</td>
                <td style="background-color:#b7d7e8">${{ hha.dca }}</td>
                <td style="background-color:#b7d7e8">${{ hha.hrp }}</td>
                <td>{{ hha.Remarks }}</td>
                <td>{{ hha.OptionChanged }}</td>
                <td>{{ hha.updated }}</td>
                <td>{{ hha.updatedBy }}</td>
                <td>
                    <a href="{% url 'HHA_2019_Records:OptionUpdate' hha.id %}"><span>Edit</span></a>
                </td>
            </tr>
            {% endfor %}
        </tbody>
    </table>
</div>

{% else %}
{% endif %}
{% endblock %}

Ценим любую помощь !!

1 Ответ

0 голосов
/ 21 апреля 2019

По вашему мнению, вы можете проверить, есть ли в форме данные, например, bool(self.form.cleaned_data) затем обновил шаблон, чтобы показать или скрыть результаты по мере необходимости.

...