2021-11-05 18:33:24 +00:00
{% extends ../base.html %}
{% block title %}Crafty Controller - {{ translate('serverWizard', 'newServer', data['lang']) }}{% end %}
{% block content %}
< div class = "content-wrapper" >
2021-11-17 18:08:41 +00:00
< div class = "d-none" id = "overlay" onclick = "hide(event)" > < / div >
2021-11-05 18:33:24 +00:00
< div class = "row" >
< 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" class = "server-wizard" >
{% raw xsrf_form_html() %}
< div class = "row" >
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_type" > {{ translate('serverWizard', 'serverType', data['lang']) }}< / label >
< select class = "form-control form-control-lg select-css" id = "server_type" name = "server_type" onchange = "serverTypeChange(this)" >
{% for s in data['server_types'] %}
< option value = "{{ s }}" > {{ s.capitalize() }}< / option >
{% end %}
< / select >
< / div >
< / div >
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_version" > {{ translate('serverWizard', 'serverVersion', data['lang']) }}< / label >
< select class = "form-control form-control-lg select-css" id = "server" name = "server" >
< option value = "0" > Select a Version< / option >
< / select >
< / div >
< / div >
< 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" placeholder = "{{ translate('serverWizard', 'myNewServer', data['lang']) }}" >
< / div >
< / div >
< / 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-3" >
< div class = "form-group" >
< label for = "min_memory1" > {{ translate('serverWizard', 'minMem', data['lang']) }} < small > - {{ translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "min_memory1" name = "min_memory" value = "1" step = "0.5" min = "0.5" >
< / div >
< / div >
< div class = "col-sm-3 offset-1" >
< div class = "form-group" >
< label for = "max_memory1" > {{ translate('serverWizard', 'maxMem', data['lang']) }} < small > - {{ translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "max_memory1" name = "max_memory" value = "2" step = "0.5" min = "0.5" >
< / div >
< / div >
< div class = "col-sm-3 offset-1" >
< div class = "form-group" >
< label for = "port1" > {{ translate('serverWizard', 'serverPort', data['lang']) }} < small > - {{ translate('serverWizard', 'defaultPort', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "port1" name = "port" value = "25565" step = "1" min = "1" >
< / div >
< / div >
2021-11-17 06:17:36 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
2021-11-17 21:00:14 +00:00
< 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 > Add Server to Existing Roles < small style = "text-transform: none;" > - If none are selected Crafty will make one and add you to it!< / small >
< / p >
< / div >
< 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" >
{{ r['role_name'].capitalize() }}< / label > < / span >
{% end %}
< / div >
< / div >
< / div >
< / div >
2021-11-17 18:08:41 +00:00
< / div >
2021-11-17 06:17:36 +00:00
< / div >
2021-11-17 18:08:41 +00:00
< / div >
2021-11-05 18:33:24 +00:00
< / div >
< button type = "submit" class = "btn btn-primary mr-2" onclick = "wait_msg()" > {{ translate('serverWizard', 'buildServer', data['lang']) }}< / button >
< button type = "reset" class = "btn btn-danger mr-2" > {{ translate('serverWizard', 'resetForm', data['lang']) }}< / button >
< / form >
< / p >
< / div >
< / div >
< / div >
< 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" >
{% 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']) }}" >
< / 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" >
< / div >
< / div >
< 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 = "paper.jar" >
< / div >
< / div >
< / 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-3" >
< div class = "form-group" >
< label for = "min_memory2" > {{ translate('serverWizard', 'minMem', data['lang']) }} < small > - {{ translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "min_memory2" name = "min_memory" value = "1" step = "0.5" min = "0.5" >
< / div >
< / div >
< div class = "col-sm-3 offset-1" >
< div class = "form-group" >
< label for = "max_memory2" > {{ translate('serverWizard', 'maxMem', data['lang']) }} < small > - {{ translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "max_memory2" name = "max_memory" value = "2" step = "0.5" min = "0.5" >
< / div >
< / div >
< div class = "col-sm-3 offset-1" >
< div class = "form-group" >
< label for = "port2" > {{ translate('serverWizard', 'serverPort', data['lang']) }} < small > - {{ translate('serverWizard', 'defaultPort', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "port2" name = "port" value = "25565" step = "1" min = "1" >
< / div >
< / div >
2021-11-17 18:08:41 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
2021-11-17 21:00:14 +00:00
< 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 > Add Server to Existing Roles < small style = "text-transform: none;" > - If none are selected Crafty will make one and add you to it!< / 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" >
{{ r['role_name'].capitalize() }}< / label > < / span >
{% end %}
< / div >
< / div >
< / div >
< / div >
2021-11-17 18:08:41 +00:00
< / div >
< / div >
< / div >
2021-11-05 18:33:24 +00:00
< / div >
< button type = "submit" class = "btn btn-primary mr-2" onclick = "wait_msg(true)" > {{ translate('serverWizard', 'importServerButton', data['lang']) }}< / button >
< button type = "reset" class = "btn btn-danger mr-2" > {{ translate('serverWizard', 'resetForm', data['lang']) }}< / button >
< / form >
< / p >
< / div >
< / div >
< / div >
< / div >
< div class = "col-sm-13 grid-margin stretch-card" >
< div class = "card" >
< div class = "card-body" >
< h4 > {{ translate('serverWizard', 'importZip', data['lang']) }}< / h4 >
< br / >
< p class = "card-description" >
< form method = "post" class = "server-wizard" >
{% 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']) }}" >
< / div >
< / div >
< 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" >
< / div >
< / div >
< 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 = "paper.jar" >
< / div >
< / div >
< / div >
< div class = "col-sm-3" >
< 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 = "min_memory3" > {{ translate('serverWizard', 'minMem', data['lang']) }} < small > - {{ translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "min_memory3" name = "min_memory" value = "1" step = "0.5" min = "0.5" >
< / div >
< / div >
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "max_memory3" > {{ translate('serverWizard', 'maxMem', data['lang']) }} < small > - {{ translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "max_memory3" name = "max_memory" value = "2" step = "0.5" min = "0.5" >
< / div >
< / div >
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "port3" > {{ translate('serverWizard', 'serverPort', data['lang']) }} < small > - {{ translate('serverWizard', 'defaultPort', data['lang']) }}< / small > < / label >
< input type = "number" class = "form-control" id = "port3" name = "port" value = "25565" step = "1" min = "1" >
< / div >
< / div >
2021-11-17 18:08:41 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
2021-11-17 21:00:14 +00:00
< 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 > Add Server to Existing Roles < small style = "text-transform: none;" > - If none are selected Crafty will make one and add you to it!< / 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" >
{{ r['role_name'].capitalize() }}< / label > < / span >
{% end %}
< / div >
< / div >
< / div >
< / div >
2021-11-17 18:08:41 +00:00
< / div >
< / div >
< / div >
2021-11-05 18:33:24 +00:00
< / div >
< button type = "submit" class = "btn btn-primary mr-2" onclick = "wait_msg(true)" > {{ translate('serverWizard', 'importServerButton', data['lang']) }}< / button >
< button type = "reset" class = "btn btn-danger mr-2" > {{ translate('serverWizard', 'resetForm', data['lang']) }}< / button >
< / div >
< / div >
< / form >
< / p >
< / div >
< / div >
< / div >
< / div >
2021-11-17 18:08:41 +00:00
< style >
2021-11-17 21:00:14 +00:00
.scroll {
max-height: 12em;
overflow-y: auto;
}
2021-11-17 18:08:41 +00:00
.menu-btn {
font-size: 0.9em;
padding: 2px 10px;
}
.menu {
padding-top: 10px;
z-index: 200;
margin-top: 4px;
position: absolute;
background-color: #2a2c44;
}
.menu-option {
padding: 6px 20px 6px;
color: white;
}
#overlay {
position: absolute;
top: 0px;
left: 0px;
width: 100%;
height: 100%;
z-index: 100;
}
< / style >
2021-11-05 18:33:24 +00:00
{% end %}
{% block js%}
< script >
2021-11-17 18:08:41 +00:00
function dropDown(event) {
event.target.parentElement.children[1].classList.remove("d-none");
document.getElementById("overlay").classList.remove("d-none");
}
function hide(event) {
var items = document.getElementsByClassName('menu');
for (let i = 0; i < items.length ; i + + ) {
items[i].classList.add("d-none");
}
document.getElementById("overlay").classList.add("d-none");
}
2021-11-05 18:33:24 +00:00
$( document ).ready(function() {
console.log('ready');
var forms = $('form.server-wizard');
forms.each(function(i, formEl) {
var form = $(formEl);
var min = form.find('[name=min_memory]');
var max = form.find('[name=max_memory]');
console.log(form, min, max)
min.change(function(){
check_sizes(max, min, 'min');
});
max.change(function(){
check_sizes(max, min, 'max');
});
});
});
function wait_msg(importing){
bootbox.alert({
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']) %}'
});
}
function check_sizes(a, b, changed){
max_mem = parseFloat(a.val());
min_mem = parseFloat(b.val());
if (max_mem < min_mem & & changed = == ' min ' ) {
a.val(min_mem)
}
if (max_mem < min_mem & & changed = == ' max ' ) {
b.val(max_mem)
}
}
< / script >
< script type = "text/javascript" >
//< ![CDATA[
// array of possible countries in the same order as they appear in the country selection list
function decodeHtmlCharCodes(str) {
return str.replace("" ", "\"");
}
function convertHtmlJsonToJavacriptArray(str) {
var result = []
str = decodeHtmlCharCodes(str)
for(var i in str)
result.push([i, str [i]]);
return result
}
var text = '{% raw data["js_server_types"] %}';
var serverTypesLists = JSON.parse(text);
//convertHtmlJsonToJavacriptArray('{{ data["js_server_types"] }}')
/* CountryChange() is called from the onchange event of a select element.
* param selectObj - the select object which fired the on change event.
*/
function serverTypeChange(selectObj) {
// get the index of the selected option
var idx = selectObj.selectedIndex;
// get the value of the selected option
var which = selectObj.options[idx].value;
// use the selected option value to retrieve the list of items from the serverTypesLists array
cList = serverTypesLists[which];
// get the country select element via its known id
var cSelect = document.getElementById("server");
// remove the current options from the country select
var len=cSelect.options.length;
while (cSelect.options.length > 0) {
cSelect.remove(0);
}
var newOption;
// create new options ordered by descending
for (var i=(cList.length)-1; i>=0; i--) {
newOption = document.createElement("option");
newOption.value = which+"|"+cList[i]; // assumes option string and value are the same
newOption.text=cList[i];
// add the new option
try {
cSelect.add(newOption); // this will fail in DOM browsers but is needed for IE
}
catch (e) {
cSelect.appendChild(newOption);
}
}
}
//]]>
< / script >
2020-08-23 22:43:28 +00:00
{% end %}