mirror of
https://github.com/django-helpdesk/django-helpdesk.git
synced 2025-06-20 01:27:44 +02:00
feat: add saved queries list view page with run and delete support
This commit is contained in:
parent
f5f02c28ba
commit
80bd72a171
@ -34,6 +34,12 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
|
<li class="nav-item{% if 'saved-searches' in request.path %} active{% endif %}">
|
||||||
|
<a class="nav-link" href="{% url 'helpdesk:saved_searches_list' %}">
|
||||||
|
<i class="fas fa-fw fa-save"></i>
|
||||||
|
<span>{% trans "Manage Saved Queries" %}</span>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
<li class="nav-item{% if 'submit' in request.path %} active{% endif %}">
|
<li class="nav-item{% if 'submit' in request.path %} active{% endif %}">
|
||||||
<a class="nav-link" href="{% url 'helpdesk:submit' %}">
|
<a class="nav-link" href="{% url 'helpdesk:submit' %}">
|
||||||
<i class="fas fa-fw fa-plus-circle"></i>
|
<i class="fas fa-fw fa-plus-circle"></i>
|
||||||
|
59
helpdesk/templates/helpdesk/saved_searches_list.html
Normal file
59
helpdesk/templates/helpdesk/saved_searches_list.html
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
{% extends "helpdesk/base.html" %}
|
||||||
|
{% load i18n %}
|
||||||
|
|
||||||
|
{% block helpdesk_title %}
|
||||||
|
{% trans "Saved Queries" %}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block helpdesk_breadcrumb %}
|
||||||
|
<li class="breadcrumb-item">
|
||||||
|
<a href="{% url 'helpdesk:list' %}">{% trans "Tickets" %}</a>
|
||||||
|
</li>
|
||||||
|
<li class="breadcrumb-item active">{% trans "Saved Queries" %}</li>
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block helpdesk_body %}
|
||||||
|
<div class="container mt-4">
|
||||||
|
<h3 class="mb-4">{% trans "Saved Queries" %}</h3>
|
||||||
|
|
||||||
|
{% if saved_queries %}
|
||||||
|
<ul class="list-group">
|
||||||
|
{% for q in saved_queries %}
|
||||||
|
<li class="list-group-item d-flex justify-content-between align-items-center">
|
||||||
|
<div>
|
||||||
|
<a href="{% url 'helpdesk:list' %}?saved_query={{ q.id }}" class="text-decoration-none">
|
||||||
|
{{ q.title }}
|
||||||
|
{% if q.shared %}
|
||||||
|
<small class="text-muted ms-2 fst-italic">
|
||||||
|
{% if q.user == user %}
|
||||||
|
({% trans "Shared" %})
|
||||||
|
{% else %}
|
||||||
|
({% trans "Shared by" %} {{ q.user.get_username }})
|
||||||
|
{% endif %}
|
||||||
|
</small>
|
||||||
|
{% endif %}
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="d-flex">
|
||||||
|
<a href="{% url 'helpdesk:list' %}?saved_query={{ q.id }}"
|
||||||
|
class="btn btn-sm btn-outline-primary mr-2"
|
||||||
|
title="{% trans 'Run this query' %}">
|
||||||
|
<i class="fas fa-play"></i> {% trans "Run" %}
|
||||||
|
</a>
|
||||||
|
|
||||||
|
{% if q.user == user %}
|
||||||
|
<a href="{% url 'helpdesk:delete_query' q.id %}"
|
||||||
|
class="btn btn-sm btn-outline-danger"
|
||||||
|
title="{% trans 'Delete this query' %}">
|
||||||
|
<i class="fas fa-trash"></i>
|
||||||
|
</a>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
{% else %}
|
||||||
|
<p>{% trans "No saved queries found." %}</p>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
{% endblock %}
|
@ -119,6 +119,7 @@ urlpatterns = [
|
|||||||
path("rss/", staff.rss_list, name="rss_index"),
|
path("rss/", staff.rss_list, name="rss_index"),
|
||||||
path("reports/", staff.report_index, name="report_index"),
|
path("reports/", staff.report_index, name="report_index"),
|
||||||
re_path(r"^reports/(?P<report>\w+)/$", staff.run_report, name="run_report"),
|
re_path(r"^reports/(?P<report>\w+)/$", staff.run_report, name="run_report"),
|
||||||
|
path("saved-searches/", staff.saved_searches_list, name="saved_searches_list"),
|
||||||
path("save_query/", staff.save_query, name="savequery"),
|
path("save_query/", staff.save_query, name="savequery"),
|
||||||
path("delete_query/<int:pk>/", staff.delete_saved_query, name="delete_query"),
|
path("delete_query/<int:pk>/", staff.delete_saved_query, name="delete_query"),
|
||||||
path("settings/", staff.EditUserSettingsView.as_view(), name="user_settings"),
|
path("settings/", staff.EditUserSettingsView.as_view(), name="user_settings"),
|
||||||
|
@ -1687,6 +1687,23 @@ def run_report(request, report):
|
|||||||
run_report = staff_member_required(run_report)
|
run_report = staff_member_required(run_report)
|
||||||
|
|
||||||
|
|
||||||
|
@helpdesk_staff_member_required
|
||||||
|
def saved_searches_list(request):
|
||||||
|
user = request.user
|
||||||
|
saved_queries = SavedSearch.objects.filter(Q(user=user) | Q(shared=True)).distinct()
|
||||||
|
|
||||||
|
return render(
|
||||||
|
request,
|
||||||
|
"helpdesk/saved_searches_list.html",
|
||||||
|
{
|
||||||
|
"saved_queries": saved_queries,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
saved_searches_list = staff_member_required(saved_searches_list)
|
||||||
|
|
||||||
|
|
||||||
@helpdesk_staff_member_required
|
@helpdesk_staff_member_required
|
||||||
def save_query(request):
|
def save_query(request):
|
||||||
title = request.POST.get("title", None)
|
title = request.POST.get("title", None)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user