Merge branch 'main' into ui/helpdesk-template-enhancements

This commit is contained in:
Christopher Broderick 2025-06-08 15:11:25 +02:00 committed by GitHub
commit a12ca9e155
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 109 additions and 0 deletions

View File

@ -0,0 +1,15 @@
{% load i18n humanize %}
{% load static %}
{% load in_list %}
<div class="form-row">
<div class="col col-sm-3">
<label for='id_priority'>{% trans "Priority" %}:</label>
</div>
<div class="col col-sm-3">
<select id='id_priority' name='priority' multiple='selected' size='5'>{% for p in priority_choices %}<option value='{{ p.0 }}'{% if p.0|in_list:query_params.filtering.priority__in %} selected='selected'{% endif %}>{{ p.1 }}</option>{% endfor %}</select>
</div>
<div class="col col-sm-6">
<button class="filterBuilderRemove btn btn-danger btn-sm float-right"><i class="fas fa-trash-alt"></i></button>
</div>
<div class='form-row filterHelp'>{% trans "Ctrl-click to select multiple options" %}</div>
</div>

View File

@ -34,6 +34,12 @@
{% endif %}
</div>
</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 %}">
<a class="nav-link" href="{% url 'helpdesk:submit' %}">
<i class="fas fa-fw fa-plus-circle"></i>

View 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 %}

View File

@ -171,6 +171,9 @@
<option id="filterBuilderSelect-Sort" value="Sort"{% if query_params.sorting %} disabled{% endif %}>
{% trans "Sorting" %}
</option>
<option id="filterBuilderSelect-Priority" value="Priority"{% if query_params.filtering.priority__in %} disabled{% endif %}>
{% trans "Priority" %}
</option>
<option id="filterBuilderSelect-Owner" value="Owner"{% if query_params.filtering.assigned_to__id__in or query_params.filtering_null.assigned_to__id__isnull %} disabled{% endif %}>
{% trans "Owner" %}
</option>
@ -201,6 +204,10 @@
id="filterBoxSort">
{% include 'helpdesk/filters/sorting.html' %}
</li>
<li class="list-group-item filterBox{% if query_params.filtering.priority__in %} filterBoxShow{% endif %}"
id="filterBoxPriority">
{% include 'helpdesk/filters/priority.html' %}
</li>
<li class="filterBox{% if query_params.filtering.assigned_to__id__in or query_params.filtering_null.assigned_to__id__isnull %} filterBoxShow{% endif %} list-group-item"
id=filterBoxOwner>
{% include 'helpdesk/filters/owner.html' %}

View File

@ -119,6 +119,7 @@ urlpatterns = [
path("rss/", staff.rss_list, name="rss_index"),
path("reports/", staff.report_index, name="report_index"),
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("delete_query/<int:pk>/", staff.delete_saved_query, name="delete_query"),
path("settings/", staff.EditUserSettingsView.as_view(), name="user_settings"),

View File

@ -1077,6 +1077,7 @@ def ticket_list(request):
"queue",
"assigned_to",
"status",
"priority",
"q",
"sort",
"sortreverse",
@ -1089,6 +1090,7 @@ def ticket_list(request):
("queue", "queue__id__in"),
("assigned_to", "assigned_to__id__in"),
("status", "status__in"),
("priority", "priority__in"),
("kbitem", "kbitem__in"),
]
filter_null_params = dict(
@ -1096,6 +1098,7 @@ def ticket_list(request):
("queue", "queue__id__isnull"),
("assigned_to", "assigned_to__id__isnull"),
("status", "status__isnull"),
("priority", "priority__isnull"),
("kbitem", "kbitem__isnull"),
]
)
@ -1187,6 +1190,7 @@ def ticket_list(request):
kb_items=kbitem,
queue_choices=huser.get_queues(),
status_choices=Ticket.STATUS_CHOICES,
priority_choices=Ticket.PRIORITY_CHOICES,
kbitem_choices=kbitem_choices,
urlsafe_query=urlsafe_query,
user_saved_queries=user_saved_queries,
@ -1687,6 +1691,23 @@ def run_report(request, 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
def save_query(request):
title = request.POST.get("title", None)