2020-08-12 00:36:09 +00:00
|
|
|
<ul class="navbar-nav ml-auto">
|
2023-01-25 22:26:04 +00:00
|
|
|
<li class="nav-item dropdown">
|
2023-09-01 18:48:20 +00:00
|
|
|
<a class="nav-link count-indicator dropdown-toggle" id="notifDropdown" href="#" data-toggle="dropdown"
|
|
|
|
aria-expanded="false">
|
2023-01-25 22:26:04 +00:00
|
|
|
<i class="fas fa-broadcast-tower
|
2020-09-23 01:42:41 +00:00
|
|
|
{% if data.get('update_available') %}
|
|
|
|
text-danger
|
|
|
|
{% end %}
|
2023-09-01 18:48:20 +00:00
|
|
|
"></i><span id="notif-count" class="badge badge-notify"></span> </a>
|
|
|
|
<div class="dropdown-menu dropdown-menu-right navbar-dropdown" style="width: 40vw;" aria-labelledby="notifDropdown">
|
|
|
|
<ul id="announcements">
|
|
|
|
</ul>
|
|
|
|
</div>
|
2023-01-25 22:26:04 +00:00
|
|
|
</li>
|
2020-12-06 20:42:49 +00:00
|
|
|
|
2023-01-25 22:26:04 +00:00
|
|
|
<li class="nav-item dropdown">
|
2023-09-01 18:48:20 +00:00
|
|
|
<a class="nav-link" href="/panel/panel_config">
|
2023-01-25 22:26:04 +00:00
|
|
|
<i class="fas fa-cogs"></i>
|
|
|
|
</a>
|
|
|
|
</li>
|
2020-12-06 20:42:49 +00:00
|
|
|
|
2023-01-25 22:26:04 +00:00
|
|
|
<li class="nav-item dropdown user-dropdown">
|
|
|
|
<a class="nav-link dropdown-toggle" id="UserDropdown" href="#" data-toggle="dropdown" aria-expanded="false">
|
2023-09-01 18:48:20 +00:00
|
|
|
<img class="img-xs rounded-circle profile-picture" onerror="pfpError(this)" src="{{ data['user_data']['pfp'] }}"
|
|
|
|
alt="Profile image"> </a>
|
2023-01-25 22:26:04 +00:00
|
|
|
<div class="dropdown-menu dropdown-menu-right navbar-dropdown" aria-labelledby="UserDropdown">
|
|
|
|
<div class="dropdown-header text-center">
|
2023-09-01 18:48:20 +00:00
|
|
|
<img class="img-md rounded-circle profile-picture" onerror="pfpError(this)" src="{{ data['user_data']['pfp'] }}"
|
|
|
|
alt="Profile image">
|
2023-01-25 22:26:04 +00:00
|
|
|
<p class="mb-1 mt-3 font-weight-semibold">{{ data['user_data']['username'] }}</p>
|
|
|
|
<p class="font-weight-light text-muted mb-0">Roles: </p>
|
|
|
|
{% for r in data['user_role'] %}
|
|
|
|
<p class="font-weight-light text-muted mb-0">{{ r }}</p>
|
2022-03-13 12:29:26 +00:00
|
|
|
{% end %}
|
2023-01-25 22:26:04 +00:00
|
|
|
{% if data.get('api_key') %}
|
|
|
|
<p class="mt-3">Logged in as API key "{{ data['api_key']['name'] }}"</p>
|
2021-09-14 02:02:57 +00:00
|
|
|
{% end %}
|
2023-01-25 22:26:04 +00:00
|
|
|
<p class="font-weight-light text-muted mb-0">Email: {{ data['user_data']['email'] }}</p>
|
2020-08-12 00:36:09 +00:00
|
|
|
</div>
|
2023-01-25 22:26:04 +00:00
|
|
|
{% if data['user_data']['preparing'] %}
|
2023-09-01 18:48:20 +00:00
|
|
|
<span class="dropdown-item" id="support_progress"><i
|
|
|
|
class="dropdown-item-icon mdi mdi-download-outline text-primary"></i>{{ translate('notify', 'supportLogs',
|
|
|
|
data['lang']) }}<br><br></span>
|
2023-01-25 22:26:04 +00:00
|
|
|
<span class="dropdown-item" id="support_progress">
|
|
|
|
<div class="support_progress" style="height: 15px; width: 100%;">
|
2023-09-01 18:48:20 +00:00
|
|
|
<div class="progress-bar progress-bar-striped progress-bar-animated" id="logs_progress_bar" role="progressbar"
|
|
|
|
style="width:0%;" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100">0%</div>
|
2023-01-25 22:26:04 +00:00
|
|
|
</div>
|
|
|
|
</span>
|
|
|
|
{% else %}
|
2023-09-01 18:48:20 +00:00
|
|
|
<a class="dropdown-item" id="support_logs"><i
|
|
|
|
class="dropdown-item-icon mdi mdi-download-outline text-primary"></i>{{ translate('notify', 'supportLogs',
|
|
|
|
data['lang']) }}</i></a>
|
2023-01-25 22:26:04 +00:00
|
|
|
{% end %}
|
|
|
|
{% if data['superuser'] %}
|
2023-09-01 18:48:20 +00:00
|
|
|
<a class="dropdown-item" href="/panel/activity_logs"><i
|
|
|
|
class="dropdown-item-icon mdi mdi-calendar-check-outline text-primary"></i>{{ translate('notify',
|
|
|
|
'activityLog', data['lang']) }}</a>
|
2023-01-25 22:26:04 +00:00
|
|
|
{% end %}
|
2023-09-01 18:48:20 +00:00
|
|
|
<a class="dropdown-item" href="/logout"><i class="dropdown-item-icon mdi mdi-power text-primary"></i>{{
|
|
|
|
translate('notify', 'logout', data['lang']) }}</a>
|
2023-01-25 22:26:04 +00:00
|
|
|
</div>
|
|
|
|
</li>
|
|
|
|
</ul>
|
2023-09-01 18:48:20 +00:00
|
|
|
<style>
|
|
|
|
.badge-notify {
|
|
|
|
background: var(--purple);
|
|
|
|
position: absolute;
|
|
|
|
-moz-transform: translate(-70%, -70%);
|
|
|
|
/* For Firefox */
|
|
|
|
-ms-transform: translate(-70%, -70%);
|
|
|
|
/* for IE */
|
|
|
|
-webkit-transform: translate(-70%, -70%);
|
|
|
|
/* For Safari, Chrome, iOS */
|
|
|
|
-o-transform: translate(-70%, -70%);
|
|
|
|
}
|
2022-09-12 19:34:47 +00:00
|
|
|
|
2023-09-01 18:48:20 +00:00
|
|
|
.clear-button:hover {
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
</style>
|
2023-01-25 22:26:04 +00:00
|
|
|
<script>
|
|
|
|
function pfpError(image) {
|
2022-09-12 19:34:47 +00:00
|
|
|
image.onerror = "";
|
|
|
|
image.src = "/static/assets/images/faces-clipart/pic-3.png";
|
|
|
|
return true;
|
|
|
|
}
|
2023-09-01 18:48:20 +00:00
|
|
|
function updateAnnouncements(data) {
|
|
|
|
console.log(data)
|
|
|
|
let text = "";
|
|
|
|
for (i = 0; i < data.length; i++) {
|
|
|
|
text += `<li id="${data[i].id}"><p style="float: right;"><i data-id="${data[i].id}"class="clear-button fa-regular fa-x"></i></p><a style="color: var(--purple);" href=${data[i].link} target="_blank"><h6>${data[i].title}</h6><small><p>${data[i].date}</p></small><p>${data[i].desc}</p></li></a>`
|
|
|
|
}
|
|
|
|
if (data.length > 0) {
|
|
|
|
localStorage.setItem("notif-count", data.length);
|
|
|
|
$("#notif-count").html(data.length);
|
|
|
|
$("#announcements").html(text);
|
|
|
|
} else {
|
|
|
|
$("#announcements").html("<p style='margin-top: 15px;' class='text-center'>No notifications</p>");
|
|
|
|
}
|
|
|
|
$(".clear-button").on("click", function (event) {
|
|
|
|
console.log("CLEAR BUTTON")
|
|
|
|
let uuid = event.target.getAttribute("data-id");
|
|
|
|
$(`#${uuid}`).remove();
|
|
|
|
send_clear(uuid);
|
|
|
|
notif_count = localStorage.getItem("notif-count") - 1;
|
|
|
|
if (notif_count > 0) {
|
|
|
|
localStorage.setItem("notif-count", notif_count);
|
|
|
|
$("#notif-count").html(notif_count);
|
|
|
|
} else {
|
|
|
|
$("#announcements").html("<p style='margin-top: 15px;' class='text-center'>No notifications</p>")
|
|
|
|
$("#notif-count").html("");
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
async function getAnnouncements() {
|
|
|
|
var token = getCookie("_xsrf");
|
|
|
|
let res = await fetch(`/api/v2/crafty/announcements/`, {
|
|
|
|
method: 'GET',
|
|
|
|
headers: {
|
|
|
|
'X-XSRFToken': token
|
|
|
|
},
|
|
|
|
});
|
|
|
|
let responseData = await res.json();
|
|
|
|
console.log(responseData);
|
|
|
|
if (responseData.status === "ok") {
|
|
|
|
updateAnnouncements(responseData.data)
|
|
|
|
} else {
|
|
|
|
updateAnnouncements("<li><p>Trouble Getting Annoucements</p></li>")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
async function send_clear(uuid) {
|
|
|
|
var token = getCookie("_xsrf");
|
|
|
|
let body = JSON.stringify({ "id": uuid });
|
|
|
|
console.log(body)
|
|
|
|
let res = await fetch(`/api/v2/crafty/announcements/`, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'X-XSRFToken': token,
|
|
|
|
},
|
|
|
|
body: body,
|
|
|
|
});
|
|
|
|
let responseData = await res.json();
|
|
|
|
console.log(responseData);
|
|
|
|
if (responseData.status === "ok") {
|
|
|
|
return
|
|
|
|
} else {
|
|
|
|
bootbox.alert(responseData.error)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$(document).ready(function () {
|
|
|
|
getAnnouncements();
|
|
|
|
})
|
2023-01-25 22:26:04 +00:00
|
|
|
</script>
|