blob: 26b6d32ffba594f329305d0e8d807b69f754881b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
{% extends "base.html" %}
{% load staticfiles %}
{% block content %}
<div class="container-fluid d-flex flex-grow-1 flex-column">
<div class="row mt-3 mb-2">
<div class="col-2 px-0">
<div class="btn-group w-100" id="filterGroup">
<button class="btn btn-secondary active" data-read="-1">All</button>
<button class="btn btn-secondary" data-read="0">Unread</button>
<button class="btn btn-secondary" data-read="1">Read</button>
</div>
</div>
</div>
<div class="row flex-grow-1" id="fixHeight">
<!-- Notification list && Controls -->
<div class="mb-2 mb-lg-0 col-lg-2 px-0 mh-100">
<span class="text-muted d-none" id="noMessages">No messages available</span>
<div class="list-group rounded-0 rounded-left overflow-auto mh-100 notifications" id="unreadNotifications" data-read="0">
{% for notification in unread_notifications %}
<a
href="#"
onclick="showmessage({{notification.id}}); setactive(this);"
class="list-group-item list-group-item-action notification">
{{ notification }}
</a>
{% endfor %}
</div>
<div class="list-group rounded-0 rounded-left overflow-auto mh-100 notifications" id="readNotifications" data-read="1">
{% for notification in read_notifications %}
<a
href="#"
onclick="showmessage({{notification.id}}); setactive(this);"
class="list-group-item list-group-item-action list-group-item-secondary notification">
{{ notification }}
</a>
{% endfor %}
</div>
</div>
<!-- Content -->
<div class="col ml-lg-2 border mh-100 p-4">
<iframe name="messageView" class="w-100 h-100" id="inbox-iframe" frameBorder="0" scrolling="yes">Please select a notification</iframe>
</div>
</div>
</div>
<script type="text/javascript">
function showmessage(msg_id) {
window.frames["messageView"].location = "notification/" + msg_id;
}
function setactive(obj) {
$(".notification").removeClass("active");
$(obj).addClass("active");
}
// Shows messages in the given notification list.
// Shows/hides the 'no messages' span after checking children amount
// given the .notification classed element
function showMessages(notificationList) {
$(".notifications").addClass("d-none");
if (notificationList.children().length < 1) {
$("#noMessages").removeClass("d-none");
} else {
$("#noMessages").addClass("d-none");
notificationList.removeClass("d-none");
}
}
$(document).ready(function(){
// For all / unread / read
$("#filterGroup button").click(function(){
let read = $(this).attr("data-read");
$(this).siblings().removeClass("active");
$(this).addClass("active");
if (read === "-1") {
return showMessages($(".notifications"));
}
return showMessages($(`.notifications[data-read="${read}"]`));
});
showMessages($(".notifications"));
});
</script>
{% endblock %}
|