2020-08-12 00:36:09 +00:00
<!DOCTYPE html>
2022-03-05 11:01:36 +00:00
< html lang = "{{ data['lang_page'] }}" >
2020-09-22 22:23:14 +00:00
2022-01-21 22:50:04 +00:00
< head >
<!-- Required meta tags -->
< meta charset = "utf-8" >
< meta name = "viewport" content = "width=device-width, initial-scale=1, shrink-to-fit=no" >
{% block meta %}{% end %}
< title > {% block title %}{{ _('Default') }}{% end %}< / title >
<!-- plugins:css -->
< link rel = "stylesheet" href = "/static/assets/vendors/mdi/css/materialdesignicons.min.css" >
< link rel = "stylesheet" href = "/static/assets/vendors/flag-icon-css/css/flag-icon.min.css" >
< link rel = "stylesheet" href = "/static/assets/vendors/ti-icons/css/themify-icons.css" >
< link rel = "stylesheet" href = "/static/assets/vendors/typicons/typicons.css" >
< link rel = "stylesheet" href = "/static/assets/vendors/fontawesome5/css/all.css" >
< link rel = "stylesheet" type = "text/css"
href="https://cdn.datatables.net/v/bs4/dt-1.10.22/fh-3.1.7/r-2.2.6/sc-2.0.3/sp-1.2.2/datatables.min.css" />
< link rel = "stylesheet" href = "/static/assets/vendors/css/vendor.bundle.base.css" >
< link rel = "stylesheet" href = "/static/assets/css/crafty.css" >
<!-- endinject -->
2022-05-31 00:57:19 +00:00
<!-- Plugin css for this page -->
< link rel = "stylesheet" href = "/static/assets/vendors/jvectormap/jquery-jvectormap.css" >
< script src = "https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js" > < / script >
<!-- End Plugin css for this page -->
2022-01-21 22:50:04 +00:00
<!-- Layout styles -->
< link rel = "stylesheet" href = "/static/assets/css/dark/style.css" >
<!-- End Layout styles -->
< link rel = "shortcut icon" type = "image/svg+xml" href = "/static/assets/images/logo_small.svg" >
< link rel = "alternate icon" href = "/static/assets/images/favicon.png" / >
< link rel = "stylesheet" href = "/static/assets/css/crafty.css" >
2022-02-27 17:26:54 +00:00
<!-- Alpine.js - The modern jQuery alternative -->
< script defer src = "https://unpkg.com/alpinejs@3.x.x/dist/cdn.min.js" > < / script >
<!-- End Alpine.js -->
2022-01-21 22:50:04 +00:00
< / head >
< body class = "dark-theme" >
< div class = "container-scroller" >
<!-- partial:partials/_navbar.html -->
< nav class = "navbar default-layout col-lg-12 col-12 p-0 fixed-top d-flex flex-row" >
< div class = "text-center navbar-brand-wrapper d-flex align-items-top justify-content-center" >
< a class = "navbar-brand brand-logo" href = "/panel/dashboard" >
< img src = "/static/assets/images/logo_long.svg" alt = "logo" / > < / a >
< a class = "navbar-brand brand-logo-mini" href = "/panel/dashboard" >
< img src = "/static/assets/images/logo_small.svg" alt = "logo" / > < / a >
< / div >
< div class = "navbar-menu-wrapper d-flex align-items-center" >
2022-02-09 22:26:16 +00:00
< style >
2022-05-24 01:23:29 +00:00
body:not(.sidebar-icon-only) .navbar-toggler .mdi-chevron-double-right {
2022-02-09 22:26:16 +00:00
display: none;
2022-05-24 01:23:29 +00:00
}
body.sidebar-icon-only .navbar-toggler .mdi-chevron-double-left {
2022-02-09 22:26:16 +00:00
display: none;
2022-05-24 01:23:29 +00:00
}
2022-02-09 22:26:16 +00:00
< / style >
2022-01-21 22:50:04 +00:00
< button class = "navbar-toggler navbar-toggler align-self-center" type = "button" data-toggle = "minimize" >
2022-02-09 22:26:16 +00:00
< span class = "mdi mdi-chevron-double-left" > < / span >
< span class = "mdi mdi-chevron-double-right" > < / span >
2022-01-21 22:50:04 +00:00
< / button >
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
{% include notify.html %}
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
< button class = "navbar-toggler navbar-toggler-right d-lg-none align-self-center" type = "button"
data-toggle="offcanvas">
< span class = "mdi mdi-menu" > < / span >
< / button >
< / div >
< / nav >
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
{% include main_menu.html %}
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
< div class = "main-panel" >
2020-12-17 13:39:29 +00:00
2022-01-21 22:50:04 +00:00
< div class = "warnings" >
< noscript class = "noscript-warning" style = "padding: 20px; background-color: rgb(247, 151, 15);" >
< div > {% raw translate('base', 'doesNotWorkWithoutJavascript', data['lang']) %}< / div >
< / noscript >
< / div >
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
{% block content %}
{% end %}
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
{% include footer.html %}
2020-08-12 00:36:09 +00:00
< / div >
2022-01-21 22:50:04 +00:00
<!-- main - panel ends -->
2020-08-23 22:43:28 +00:00
2022-01-21 22:50:04 +00:00
< / div >
<!-- page - body - wrapper ends -->
< / div >
2020-08-23 22:43:28 +00:00
2021-02-27 12:05:04 +00:00
2022-01-21 22:50:04 +00:00
< style >
.notifications {
position: fixed;
width: 200px;
top: 70px;
right: 0px;
}
2021-02-27 12:05:04 +00:00
2022-01-21 22:50:04 +00:00
.notification {
position: relative;
box-sizing: border-box;
padding: 0.5rem;
padding-left: 0.7rem;
width: 180px;
margin-left: 10px;
margin-right: 10px;
background: #282a40;
transition: right 0.75s, opacity 0.75s, top 0.75s;
right: -6rem;
opacity: 0.1;
margin-bottom: 1rem;
z-index: 999;
top: 0px;
}
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
.notification.active {
right: 0rem;
opacity: 1;
}
.notification.remove {
right: 0rem;
opacity: 0.1;
top: -2rem;
}
.notification p {
margin: 0px;
width: calc(160.8px - 16px);
z-index: inherit;
}
.notification span {
position: absolute;
right: 0.5rem;
top: 0.46rem;
cursor: pointer;
font-weight: bold;
line-height: 20px;
font-size: 22px;
user-select: none;
z-index: inherit;
}
< / style >
< div class = "notifications" > < / div >
< script src = "/static/assets/vendors/js/vendor.bundle.base.js" > < / script >
< script src = "/static/assets/js/shared/off-canvas.js" > < / script >
< script src = "/static/assets/js/shared/hoverable-collapse.js" > < / script >
< script src = "/static/assets/js/shared/misc.js" > < / script >
2022-05-24 01:23:29 +00:00
< script type = "text/javascript"
src="https://cdn.datatables.net/v/bs4/dt-1.10.22/fh-3.1.7/r-2.2.6/sc-2.0.3/sp-1.2.2/datatables.min.js">< / script >
2022-01-21 22:50:04 +00:00
< script src = "https://cdnjs.cloudflare.com/ajax/libs/bootbox.js/5.4.0/bootbox.min.js" > < / script >
< script type = "text/javascript" src = "/static/assets/js/motd.js" > < / script >
< script >
$.extend($.fn.dataTable.defaults, {
language: {% raw translate('datatables', 'i18n', data['lang']) %}
2021-03-26 13:57:50 +00:00
})
2021-01-11 19:51:38 +00:00
2022-01-21 22:50:04 +00:00
//used to get cookies from browser - this is part of tornados xsrf protection - it's for extra security
function getCookie(name) {
var r = document.cookie.match("\\b" + name + "=([^;]*)\\b");
return r ? r[1] : undefined;
2020-08-24 23:11:17 +00:00
}
2021-03-26 13:57:50 +00:00
// tool tips
2020-08-24 23:11:17 +00:00
$(function () {
$('[data-toggle="tooltip"]').tooltip()
})
2020-09-23 01:42:41 +00:00
2021-03-26 13:57:50 +00:00
// Notify
2022-01-21 22:50:04 +00:00
$(document).ready(function () {
$("#notificationDropdown").click(function () {
$.get("/ajax/announcements", function (data) {
2020-09-23 01:42:41 +00:00
console.log(data);
bootbox.alert({
2022-01-21 22:50:04 +00:00
title: "Notifications",
message: data,
2020-09-23 01:42:41 +00:00
});
});
});
});
2020-12-17 13:39:29 +00:00
2021-03-26 13:57:50 +00:00
// {% if request.protocol == 'https' %}
2022-01-21 22:50:04 +00:00
let usingWebSockets = true;
let listenEvents = [];
try {
pageQueryParams = 'page_query_params=' + encodeURIComponent(location.search)
page = 'page=' + encodeURIComponent(location.pathname)
var wsInternal = new WebSocket('wss://' + location.host + '/ws?' + page + '& ' + pageQueryParams);
wsInternal.onopen = function () {
console.log('opened WebSocket connection:', wsInternal)
};
wsInternal.onmessage = function (rawMessage) {
var message = JSON.parse(rawMessage.data);
console.log('got message: ', message)
listenEvents
.filter(listenedEvent => listenedEvent.event == message.event)
.forEach(listenedEvent => listenedEvent.callback(message.data))
};
wsInternal.onerror = function (errorEvent) {
console.error('WebSocket Error', errorEvent);
2022-05-24 23:11:14 +00:00
warn('WebSockets are required for Crafty to work. This websocket connection has been closed. Are you using a reverse proxy?', 'https://wiki.craftycontrol.com/en/4/docs/Reverse%20Proxy%20Examples')
2022-03-13 12:44:19 +00:00
2022-01-21 22:50:04 +00:00
};
wsInternal.onclose = function (closeEvent) {
console.log('Closed WebSocket', closeEvent);
2022-05-24 01:23:29 +00:00
warn('WebSockets are required for Crafty to work. This websocket connection has been closed. Are you using a reverse proxy?', 'https://wiki.craftycontrol.com/en/4/docs/Reverse%20Proxy%20Examples')
2022-01-21 22:50:04 +00:00
};
webSocket = {
on: function (event, callback) {
console.log('registered ' + event + ' event');
listenEvents.push({ event: event, callback: callback })
},
emit: function (event, data) {
var message = {
event: event,
data: data
2020-12-17 13:39:29 +00:00
}
2022-01-21 22:50:04 +00:00
wsInternal.send(JSON.stringify(message));
2020-12-17 13:39:29 +00:00
}
}
2022-01-21 22:50:04 +00:00
} catch (error) {
console.error('Error while making websocket helpers', error);
usingWebSockets = false;
}
2021-03-26 13:57:50 +00:00
// {% else %}
2022-01-21 22:50:04 +00:00
let usingWebSockets = false;
warn('WebSockets are not supported in Crafty if not using the https protocol')
var webSocket;
2021-03-26 13:57:50 +00:00
// {% end%}
2020-12-17 13:39:29 +00:00
2022-01-21 22:50:04 +00:00
if (webSocket) {
webSocket.on('send_start_error', function (start_error) {
var x = document.querySelector('.bootbox');
if (x) {
x.remove()
}
var x = document.querySelector('.modal-backdrop');
if (x) {
x.remove()
}
bootbox.alert({
message: start_error.error,
callback: function () {
location.reload();
}
})
});
2021-09-13 17:10:34 +00:00
}
2022-03-13 12:29:26 +00:00
if (webSocket) {
webSocket.on('support_status_update', function (logs) {
2022-05-24 01:23:29 +00:00
if (logs.percent >= 100) {
2022-03-13 12:29:26 +00:00
document.getElementById('logs_progress_bar').innerHTML = '100%';
document.getElementById('logs_progress_bar').style.width = '100%';
2022-05-24 01:23:29 +00:00
} else {
document.getElementById('logs_progress_bar').innerHTML = logs.percent + '%';
2022-03-13 12:29:26 +00:00
document.getElementById('logs_progress_bar').style.width = logs.percent + '%';
}
});
}
2022-01-21 22:50:04 +00:00
if (webSocket) {
webSocket.on('send_logs_bootbox', function (server_id) {
var x = document.querySelector('.bootbox');
if (x) {
x.remove()
2022-01-14 01:42:53 +00:00
}
2022-01-21 22:50:04 +00:00
var x = document.querySelector('.modal-backdrop');
if (x) {
x.remove()
2021-11-23 21:11:23 +00:00
}
2022-01-21 22:50:04 +00:00
bootbox.alert({
title: "{{ translate('notify', 'downloadLogs', data['lang']) }}",
message: "{{ translate('notify', 'finishedPreparing', data['lang']) }}",
buttons: {
ok: {
label: 'Download',
className: 'btn-info'
}
},
callback: function () {
console.log("in callback")
location.href = "/panel/download_support_package";
}
});
});
2021-11-23 21:11:23 +00:00
}
2022-01-21 22:50:04 +00:00
if (webSocket) {
webSocket.on('send_eula_bootbox', function (server_id) {
var x = document.querySelector('.bootbox');
if (x) {
x.remove()
}
var x = document.querySelector('.modal-backdrop');
if (x) {
x.remove()
}
bootbox.confirm({
title: '{% raw translate("error", "eulaTitle", data['lang']) %}',
message: '{% raw translate("error", "eulaMsg", data['lang']) %} < br > < br > < a href = "https://account.mojang.com/documents/minecraft_eula" target = "_blank" > EULA< / a > < br > < br > {% raw translate("error", "eulaAgree", data['lang']) %}',
buttons: {
confirm: {
label: 'Yes',
className: 'btn-info'
},
cancel: {
label: 'No',
className: 'btn-secondary'
}
},
callback: function (result) {
if (result == true) {
eulaAgree(server_id.id)
}
else {
location.reload()
}
}
})
});
}
function eulaAgree(server_id, command) {
2022-05-24 01:23:29 +00:00
//< !--this getCookie function is in base.html-- >
2021-11-23 21:11:23 +00:00
var token = getCookie("_xsrf");
$.ajax({
type: "POST",
2022-01-21 22:50:04 +00:00
headers: { 'X-XSRFToken': token },
url: '/ajax/eula?id=' + server_id,
success: function (data) {
2021-11-23 21:11:23 +00:00
console.log("got response:");
console.log(data);
location.reload();
}
});
}
2021-08-07 18:25:47 +00:00
2022-05-24 01:23:29 +00:00
function warn(message, link = null) {
2020-12-17 13:39:29 +00:00
var closeEl = document.createElement('span');
var strongEL = document.createElement('strong');
var msgEl = document.createElement('div');
closeEl.innerHTML = '× ';
strongEL.textContent = 'Warning: ';
msgEl.append(strongEL, message);
closeEl.style.marginLeft = '15px';
closeEl.style.fontWeight = 'bold';
2021-02-27 12:07:16 +00:00
closeEl.style.float = 'right';
2021-02-27 12:05:04 +00:00
closeEl.style.fontSize = '22px';
2021-02-27 12:07:16 +00:00
closeEl.style.lineHeight = '20px';
2020-12-17 13:39:29 +00:00
closeEl.style.cursor = 'pointer';
2022-01-21 22:50:04 +00:00
closeEl.addEventListener('click', function () { this.parentElement.style.display = 'none'; });
2020-12-17 13:39:29 +00:00
var parentEl = document.createElement('div');
parentEl.style.padding = '20px';
parentEl.style.backgroundColor = '#f7970f';
parentEl.appendChild(closeEl);
parentEl.appendChild(msgEl);
2022-05-24 01:23:29 +00:00
if (link) {
let linkEl = document.createElement('a')
linkEl.href = link;
linkEl.innerHTML = "See our documentation for details.";
linkEl.style.color = 'white';
linkEl.style.textDecoration = 'underline';
linkEl.target = "_blank";
parentEl.appendChild(linkEl);
}
2020-12-17 13:39:29 +00:00
document.querySelector('.warnings').appendChild(parentEl);
}
2021-02-27 12:05:04 +00:00
function closeNotification(element) {
element.parentElement.classList.add('remove');
setTimeout(function () {
element.parentElement.remove();
}, 500);
}
function notify(message) {
2022-02-27 17:26:54 +00:00
console.log(`notify(${message})`);
2021-02-27 12:05:04 +00:00
var paragraphEl = document.createElement('p');
var closeEl = document.createElement('span');
paragraphEl.textContent = message;
closeEl.innerHTML = '× ';
2022-01-21 22:50:04 +00:00
closeEl.addEventListener('click', function () { closeNotification(this) });
2021-02-27 12:05:04 +00:00
var parentEl = document.createElement('div');
parentEl.appendChild(paragraphEl);
parentEl.appendChild(closeEl);
parentEl.classList.add('notification');
document.querySelector('.notifications').appendChild(parentEl);
setTimeout(function () {
parentEl.classList.add('active');
}, 200);
setTimeout(function (element) {
closeNotification(element);
}, 7500, closeEl);
`
< div class = "notification" >
< p > Hello, World! This text should overflow< / p >
< span > × < / span >
< / div >
`
}
webSocket.on('notification', notify);
2022-02-27 17:26:54 +00:00
document.addEventListener('alpine:init', () => {
console.log('%c[Crafty Controller] %cAlpine.js pre-initialization!', 'font-weight: 900; color: #800080;', 'color: #eee;');
})
document.addEventListener('alpine:initialized', () => {
console.log('%c[Crafty Controller] %cAlpine.js initialized!', 'font-weight: 900; color: #800080;', 'color: #eee;');
})
2022-01-21 22:50:04 +00:00
$(document).ready(function () {
2022-02-27 17:26:54 +00:00
console.log('%c[Crafty Controller] %cReady for JS!', 'font-weight: 900; color: #800080;', 'font-weight: 900; color: #eee;');
2022-01-21 22:50:04 +00:00
$('#support_logs').click(function () {
2022-01-15 04:53:44 +00:00
var dialog = bootbox.dialog({
message: '< p class = "text-center mb-0" > < i class = "fa fa-spin fa-cog" > < / i > {{ translate('notify', 'preparingLogs', data['lang']) }}< / p > ',
closeButton: false
2022-01-21 22:50:04 +00:00
});
setTimeout(function () {
location.href = "/panel/support_logs";
}, 6000);
2022-01-15 04:53:44 +00:00
});
2022-01-21 22:50:04 +00:00
});
2022-01-15 04:53:44 +00:00
2022-01-21 22:50:04 +00:00
< / script >
2022-01-15 04:53:44 +00:00
2022-01-21 22:50:04 +00:00
{% block js %}
<!-- Custom js for base.html page partial pages -->
<!-- End custom js for base.html page -->
{% end %}
2020-08-12 00:36:09 +00:00
2022-01-21 22:50:04 +00:00
< / body >
2020-08-23 22:43:28 +00:00
2022-05-28 15:31:11 +00:00
< / html >