mirror of
https://github.com/django-helpdesk/django-helpdesk.git
synced 2025-06-20 09:37:48 +02:00
Merge branch 'main' into ui/helpdesk-template-enhancements
This commit is contained in:
commit
a12ca9e155
15
helpdesk/templates/helpdesk/filters/priority.html
Normal file
15
helpdesk/templates/helpdesk/filters/priority.html
Normal 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>
|
@ -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 %}
|
@ -171,6 +171,9 @@
|
|||||||
<option id="filterBuilderSelect-Sort" value="Sort"{% if query_params.sorting %} disabled{% endif %}>
|
<option id="filterBuilderSelect-Sort" value="Sort"{% if query_params.sorting %} disabled{% endif %}>
|
||||||
{% trans "Sorting" %}
|
{% trans "Sorting" %}
|
||||||
</option>
|
</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 %}>
|
<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" %}
|
{% trans "Owner" %}
|
||||||
</option>
|
</option>
|
||||||
@ -201,6 +204,10 @@
|
|||||||
id="filterBoxSort">
|
id="filterBoxSort">
|
||||||
{% include 'helpdesk/filters/sorting.html' %}
|
{% include 'helpdesk/filters/sorting.html' %}
|
||||||
</li>
|
</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"
|
<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>
|
id=filterBoxOwner>
|
||||||
{% include 'helpdesk/filters/owner.html' %}
|
{% include 'helpdesk/filters/owner.html' %}
|
||||||
|
@ -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"),
|
||||||
|
@ -1077,6 +1077,7 @@ def ticket_list(request):
|
|||||||
"queue",
|
"queue",
|
||||||
"assigned_to",
|
"assigned_to",
|
||||||
"status",
|
"status",
|
||||||
|
"priority",
|
||||||
"q",
|
"q",
|
||||||
"sort",
|
"sort",
|
||||||
"sortreverse",
|
"sortreverse",
|
||||||
@ -1089,6 +1090,7 @@ def ticket_list(request):
|
|||||||
("queue", "queue__id__in"),
|
("queue", "queue__id__in"),
|
||||||
("assigned_to", "assigned_to__id__in"),
|
("assigned_to", "assigned_to__id__in"),
|
||||||
("status", "status__in"),
|
("status", "status__in"),
|
||||||
|
("priority", "priority__in"),
|
||||||
("kbitem", "kbitem__in"),
|
("kbitem", "kbitem__in"),
|
||||||
]
|
]
|
||||||
filter_null_params = dict(
|
filter_null_params = dict(
|
||||||
@ -1096,6 +1098,7 @@ def ticket_list(request):
|
|||||||
("queue", "queue__id__isnull"),
|
("queue", "queue__id__isnull"),
|
||||||
("assigned_to", "assigned_to__id__isnull"),
|
("assigned_to", "assigned_to__id__isnull"),
|
||||||
("status", "status__isnull"),
|
("status", "status__isnull"),
|
||||||
|
("priority", "priority__isnull"),
|
||||||
("kbitem", "kbitem__isnull"),
|
("kbitem", "kbitem__isnull"),
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
@ -1187,6 +1190,7 @@ def ticket_list(request):
|
|||||||
kb_items=kbitem,
|
kb_items=kbitem,
|
||||||
queue_choices=huser.get_queues(),
|
queue_choices=huser.get_queues(),
|
||||||
status_choices=Ticket.STATUS_CHOICES,
|
status_choices=Ticket.STATUS_CHOICES,
|
||||||
|
priority_choices=Ticket.PRIORITY_CHOICES,
|
||||||
kbitem_choices=kbitem_choices,
|
kbitem_choices=kbitem_choices,
|
||||||
urlsafe_query=urlsafe_query,
|
urlsafe_query=urlsafe_query,
|
||||||
user_saved_queries=user_saved_queries,
|
user_saved_queries=user_saved_queries,
|
||||||
@ -1687,6 +1691,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