crafty-4/app/frontend/templates/server/bedrock_wizard.html

581 lines
22 KiB
HTML
Raw Normal View History

2022-02-10 20:54:00 +00:00
{% extends ../base.html %}
{% block title %}Crafty Controller - {{ translate('serverWizard', 'newServer', data['lang']) }}{% end %}
{% block content %}
<div class="content-wrapper">
<ul class="nav nav-tabs col-md-12 tab-simple-styled " role="tablist">
<li class="nav-item term-nav-item">
2022-08-31 23:45:19 +00:00
<a class="nav-link" href="/server/step1" role="tab" aria-selected="false">
2022-02-10 20:54:00 +00:00
<i class="fas fa-file-signature"></i>Minecraft-Java</a>
</li>
<li class="nav-item term-nav-item">
<a class="nav-link active" href="/server/bedrock_step1" role="tab" aria-selected="false">
<i class="fas fa-file-signature"></i>Minecraft-Bedrock</a>
</li>
2022-08-31 23:45:19 +00:00
</ul>
<br>
<div class="d-none" id="overlay" onclick="hide(event)"></div>
<div class="row">
{% if data['online'] %}
<div class="col-sm-6 grid-margin stretch-card">
<div class="card">
<div class="card-body">
<h4>{{ translate('serverWizard', 'newServer', data['lang']) }}</h4>
<br />
<p class="card-description">
<form method="post" name="create_server" class="server-wizard" onSubmit="wait_msg()">
{% raw xsrf_form_html() %}
<div class="row">
<div class="col-sm-12 col-md-12">
<div class="form-group">
<label for="server_name">{{ translate('serverWizard', 'serverName', data['lang']) }}</label>
<input type="text" class="form-control" id="server_name" name="server_name"
placeholder="{{ translate('serverWizard', 'myNewServer', data['lang']) }}" required>
</div>
</div>
</div>
<div class="col-sm-12">
<div class="form-group">
<div id="accordion-1">
<div class="card">
<div class="card-header p-2" id="Role-1">
<p class="mb-0 p-0" data-toggle="collapse" data-target="#collapseRole-1" aria-expanded="true"
aria-controls="collapseRole-1">
<i class="fas fa-chevron-down"></i> {{ translate('serverWizard', 'addRole', data['lang']) }}
<small style="text-transform: none;"> - {{ translate('serverWizard', 'autoCreate',
data['lang']) }}</small>
</p>
2022-02-10 20:54:00 +00:00
</div>
2022-08-31 23:45:19 +00:00
<div id="collapseRole-1" class="collapse" aria-labelledby="Role-1" data-parent="">
<div class="card-body scroll">
<div class="form-group">
{% for r in data['roles'] %}
<span class="d-block menu-option"><label><input name="{{ r['role_id'] }}"
type="checkbox">&nbsp;
{{ r['role_name'].capitalize() }}</label></span>
{% end %}
</div>
</div>
2022-02-10 20:54:00 +00:00
</div>
</div>
2022-08-31 23:45:19 +00:00
</div>
</div>
</div>
<button onclick="eula_confirm()" type="button" class="btn btn-primary mr-2">{{ translate('serverWizard',
'buildServer',
data['lang']) }}</button>
<button type="reset" class="btn btn-danger mr-2">{{ translate('serverWizard', 'resetForm', data['lang'])
}}</button>
</div>
</form>
</p>
</div>
</div>
{% end %}
<div class="col-sm-6 grid-margin stretch-card">
<div class="card">
<div class="card-body">
<h4>{{ translate('serverWizard', 'importServer', data['lang']) }}</h4>
<br />
<p class="card-description">
<form method="post" class="server-wizard" onSubmit="wait_msg(true)">
{% raw xsrf_form_html() %}
<input type="hidden" value="import_jar" name="create_type">
<div class="row">
<div class="col-sm-12">
<div class="form-group">
<label for="server_name">{{ translate('serverWizard', 'serverName', data['lang']) }}</label>
<input type="text" class="form-control" id="server_name" name="server_name" value=""
placeholder="{{ translate('serverWizard', 'myNewServer', data['lang']) }}" required>
</div>
</div>
<div class="col-sm-12">
<div class="form-group">
<label for="server">{{ translate('serverWizard', 'serverPath', data['lang']) }} <small>{{
translate('serverWizard', 'absoluteServerPath', data['lang']) }}</small></label>
<input type="text" class="form-control" id="server_path" name="server_path"
placeholder="/var/opt/server" required>
</div>
</div>
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
<div class="col-sm-12">
<div class="form-group">
<label for="server_jar">{{ translate('serverWizard', 'serverJar', data['lang']) }}</label>
<input type="text" class="form-control" id="server_jar" name="server_jar" value=""
placeholder="bedrock_server" required>
</div>
</div>
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
</div>
<br />
<h4 class="card-title">{{ translate('serverWizard', 'quickSettings', data['lang']) }} <small
style="text-transform: none;"> - {{ translate('serverWizard', 'quickSettingsDescription',
data['lang']) }}</small></h4>
<hr>
<div class="row">
<div class="col-sm-12">
<div class="form-group">
<label for="port2">{{ translate('serverWizard', 'serverPort', data['lang']) }}
<small></small></label>
<input type="number" class="form-control" id="port2" name="port" value="19132" step="1" min="1"
required>
2022-02-10 20:54:00 +00:00
</div>
2022-08-31 23:45:19 +00:00
</div>
<div class="col-sm-12">
<div class="form-group">
<div id="accordion-2">
<div class="card">
<div class="card-header p-2" id="Role-2">
<p class="mb-0 p-0" data-toggle="collapse" data-target="#collapseRole-2" aria-expanded="true"
aria-controls="collapseRole-2">
<i class="fas fa-chevron-down"></i> {{ translate('serverWizard', 'addRole', data['lang']) }}
<small style="text-transform: none;"> - {{ translate('serverWizard', 'autoCreate',
data['lang']) }}</small>
</p>
</div>
<div id="collapseRole-2" class="collapse" aria-labelledby="Role-2" data-parent="">
<div class="card-body scroll">
<div class="form-group">
{% for r in data['roles'] %}
<span class="d-block menu-option"><label><input name="{{ r['role_id'] }}"
type="checkbox">&nbsp;
{{ r['role_name'].capitalize() }}</label></span>
{% end %}
2022-02-10 20:54:00 +00:00
</div>
</div>
</div>
</div>
</div>
</div>
2022-08-31 23:45:19 +00:00
</div>
</div>
<button type="submit" class="btn btn-primary mr-2">{{ translate('serverWizard', 'importServerButton',
data['lang']) }}</button>
<button type="reset" class="btn btn-danger mr-2">{{ translate('serverWizard', 'resetForm', data['lang'])
}}</button>
</form>
</p>
2022-02-10 20:54:00 +00:00
</div>
</div>
2022-08-31 23:45:19 +00:00
</div>
<div class="col-sm-6 grid-margin stretch-card">
<div class="card">
<div class="card-body">
<h4>{{ translate('serverWizard', 'importZip', data['lang']) }}</h4>
<br />
<p class="card-description">
<form name="zip" method="post" class="server-wizard" onSubmit="wait_msg(true)">
{% raw xsrf_form_html() %}
<input type="hidden" value="import_zip" name="create_type">
<div class="row">
<div class="col-sm-9">
<div class="col-sm-12">
<div class="form-group">
<label for="server_name">{{ translate('serverWizard', 'serverName', data['lang']) }}</label>
<input type="text" class="form-control" id="server_name" name="server_name" value=""
placeholder="{{ translate('serverWizard', 'myNewServer', data['lang']) }}" required>
</div>
</div>
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
<div class="col-sm-12">
<div class="form-group">
<label for="server">{{ translate('serverWizard', 'zipPath', data['lang']) }} <small>{{
translate('serverWizard', 'absoluteZipPath', data['lang']) }}</small></label>
<input type="text" class="form-control" id="server_path" name="server_path"
placeholder="/var/opt/server.zip" required>
</div>
</div>
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
<div class="col-sm-12">
<div class="form-group">
<label for="server">{{ translate('serverWizard', 'selectRoot', data['lang']) }} <small>{{
translate('serverWizard', 'explainRoot', data['lang']) }}</small></label>
<br>
<button class="btn btn-primary mr-2" id="root_files_button" type="button">{{
translate('serverWizard', 'clickRoot', data['lang']) }}</button>
</div>
</div>
2022-06-03 18:50:58 +00:00
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
<div class="col-sm-12">
<div class="form-group">
<label for="server_jar">{{ translate('serverWizard', 'serverJar', data['lang']) }}</label>
<input type="text" class="form-control" id="server_jar" name="server_jar" value=""
placeholder="bedrock_server" required>
2022-02-10 20:54:00 +00:00
</div>
2022-08-31 23:45:19 +00:00
</div>
</div>
</div>
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
<div class="col-sm-12">
<h4 class="card-title">{{ translate('serverWizard', 'quickSettings', data['lang']) }} <small
style="text-transform: none;"> - {{ translate('serverWizard', 'quickSettingsDescription',
data['lang']) }}</small></h4>
<hr>
<div class="row">
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
<div class="col-sm-12">
<div class="form-group">
<label for="port3">{{ translate('serverWizard', 'serverPort', data['lang']) }}
<small></small></label>
<input type="number" class="form-control" id="port3" name="port" value="19132" step="1" min="1"
required>
</div>
</div>
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
<div class="col-sm-12">
<div class="form-group">
<div id="accordion-3">
<div class="card">
<div class="card-header p-2" id="Role-3">
<p class="mb-0 p-0" data-toggle="collapse" data-target="#collapseRole-3" aria-expanded="true"
aria-controls="collapseRole-3">
<i class="fas fa-chevron-down"></i> {{ translate('serverWizard', 'addRole', data['lang'])
}} <small style="text-transform: none;"> - {{ translate('serverWizard', 'autoCreate',
data['lang']) }}</small>
</p>
</div>
<div id="collapseRole-3" class="collapse" aria-labelledby="Role-3" data-parent="">
<div class="card-body scroll">
<div class="form-group">
{% for r in data['roles'] %}
<span class="d-block menu-option"><label><input name="{{ r['role_id'] }}"
type="checkbox">&nbsp;
{{ r['role_name'].capitalize() }}</label></span>
{% end %}
2022-02-10 20:54:00 +00:00
</div>
</div>
</div>
</div>
2022-08-31 23:45:19 +00:00
</div>
</div>
</div>
<div class="col-sm-12" style="visibility: hidden;">
<div class="form-group">
<input type="text" class="form-control" id="zip_root_path" name="zip_root_path">
</div>
</div>
<div class="modal fade" id="dir_select" tabindex="-1" role="dialog" aria-labelledby="dir_select"
aria-hidden="true">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLongTitle">{{ translate('serverWizard',
'selectZipDir', data['lang']) }}</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
2022-02-10 20:54:00 +00:00
</div>
2022-08-31 23:45:19 +00:00
<div class="modal-body">
<div class="tree-ctx-item" id="main-tree-div" data-path=""
style="overflow: scroll; max-height:75%;">
<input type="radio" id="main-tree-input" name="root_path" value="" checked>
<span id="main-tree" class="files-tree-title tree-caret-down root-dir" data-path="">
<i class="far fa-folder"></i>
<i class="far fa-folder-open"></i>
{{ translate('serverFiles', 'files', data['lang']) }}
</span>
</input>
2022-02-10 20:54:00 +00:00
</div>
</div>
2022-08-31 23:45:19 +00:00
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">{{
translate('serverWizard', 'close', data['lang']) }}</button>
<button type="button" id="modal-okay" data-dismiss="modal" class="btn btn-primary">{{
translate('serverWizard', 'save', data['lang']) }}</button>
</div>
2022-02-10 20:54:00 +00:00
</div>
</div>
</div>
2022-08-31 23:45:19 +00:00
</div>
<button id="zip_submit" type="submit" title="You must select server root dir first" disabled
class="btn btn-primary mr-2">{{ translate('serverWizard', 'importServerButton', data['lang'])
}}</button>
<button type="reset" class="btn btn-danger mr-2">{{ translate('serverWizard', 'resetForm', data['lang'])
}}</button>
</div>
2022-02-10 20:54:00 +00:00
</div>
2022-08-31 23:45:19 +00:00
</form>
</p>
2022-02-10 20:54:00 +00:00
</div>
2022-08-31 23:45:19 +00:00
</div>
</div>
2022-02-10 20:54:00 +00:00
</div>
<style>
2022-08-31 23:45:19 +00:00
.scroll {
2022-02-10 20:54:00 +00:00
max-height: 12em;
overflow-y: auto;
2022-08-31 23:45:19 +00:00
}
.menu-btn {
2022-02-10 20:54:00 +00:00
font-size: 0.9em;
padding: 2px 10px;
2022-08-31 23:45:19 +00:00
}
.menu {
2022-02-10 20:54:00 +00:00
padding-top: 10px;
z-index: 200;
margin-top: 4px;
position: absolute;
background-color: #2a2c44;
2022-08-31 23:45:19 +00:00
}
.menu-option {
2022-02-10 20:54:00 +00:00
padding: 6px 20px 6px;
color: white;
2022-08-31 23:45:19 +00:00
}
#overlay {
2022-02-10 20:54:00 +00:00
position: absolute;
top: 0px;
left: 0px;
width: 100%;
height: 100%;
z-index: 100;
2022-08-31 23:45:19 +00:00
}
2022-02-10 20:54:00 +00:00
</style>
<style>
/* Remove default bullets */
2022-08-31 23:45:19 +00:00
.tree-view,
.tree-nested {
list-style-type: none;
margin: 0;
padding: 0;
margin-left: 10px;
}
/* Style the items */
.tree-item,
.files-tree-title {
cursor: pointer;
user-select: none;
/* Prevent text selection */
}
/* Create the caret/arrow with a unicode, and style it */
.tree-caret .fa-folder {
display: inline-block;
}
.tree-caret .fa-folder-open {
display: none;
}
/* Rotate the caret/arrow icon when clicked on (using JavaScript) */
.tree-caret-down .fa-folder {
display: none;
}
.tree-caret-down .fa-folder-open {
display: inline-block;
}
/* Hide the nested list */
.tree-nested {
display: none;
}
2022-02-10 20:54:00 +00:00
</style>
{% end %}
{% block js%}
<script>
2022-08-31 23:45:19 +00:00
function eula_confirm() {
bootbox.confirm({
title: "{% raw translate('error', 'eulaTitle', data['lang']) %}",
message: "{% raw translate('error', 'eulaMsg', data['lang']) %} <br><br><a href='https://www.minecraft.net/en-us/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) {
document.create_server.submit();
}
else {
return;
}
}
})
}
</script>
<script>
document.getElementById("root_files_button").addEventListener("click", function () {
if (document.forms["zip"]["server_path"].value != "") {
if (document.getElementById('root_files_button').classList.contains('clicked')) {
2022-02-10 20:54:00 +00:00
document.getElementById('main-tree-div').innerHTML = '<input type="radio" id="main-tree-input" name="root_path" value="" checked><span id="main-tree" class="files-tree-title tree-caret-down root-dir" data-path=""><i class="far fa-folder"></i><i class="far fa-folder-open"></i>{{ translate('serverFiles', 'files', data['lang']) }}</span></input>'
2022-08-31 23:45:19 +00:00
} else {
2022-02-10 20:54:00 +00:00
document.getElementById('root_files_button').classList.add('clicked')
}
2022-08-31 23:45:19 +00:00
path = document.forms["zip"]["server_path"].value;
console.log(document.forms["zip"]["server_path"].value)
var token = getCookie("_xsrf");
var dialog = bootbox.dialog({
message: '<p class="text-center mb-0"><i class="fa fa-spin fa-cog"></i> Please wait while we gather your files...</p>',
closeButton: false
});
$.ajax({
type: "POST",
headers: { 'X-XSRFToken': token },
url: '/ajax/unzip_server?id=-1&path=' + path,
});
} else {
bootbox.alert("You must input a path before selecting this button");
}
2022-02-10 20:54:00 +00:00
});
</script>
<script>
2022-08-31 23:45:19 +00:00
function dropDown(event) {
2022-02-10 20:54:00 +00:00
event.target.parentElement.children[1].classList.remove("d-none");
document.getElementById("overlay").classList.remove("d-none");
2022-08-31 23:45:19 +00:00
}
function hide(event) {
2022-02-10 20:54:00 +00:00
var items = document.getElementsByClassName('menu');
for (let i = 0; i < items.length; i++) {
2022-08-31 23:45:19 +00:00
items[i].classList.add("d-none");
2022-02-10 20:54:00 +00:00
}
document.getElementById("overlay").classList.add("d-none");
2022-08-31 23:45:19 +00:00
}
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
function wait_msg(importing) {
2022-02-10 20:54:00 +00:00
bootbox.alert({
2022-08-31 23:45:19 +00:00
title: importing ? '{% raw translate("serverWizard", "importing", data['lang']) %}': '{% raw translate("serverWizard", "downloading", data['lang']) %}',
message: '<i class="fas fa-cloud-download"></i> {% raw translate("serverWizard", "bePatient", data['lang']) %}',
});
2022-02-10 20:54:00 +00:00
}
2022-08-31 23:45:19 +00:00
function show_file_tree() {
2022-02-10 20:54:00 +00:00
$("#dir_select").modal();
}
2022-08-31 23:45:19 +00:00
function getTreeView(path) {
document.getElementById('zip_submit').disabled = false;
path = path
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
$.ajax({
type: "GET",
url: '/ajax/get_zip_tree?id=-1&path=' + path,
dataType: 'text',
success: function (data) {
console.log("got response:");
console.log(data);
dataArr = data.split('\n');
serverDir = dataArr.shift(); // Remove & return first element (server directory)
text = dataArr.join('\n');
try {
document.getElementById('main-tree-div').innerHTML += text;
document.getElementById('main-tree').parentElement.classList.add("clicked");
} catch {
document.getElementById('files-tree').innerHTML = text;
}
2022-06-03 18:50:58 +00:00
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
document.getElementsByClassName('files-tree-title')[0].setAttribute('data-path', serverDir);
document.getElementsByClassName('files-tree-title')[0].setAttribute('data-name', 'Files');
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
},
});
}
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
function getToggleMain(event) {
path = event.target.parentElement.getAttribute('data-path');
document.getElementById("files-tree").classList.toggle("d-block");
document.getElementById(path + "span").classList.toggle("tree-caret-down");
document.getElementById(path + "span").classList.toggle("tree-caret");
}
2022-06-03 18:50:58 +00:00
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
function getDirView(event) {
path = event.target.parentElement.getAttribute('data-path');
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
if (document.getElementById(path).classList.contains('clicked')) {
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
var toggler = document.getElementById(path + "span");
2022-02-10 20:54:00 +00:00
2022-08-31 23:45:19 +00:00
if (toggler.classList.contains('files-tree-title')) {
document.getElementById(path + "ul").classList.toggle("d-block");
document.getElementById(path + "span").classList.toggle("tree-caret-down");
}
return;
} else {
2022-02-10 20:54:00 +00:00
$.ajax({
type: "GET",
2022-08-31 23:45:19 +00:00
url: '/ajax/get_zip_dir?id=-1&path=' + path,
2022-02-10 20:54:00 +00:00
dataType: 'text',
2022-08-31 23:45:19 +00:00
success: function (data) {
2022-02-10 20:54:00 +00:00
console.log("got response:");
dataArr = data.split('\n');
serverDir = dataArr.shift(); // Remove & return first element (server directory)
text = dataArr.join('\n');
2022-08-31 23:45:19 +00:00
try {
document.getElementById(path + "span").classList.add('tree-caret-down');
2022-02-10 20:54:00 +00:00
document.getElementById(path).innerHTML += text;
document.getElementById(path).classList.add("clicked");
2022-08-31 23:45:19 +00:00
} catch {
2022-02-10 20:54:00 +00:00
console.log("Bad")
}
var toggler = document.getElementById(path);
2022-06-03 18:50:58 +00:00
2022-08-31 23:45:19 +00:00
if (toggler.classList.contains('files-tree-title')) {
document.getElementById(path + "span").addEventListener("click", function caretListener() {
document.getElementById(path + "ul").classList.toggle("d-block");
document.getElementById(path + "span").classList.toggle("tree-caret-down");
2022-02-10 20:54:00 +00:00
});
}
},
});
}
2022-08-31 23:45:19 +00:00
}
if (webSocket) {
webSocket.on('send_temp_path', function (data) {
setTimeout(function () {
var x = document.querySelector('.bootbox');
if (x) {
x.remove()
}
var x = document.querySelector('.modal-backdrop');
if (x) {
x.remove()
}
document.getElementById('main-tree-input').setAttribute('value', data.path)
getTreeView(data.path);
show_file_tree();
2022-06-03 18:50:58 +00:00
}, 5000);
2022-08-31 23:45:19 +00:00
});
}
2022-02-10 20:54:00 +00:00
</script>
2022-08-31 23:45:19 +00:00
{% end %}