2022-02-10 23:20:36 +00:00
{% extends ../base.html %}
{% block title %}Crafty Controller - {{ translate('serverWizard', 'newServer', data['lang']) }}{% end %}
{% block content %}
< div class = "content-wrapper" >
2022-09-04 22:01:00 +00:00
< ul class = "nav nav-tabs col-md-12 tab-simple-styled " role = "tablist" >
< li class = "nav-item term-nav-item" >
< a class = "nav-link active" href = "/server/step1" role = "tab" aria-selected = "false" >
< i class = "fas fa-file-signature" > < / i > Minecraft-Java< / a >
< / li >
< li class = "nav-item term-nav-item" >
< a class = "nav-link" href = "/server/bedrock_step1" role = "tab" aria-selected = "false" >
< i class = "fas fa-file-signature" > < / i > Minecraft-Bedrock< / a >
< / li >
< / ul >
< div class = "d-none" id = "overlay" onclick = "hide(event)" > < / div >
< div class = "row" >
< div class = "col-sm-6 grid-margin stretch-card" >
2023-05-14 17:59:47 +00:00
< div class = "card" id = "creation_wizard" >
2022-09-04 22:01:00 +00:00
< div class = "card-body" >
2023-05-22 20:45:17 +00:00
{% if data["server_api"] and data["online"] %}
< a href = "https://serverjars.com/" target = "_blank" alt = "serverjars icon" > < img src = "../../static/assets/images/serverjars/ICON.svg"
style="float: right; width: 40px; position: relative;">< / a >
{% end %}
2022-02-10 23:20:36 +00:00
2022-09-04 22:01:00 +00:00
< h4 > {{ translate('serverWizard', 'newServer', data['lang']) }}< / h4 >
< br / >
< p class = "card-description" >
2022-02-10 23:20:36 +00:00
2022-09-04 22:01:00 +00:00
< form method = "post" class = "server-wizard" onSubmit = "wait_msg()" >
2023-05-17 16:51:45 +00:00
{% if data["server_api"] and data["online"] %}
2023-05-14 17:59:47 +00:00
< fieldset >
2023-05-18 07:53:23 +00:00
{% else %}
< fieldset disabled = "disabled" >
< style >
#creation_wizard {
-webkit-filter: grayscale(1);
}
.api-alert {
position: absolute;
top: -5px;
left: 0;
font-size: 50px !important;
color: #fff;
background: rgb(0, 170, 170);
opacity: .4;
width: 100%;
height: 100%;
z-index: 100;
}
.api-alert p {
margin: 0;
position: absolute;
top: 50%;
left: 50%;
text-align: center;
font-size: 20px;
-ms-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
}
< / style >
{% end %}
{% raw xsrf_form_html() %}
< div class = "row" >
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_jar" > {{ translate('serverWizard', 'serverType', data['lang'])
}}< / label >
< div class = "input-group" >
< select required class = "form-control form-control-lg select-css" id = "server_jar" name = "server_jar" onchange = "serverJarChange(this)" >
< option value = "None" > {{ translate('serverWizard', 'selectType', data['lang']) }}< / option >
{% for s in data['server_types'] %}
< option value = "{{ s }}" > {{ s.capitalize() }}< / option >
{% end %}
< / select >
{% if data['super_user'] %}
< div class = "input-group-append" >
< button class = "btn custom-picker" type = "button" onclick = "refreshCache()" > < i id = "refresh-cache" class = "refresh-class fas fa-sync" > < / i > < / button >
< / div >
2023-02-02 22:47:54 +00:00
{% end %}
< / div >
2023-05-18 07:53:23 +00:00
< / div >
2023-02-02 22:47:54 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2023-05-18 07:53:23 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_type" > {{ translate('serverWizard', 'serverSelect', data['lang']) }}< / label >
< select required class = "form-control form-control-lg select-css" id = "server_type" name = "server_type" onchange = "serverTypeChange(this)" >
< option value = "" > {{ translate('serverWizard', 'selectServer', data['lang']) }}< / option >
< / select >
< / div >
< / div >
2022-02-10 23:20:36 +00:00
2023-05-18 07:53:23 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_version" > {{ translate('serverWizard', 'serverVersion', data['lang']) }}< / label >
< select required class = "form-control form-control-lg select-css" id = "server" name = "server" >
< option value = "" > {{ translate('serverWizard', 'selectVersion', data['lang']) }}< / option >
< / select >
< / div >
< / div >
2022-03-27 22:09:49 +00:00
2023-05-18 07:53:23 +00:00
< 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']) }}" required >
< / div >
< / div >
2022-09-04 22:01:00 +00:00
2022-03-27 22:09:49 +00:00
< / div >
2023-05-18 07:53:23 +00:00
< 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-4" >
< 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" required >
< / div >
< / div >
2022-02-10 23:20:36 +00:00
2023-05-18 07:53:23 +00:00
< div class = "col-sm-4" >
< 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" required >
< / div >
< / div >
2022-02-10 23:20:36 +00:00
2023-05-18 07:53:23 +00:00
< div class = "col-sm-4" >
< 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" max = "65535 " required >
< / 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 >
< / 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 >
2022-02-10 23:20:36 +00:00
< / div >
< / div >
< / div >
< / div >
< / div >
2023-05-18 07:53:23 +00:00
2022-02-10 23:20:36 +00:00
< / div >
2023-05-18 07:53:23 +00:00
< button type = "submit" 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 >
< / fieldset >
{% if not data["server_api"] %}
< div class = "api-alert" style = "position: absolute; top: -5px; z-index: 100; opacity: .99;" >
< p style = "color: white !important;" > < i class = "fas fa-exclamation-triangle" style = "color: white;" > < / i > {{ translate('error', 'serverJars1', data['lang']) }}< a style = "color: red;" ; href = "https://status.craftycontrol.com/status/craftycontrol" target = "_blank" > {{ translate('error', 'craftyStatus', data['lang']) }}< / a >
{{ translate('error', 'serverJars2', data['lang']) }}< / p >
2022-03-27 22:09:49 +00:00
< / div >
2022-09-04 22:01:00 +00:00
< / div >
< button type = "submit" 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 >
2023-05-14 17:59:47 +00:00
< / fieldset >
2023-05-17 16:51:45 +00:00
{% if not data["server_api"] and data["online"] %}
2023-05-14 18:23:06 +00:00
< div class = "api-alert" style = "position: absolute; top: -5px; z-index: 100; opacity: .99;" >
2023-05-17 16:51:45 +00:00
< p style = "color: white !important;" > < i class = "fas fa-exclamation-triangle" style = "color: red;" > < / i > {{ translate('error', 'serverJars1', data['lang']) }}< a style = "color: red;" ; href = "https://status.craftycontrol.com/status/craftycontrol"
2023-05-14 18:35:23 +00:00
target="_blank"> {{ translate('error', 'craftyStatus', data['lang']) }}< / a >
{{ translate('error', 'serverJars2', data['lang']) }}< / p > < / div >
2023-05-14 18:23:06 +00:00
{% end %}
2023-05-17 16:51:45 +00:00
{% if not data["online"] %}
< div class = "api-alert" style = "position: absolute; top: -5px; z-index: 100; opacity: .99;" >
< p style = "color: white !important;" > < i class = "fas fa-exclamation-triangle" style = "color: red;" > < / i > {{ translate('error', 'noInternet', data['lang']) }}< / p > < / div >
{% end %}
2023-05-18 07:53:23 +00:00
{% end %}
2022-02-10 23:20:36 +00:00
< / div >
< / div >
2023-05-14 18:23:06 +00:00
< / form >
2022-09-04 22:01:00 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2023-02-02 22:47:54 +00:00
<!-- Import an Existing Server -->
< div class = "col-md-6 grid-margin stretch-card" >
2022-09-04 22:01:00 +00:00
< 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 >
2023-02-04 09:50:44 +00:00
< input type = "text" class = "form-control" id = "server_name" name = "server_name" value = "" placeholder = "{{ translate('serverWizard', 'myNewServer', data['lang']) }}" required >
2022-09-04 22:01:00 +00:00
< / 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 >
2023-02-04 09:50:44 +00:00
< input type = "text" class = "form-control" id = "server_path" name = "server_path" placeholder = "/var/opt/server" required >
2022-09-04 22:01:00 +00:00
< / div >
< / div >
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_jar" > {{ translate('serverWizard', 'serverJar', data['lang']) }}< / label >
2023-02-04 09:50:44 +00:00
< input type = "text" class = "form-control" id = "server_jar" name = "server_jar" value = "" placeholder = "paper.jar" required >
2022-09-04 22:01:00 +00:00
< / div >
< / div >
2022-02-10 23:20:36 +00:00
2022-09-04 22:01:00 +00:00
< / div >
2022-02-10 23:20:36 +00:00
< br / >
2023-02-04 09:50:44 +00:00
< h4 class = "card-title" > {{ translate('serverWizard', 'quickSettings', data['lang']) }} < small style = "text-transform: none;" > - {{ translate('serverWizard', 'quickSettingsDescription',
2022-09-04 22:01:00 +00:00
data['lang']) }}< / small > < / h4 >
< hr >
< div class = "row" >
2022-02-10 23:20:36 +00:00
2022-09-04 22:01:00 +00:00
< div class = "col-sm-4" >
< div class = "form-group" >
< label for = "min_memory2" > {{ translate('serverWizard', 'minMem', data['lang']) }} < small > - {{
translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "min_memory2" name = "min_memory" value = "1" step = "0.5" min = "0.5" required >
2022-09-04 22:01:00 +00:00
< / div >
< / div >
2022-02-10 23:20:36 +00:00
2022-09-04 22:01:00 +00:00
< div class = "col-sm-4" >
< div class = "form-group" >
< label for = "max_memory2" > {{ translate('serverWizard', 'maxMem', data['lang']) }} < small > - {{
translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "max_memory2" name = "max_memory" value = "2" step = "0.5" min = "0.5" required >
2022-03-27 22:09:49 +00:00
< / div >
2022-09-04 22:01:00 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2022-09-04 22:01:00 +00:00
< div class = "col-sm-4" >
< div class = "form-group" >
< label for = "port2" > {{ translate('serverWizard', 'serverPort', data['lang']) }} < small > - {{
translate('serverWizard', 'defaultPort', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "port2" name = "port" value = "25565" step = "1" min = "1" max = "65535" required >
2022-09-04 22:01:00 +00:00
< / div >
< / 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" >
2023-02-04 09:50:44 +00:00
< p class = "mb-0 p-0" data-toggle = "collapse" data-target = "#collapseRole-2" aria-expanded = "true" aria-controls = "collapseRole-2" >
2022-09-04 22:01:00 +00:00
< 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'] %}
2023-02-04 09:50:44 +00:00
< span class = "d-block menu-option" > < label > < input name = "{{ r['role_id'] }}" type = "checkbox" >
2022-09-04 22:01:00 +00:00
{{ r['role_name'].capitalize() }}< / label > < / span >
{% end %}
< / div >
< / div >
< / div >
< / div >
2022-02-10 23:20:36 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2022-09-04 22:01:00 +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 >
< / div >
< / div >
< / div >
2023-02-02 22:47:54 +00:00
<!-- Import from a Zip File -->
< div class = "col-md-6 grid-margin stretch-card" >
2022-09-04 22:27:45 +00:00
< div class = "card" >
< div class = "card-body" >
2022-09-04 22:01:00 +00:00
2022-09-04 22:27:45 +00:00
< h4 > {{ translate('serverWizard', 'importZip', data['lang']) }}< / h4 >
< br / >
< p class = "card-description" >
2022-09-04 22:01:00 +00:00
2022-09-04 22:27:45 +00:00
< 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" >
2022-09-04 22:01:00 +00:00
2022-09-04 22:27:45 +00:00
< div class = "row" >
2022-09-04 22:01:00 +00:00
< div class = "col-sm-12" >
2022-09-04 22:27:45 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_name" > {{ translate('serverWizard', 'serverName', data['lang']) }}< / label >
2023-02-04 09:50:44 +00:00
< input type = "text" class = "form-control" id = "server_name" name = "server_name" value = "" placeholder = "{{ translate('serverWizard', 'myNewServer', data['lang']) }}" required >
2022-09-04 22:27:45 +00:00
< / div >
2022-09-04 22:01:00 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2022-09-04 22:27:45 +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 >
2023-02-04 09:50:44 +00:00
< input type = "text" class = "form-control" id = "server_path" name = "server_path" placeholder = "/var/opt/server.zip" required >
2022-09-04 22:27:45 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2022-09-04 22:27:45 +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 >
2022-09-04 22:01:00 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2022-09-04 22:27:45 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
< label for = "server_jar" > {{ translate('serverWizard', 'serverJar', data['lang']) }}< / label >
2023-02-04 09:50:44 +00:00
< input type = "text" class = "form-control" id = "server_jar" name = "server_jar" value = "" placeholder = "paper.jar" required >
2022-09-04 22:27:45 +00:00
< / div >
2022-09-04 22:01:00 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2022-09-04 22:01:00 +00:00
< / div >
2022-09-04 22:27:45 +00:00
< div class = "col-sm-12" >
2023-02-04 09:50:44 +00:00
< h4 class = "card-title" > {{ translate('serverWizard', 'quickSettings', data['lang']) }} < small style = "text-transform: none;" > - {{ translate('serverWizard', 'quickSettingsDescription',
2022-03-27 22:09:49 +00:00
data['lang']) }}< / small > < / h4 >
< hr >
< div class = "row" >
2023-02-02 22:47:54 +00:00
< div class = "col-sm-4" >
2022-03-27 22:09:49 +00:00
< div class = "form-group" >
2022-09-04 22:01:00 +00:00
< label for = "min_memory3" > {{ translate('serverWizard', 'minMem', data['lang']) }} < small > - {{
2022-03-27 22:09:49 +00:00
translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "min_memory3" name = "min_memory" value = "1" step = "0.5" min = "0.5" required >
2022-02-10 23:20:36 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2023-02-02 22:47:54 +00:00
< div class = "col-sm-4" >
2022-03-27 22:09:49 +00:00
< div class = "form-group" >
2022-09-04 22:01:00 +00:00
< label for = "max_memory3" > {{ translate('serverWizard', 'maxMem', data['lang']) }} < small > - {{
2022-03-27 22:09:49 +00:00
translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "max_memory3" name = "max_memory" value = "2" step = "0.5" min = "0.5" required >
2022-02-10 23:20:36 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2022-02-10 23:20:36 +00:00
2023-02-02 22:47:54 +00:00
< div class = "col-sm-4" >
2022-03-27 22:09:49 +00:00
< div class = "form-group" >
2022-09-04 22:01:00 +00:00
< label for = "port3" > {{ translate('serverWizard', 'serverPort', data['lang']) }} < small > - {{
2022-03-27 22:09:49 +00:00
translate('serverWizard', 'defaultPort', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "port3" name = "port" value = "25565" step = "1" min = "1" max = "65535" required >
2022-02-10 23:20:36 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2022-09-04 22:01:00 +00:00
2022-03-27 22:09:49 +00:00
< div class = "col-sm-12" >
< div class = "form-group" >
2022-09-04 22:01:00 +00:00
< div id = "accordion-3" >
2022-03-27 22:09:49 +00:00
< div class = "card" >
2022-09-04 22:01:00 +00:00
< div class = "card-header p-2" id = "Role-3" >
2023-02-04 09:50:44 +00:00
< p class = "mb-0 p-0" data-toggle = "collapse" data-target = "#collapseRole-3" aria-expanded = "true" aria-controls = "collapseRole-3" >
2022-09-04 22:01:00 +00:00
< i class = "fas fa-chevron-down" > < / i > {{ translate('serverWizard', 'addRole', data['lang'])
}} < small style = "text-transform: none;" > - {{ translate('serverWizard', 'autoCreate',
2022-03-27 22:09:49 +00:00
data['lang']) }}< / small >
< / p >
< / div >
2022-09-04 22:01:00 +00:00
< div id = "collapseRole-3" class = "collapse" aria-labelledby = "Role-3" data-parent = "" >
2022-03-27 22:09:49 +00:00
< div class = "card-body scroll" >
< div class = "form-group" >
{% for r in data['roles'] %}
2023-02-04 09:50:44 +00:00
< span class = "d-block menu-option" > < label > < input name = "{{ r['role_id'] }}" type = "checkbox" >
2022-02-10 23:20:36 +00:00
{{ r['role_name'].capitalize() }}< / label > < / span >
2022-03-27 22:09:49 +00:00
{% end %}
2022-02-10 23:20:36 +00:00
< / div >
< / div >
< / div >
< / div >
< / div >
< / div >
< / div >
2023-02-02 22:47:54 +00:00
< div class = "col-sm-12" style = "visibility: hidden;" hidden >
2022-03-27 22:09:49 +00:00
< div class = "form-group" >
2022-09-04 22:01:00 +00:00
< input type = "text" class = "form-control" id = "zip_root_path" name = "zip_root_path" >
2022-02-10 23:20:36 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2023-02-04 09:50:44 +00:00
< div class = "modal fade" id = "dir_select" tabindex = "-1" role = "dialog" aria-labelledby = "dir_select" aria-hidden = "true" >
2022-09-04 22:01:00 +00:00
< 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" > × < / span >
< / button >
2022-02-10 23:20:36 +00:00
< / div >
2022-09-04 22:01:00 +00:00
< div class = "modal-body" >
2023-02-04 09:50:44 +00:00
< div class = "tree-ctx-item" id = "main-tree-div" data-path = "" style = "overflow: scroll; max-height:75%;" >
2022-09-04 22:01:00 +00:00
< 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-03-27 22:09:49 +00:00
< / div >
2022-02-10 23:20:36 +00:00
< / div >
2022-09-04 22:01:00 +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 23:20:36 +00:00
< / div >
< / div >
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2023-02-04 09:50:44 +00:00
< 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'])
2022-09-04 22:01:00 +00:00
}}< / button >
2022-10-02 19:54:13 +00:00
< button type = "button" class = "btn btn-danger mr-2 tree-reset" > {{ translate('serverWizard', 'resetForm',
data['lang'])
2022-09-04 22:01:00 +00:00
}}< / button >
2022-03-27 22:09:49 +00:00
< / div >
2022-09-04 22:27:45 +00:00
< / div >
2022-09-04 22:01:00 +00:00
< / form >
< / p >
2022-02-10 23:20:36 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2023-02-02 22:47:54 +00:00
<!-- Upload Zip File For Server Import -->
< div class = "col-md-6 grid-margin stretch-card" >
2022-09-28 02:06:22 +00:00
< div class = "card" >
< div class = "card-body" >
< h4 > {{ translate('serverWizard', 'uploadZip', 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" >
2023-02-02 22:47:54 +00:00
< 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 class = "form-group" >
2023-03-12 09:43:50 +00:00
< label for = "server" > {{ translate('serverWizard', 'serverUpload', data['lang']) }}< / label >
2023-02-02 22:47:54 +00:00
< div id = "upload_input" class = "input-group" >
< div class = "custom-file" >
< input type = "file" multiple = "false" class = "custom-file-input" id = "file" name = "file" required >
< label id = "fileLabel" class = "custom-file-label" for = "file" > {{ translate('serverWizard', 'labelZipFile', data['lang']) }}< / label >
2022-09-28 02:06:22 +00:00
< / div >
2023-02-02 22:47:54 +00:00
< div class = "input-group-append" >
2023-03-12 09:43:50 +00:00
< button type = "button" class = "btn btn-info upload-button" id = "upload-button" onclick = "sendFile()" disabled > {{ translate('serverWizard',
'uploadButton', data['lang']) }}< / button >
2022-09-28 02:06:22 +00:00
< / div >
< / div >
2023-02-02 22:47:54 +00:00
< / div >
2022-09-28 02:06:22 +00:00
2023-02-02 22:47:54 +00:00
< div id = "lower_half" style = "visibility: hidden;" hidden >
< 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_upload_button" type = "button" > {{
translate('serverWizard', 'clickRoot', data['lang']) }}< / button >
< / div >
2022-09-28 02:06:22 +00:00
2023-02-02 22:47:54 +00:00
< div class = "form-group" >
< label for = "server_jar" > {{ translate('serverWizard', 'serverJar', data['lang']) }}< / label >
2023-02-04 09:50:44 +00:00
< input type = "text" class = "form-control" id = "server_jar" name = "server_jar" value = "" placeholder = "paper.jar" required >
2023-02-02 22:47:54 +00:00
< / div >
2022-09-28 02:06:22 +00:00
2023-02-04 09:50:44 +00:00
< h4 class = "card-title" > {{ translate('serverWizard', 'quickSettings', data['lang']) }} < small style = "text-transform: none;" > - {{ translate('serverWizard', 'quickSettingsDescription',
2023-02-02 22:47:54 +00:00
data['lang']) }}< / small > < / h4 >
< hr >
2022-09-28 02:06:22 +00:00
2023-02-02 22:47:54 +00:00
< div class = "form-group" >
< label for = "min_memory3" > {{ translate('serverWizard', 'minMem', data['lang']) }} < small > - {{
translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "min_memory3" name = "min_memory" value = "1" step = "0.5" min = "0.5" required >
2023-02-02 22:47:54 +00:00
< / div >
2022-09-28 02:06:22 +00:00
2023-02-02 22:47:54 +00:00
< div class = "form-group" >
< label for = "max_memory3" > {{ translate('serverWizard', 'maxMem', data['lang']) }} < small > - {{
translate('serverWizard', 'sizeInGB', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "max_memory3" name = "max_memory" value = "2" step = "0.5" min = "0.5" required >
2023-02-02 22:47:54 +00:00
< / div >
2022-09-28 02:06:22 +00:00
2023-02-02 22:47:54 +00:00
< div class = "form-group" >
< label for = "port3" > {{ translate('serverWizard', 'serverPort', data['lang']) }} < small > - {{
translate('serverWizard', 'defaultPort', data['lang']) }}< / small > < / label >
2023-02-04 09:50:44 +00:00
< input type = "number" class = "form-control" id = "port3" name = "port" value = "25565" step = "1" min = "1" max = "65535" required >
2023-02-02 22:47:54 +00:00
< / div >
< div class = "form-group" >
< div id = "accordion-3" >
< div class = "card" >
< div class = "card-header p-2" id = "Role-3" >
2023-02-04 09:50:44 +00:00
< p class = "mb-0 p-0" data-toggle = "collapse" data-target = "#collapseRole-3" aria-expanded = "true" aria-controls = "collapseRole-3" >
2023-02-02 22:47:54 +00:00
< 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'] %}
2023-02-04 09:50:44 +00:00
< span class = "d-block menu-option" > < label > < input name = "{{ r['role_id'] }}" type = "checkbox" >
2023-02-02 22:47:54 +00:00
{{ r['role_name'].capitalize() }}< / label > < / span >
{% end %}
2022-09-28 02:06:22 +00:00
< / div >
< / div >
< / div >
2023-02-02 22:47:54 +00:00
< / div >
< / div >
< / div >
< div style = "visibility: hidden;" >
< div class = "form-group" >
< input type = "text" class = "form-control" id = "zip_root_path" name = "zip_root_path" >
< / div >
2023-02-04 09:50:44 +00:00
< div class = "modal fade" id = "dir_upload_select" tabindex = "-1" role = "dialog" aria-labelledby = "dir_select" aria-hidden = "true" >
2023-02-02 22:47:54 +00:00
< 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" > × < / span >
< / button >
2022-09-28 02:06:22 +00:00
< / div >
2023-02-02 22:47:54 +00:00
< div class = "modal-body" >
2023-02-04 09:50:44 +00:00
< div class = "tree-ctx-item" id = "main-tree-div-upload" data-path = "" style = "overflow: scroll; max-height:75%;" >
2023-02-02 22:47:54 +00:00
< input type = "radio" id = "main-tree-input-upload" name = "root_path" value = "" checked >
2023-02-04 09:50:44 +00:00
< span id = "main-tree-upload" class = "files-tree-title tree-caret-down root-dir" data-path = "" >
2023-02-02 22:47:54 +00:00
< i class = "far fa-folder" > < / i >
< i class = "far fa-folder-open" > < / i >
{{ translate('serverFiles', 'files', data['lang']) }}
< / span >
< / input >
2022-09-28 02:06:22 +00:00
< / div >
< / div >
2023-02-02 22:47:54 +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-09-28 02:06:22 +00:00
< / div >
< / div >
< / div >
< / div >
2023-02-04 09:50:44 +00:00
< button id = "upload_submit" type = "submit" title = "You must select server root dir first" disabled class = "btn btn-primary mr-2" > {{ translate('serverWizard', 'importServerButton', data['lang'])
2023-02-02 22:47:54 +00:00
}}< / button >
< button type = "button" class = "btn btn-danger mr-2 tree-reset" > {{ translate('serverWizard', 'resetForm',
data['lang'])
}}< / button >
2022-09-28 02:06:22 +00:00
< / div >
< / form >
< / p >
< / div >
< / div >
2022-09-04 22:27:45 +00:00
< / div >
2022-03-27 22:09:49 +00:00
< / div >
2022-09-04 22:27:45 +00:00
< / div >
2023-02-02 22:47:54 +00:00
< style >
button>i.refresh-class {
margin: 0px;
}
< / style >
2022-09-04 22:27:45 +00:00
< style >
.refresh-class:hover {
cursor: grab;
}
.scroll {
max-height: 12em;
overflow-y: auto;
}
.menu-btn {
font-size: 0.9em;
padding: 2px 10px;
}
.menu {
padding-top: 10px;
z-index: 200;
margin-top: 4px;
position: absolute;
2022-09-25 21:52:01 +00:00
background-color: var(--card-banner-bg);
2022-09-04 22:27:45 +00:00
}
.menu-option {
padding: 6px 20px 6px;
color: white;
}
#overlay {
position: absolute;
top: 0px;
left: 0px;
width: 100%;
height: 100%;
z-index: 100;
}
< / style >
< style >
/* Remove default bullets */
.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;
}
#op_logo {
position: relative;
top: 50%;
transform: translateY(-50%);
}
< / style >
2022-10-03 19:38:45 +00:00
< style >
.scroll {
max - height: 12em;
overflow - y: auto;
}
.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 >
< style >
/* Remove default bullets */
.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;
}
#op_logo {
position: relative;
top: 50%;
transform: translateY(-50%);
}
< / style >
< / style >
2022-09-04 22:27:45 +00:00
{% end %}
{% block js%}
2023-02-02 22:47:54 +00:00
2022-09-04 22:27:45 +00:00
< 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')) {
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 > '
} else {
document.getElementById('root_files_button').classList.add('clicked')
}
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 },
2022-12-01 01:28:24 +00:00
url: '/ajax/unzip_server?id=-1& path=' + encodeURIComponent(path),
2022-09-04 22:27:45 +00:00
});
} else {
bootbox.alert("You must input a path before selecting this button");
2022-08-03 19:38:44 +00:00
}
2022-10-03 19:38:45 +00:00
< / script >
{% end %}
2022-09-28 02:06:22 +00:00
2022-10-03 19:38:45 +00:00
{% block js %}
< script >
2022-12-15 23:48:15 +00:00
var upload = false;
2022-10-03 19:38:45 +00:00
var file;
function sendFile() {
file = $("#file")[0].files[0]
2023-02-02 22:47:54 +00:00
document.getElementById("upload_input").innerHTML = '< div class = "progress" style = "width: 100%;" > < div class = "progress-bar progress-bar-striped progress-bar-animated" role = "progressbar" aria-valuenow = "100" aria-valuemin = "0" aria-valuemax = "100" style = "width: 100%" > < i class = "fa-solid fa-spinner" > < / i > < / div > < / div > '
2022-09-28 02:06:22 +00:00
let xmlHttpRequest = new XMLHttpRequest();
let token = getCookie("_xsrf")
let fileName = file.name
let target = '/upload'
let mimeType = file.type
let size = file.size
let type = 'server_import'
2023-02-01 20:43:17 +00:00
xmlHttpRequest.upload.addEventListener('progress', function (e) {
if (e.loaded < = size) {
var percent = Math.round(e.loaded / size * 100);
$(`#upload-progress-bar`).css('width', percent + '%');
$(`#upload-progress-bar`).html(percent + '%');
}
});
2022-09-28 02:06:22 +00:00
xmlHttpRequest.open('POST', target, true);
xmlHttpRequest.setRequestHeader('X-Content-Type', mimeType);
xmlHttpRequest.setRequestHeader('X-XSRFToken', token);
xmlHttpRequest.setRequestHeader('X-Content-Length', size);
xmlHttpRequest.setRequestHeader('X-Content-Disposition', 'attachment; filename="' + fileName + '"');
xmlHttpRequest.setRequestHeader('X-Content-Upload-Type', type);
xmlHttpRequest.setRequestHeader('X-FileName', fileName);
xmlHttpRequest.addEventListener('load', (event) => {
if (event.target.responseText == 'success') {
2022-10-03 19:38:45 +00:00
console.log('Upload for file', file.name, 'was successful!')
2023-02-02 22:47:54 +00:00
document.getElementById("upload_input").innerHTML = '< div class = "card-header header-sm d-flex justify-content-between align-items-center" style = "width: 100%;" > < span id = "file-uploaded" style = "color: gray;" > ' + fileName + '< / span > 🔒< / div > ';
2022-10-03 19:38:45 +00:00
document.getElementById("lower_half").style.visibility = "visible";
2023-02-02 22:47:54 +00:00
document.getElementById("lower_half").hidden = false;
2022-09-28 02:06:22 +00:00
}
2022-10-03 19:38:45 +00:00
else {
2023-02-01 22:09:39 +00:00
let response_text = JSON.parse(event.target.responseText);
var x = document.querySelector('.bootbox');
console.log(JSON.parse(event.target.responseText).info)
bootbox.alert({
message: JSON.parse(event.target.responseText).info,
callback: function () {
window.location.reload();
}
});
2022-10-03 19:38:45 +00:00
doUpload = false;
2022-09-04 22:27:45 +00:00
}
2022-09-28 02:06:22 +00:00
}, false);
xmlHttpRequest.addEventListener('error', (e) => {
console.error('Error while uploading file', file.name + '.', 'Event:', e)
}, false);
xmlHttpRequest.send(file);
}
2022-03-27 22:09:49 +00:00
2022-10-03 19:38:45 +00:00
document.getElementById("root_files_button").addEventListener("click", function () {
2022-09-28 02:06:22 +00:00
if (document.forms["zip"]["server_path"].value != "") {
if (document.getElementById('root_files_button').classList.contains('clicked')) {
2022-10-03 19:38:45 +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 > '
} else {
document.getElementById('root_files_button').classList.add('clicked')
}
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
2022-09-28 02:06:22 +00:00
});
2022-10-03 19:38:45 +00:00
$.ajax({
type: "POST",
headers: { 'X-XSRFToken': token },
2022-12-01 01:28:24 +00:00
url: '/ajax/unzip_server?id=-1& path=' + encodeURIComponent(path),
2022-09-28 02:06:22 +00:00
});
} else {
bootbox.alert("You must input a path before selecting this button");
}
});
2022-03-27 22:09:49 +00:00
2022-10-03 19:38:45 +00:00
document.getElementById("root_upload_button").addEventListener("click", function () {
2022-09-28 02:06:22 +00:00
if (file) {
2022-12-15 23:48:15 +00:00
upload = true;
2022-09-28 02:06:22 +00:00
if (document.getElementById('root_upload_button').classList.contains('clicked')) {
2022-12-15 23:48:15 +00:00
document.getElementById('main-tree-div-upload').innerHTML = '< input type = "radio" id = "main-tree-input-upload" name = "root_path" value = "" checked > < span id = "main-tree-upload" 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-10-03 19:38:45 +00:00
} else {
document.getElementById('root_upload_button').classList.add('clicked')
}
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
2022-09-28 02:06:22 +00:00
});
2022-10-03 19:38:45 +00:00
$.ajax({
type: "POST",
headers: { 'X-XSRFToken': token },
2022-12-01 01:28:24 +00:00
url: '/ajax/unzip_server?id=-1& file=' + encodeURIComponent(file.name),
2022-09-28 02:06:22 +00:00
});
} else {
bootbox.alert("You must input a path before selecting this button");
}
2022-02-10 23:20:36 +00:00
});
2022-10-02 19:54:13 +00:00
< / script >
2022-03-27 22:09:49 +00:00
2022-10-02 19:54:13 +00:00
< script >
2022-10-03 19:38:45 +00:00
$(".tree-reset").on("click", function () {
location.href = "/server/step1";
});
function dropDown(event) {
event.target.parentElement.children[1].classList.remove("d-none");
2022-09-28 02:06:22 +00:00
document.getElementById("overlay").classList.remove("d-none");
}
2022-06-03 18:49:51 +00:00
2022-10-03 19:38:45 +00:00
function hide(event) {
2022-09-28 02:06:22 +00:00
var items = document.getElementsByClassName('menu');
items.forEach(item => {
item.classList.add("d-none");
})
document.getElementById("overlay").classList.add("d-none");
}
2022-10-03 19:38:45 +00:00
$(document).ready(function () {
console.log('ready');
2022-09-28 02:06:22 +00:00
var forms = $('form.server-wizard');
forms.each(function (i, formEl) {
var form = $(formEl);
2022-10-03 19:38:45 +00:00
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');
2022-09-28 02:06:22 +00:00
});
2022-10-03 19:38:45 +00:00
max.change(function () {
check_sizes(max, min, 'max');
2022-09-28 02:06:22 +00:00
});
});
});
2022-06-03 18:49:51 +00:00
2022-10-03 19:38:45 +00:00
function wait_msg(importing) {
bootbox.alert({
title: importing ? '{% raw translate("serverWizard", "importing", data["lang"]) %}' : '{% raw translate("serverWizard", "downloading", data["lang"]) %}',
2023-05-22 20:45:17 +00:00
message: importing ? '< i class = "fas fa-cloud-download" > < / i > {% raw translate("serverWizard", "bePatient", data["lang"]) %}': '< i class = "fas fa-cloud-download" > < / i > {% raw translate("serverWizard", "bePatient", data["lang"]) %}< br > < br > < a href = "https://serverjars.com" target = "_blank" style = "text-align: center;" > < img src = "../../static/assets/images/serverjars/FULL-WHITE.svg" alt = "Powered by serverjars.com" width = "40%" > < / a > ',
2022-10-03 19:38:45 +00:00
});
2022-09-28 02:06:22 +00:00
}
2022-02-10 23:20:36 +00:00
2022-10-03 19:38:45 +00:00
function show_file_tree() {
2022-12-15 23:48:15 +00:00
if (upload) {
$("#dir_upload_select").modal();
} else {
$("#dir_select").modal();
}
2022-09-28 02:06:22 +00:00
}
2022-02-10 23:20:36 +00:00
2022-10-03 19:38:45 +00:00
function check_sizes(a, b, changed) {
max_mem = parseFloat(a.val());
2022-09-28 02:06:22 +00:00
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)
}
}
2022-03-27 22:09:49 +00:00
2022-10-03 19:38:45 +00:00
function getTreeView(path) {
const styles = window.getComputedStyle(document.getElementById("lower_half"));
2022-09-28 02:06:22 +00:00
//If this value is still hidden we know the user is executing a zip import and not an upload
2022-10-03 19:38:45 +00:00
if (styles.visibility === "hidden") {
2022-09-28 02:06:22 +00:00
document.getElementById('zip_submit').disabled = false;
} else {
document.getElementById('upload_submit').disabled = false;
2022-03-27 22:09:49 +00:00
}
2022-09-28 02:06:22 +00:00
path = path
2022-02-10 23:20:36 +00:00
$.ajax({
type: "GET",
2022-10-03 19:38:45 +00:00
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');
2022-12-15 23:48:15 +00:00
if (styles.visibility === "hidden") {
try {
document.getElementById('main-tree-div').innerHTML += text;
document.getElementById('main-tree').parentElement.classList.add("clicked");
} catch {
document.getElementById('files-tree').innerHTML = text;
}
} else {
try {
document.getElementById('main-tree-div-upload').innerHTML += text;
document.getElementById('main-tree-upload').parentElement.classList.add("clicked");
} catch {
document.getElementById('files-tree').innerHTML = text;
}
2022-02-10 23:20:36 +00:00
}
2022-03-03 22:20:55 +00:00
2022-10-03 19:38:45 +00:00
document.getElementsByClassName('files-tree-title')[0].setAttribute('data-path', serverDir);
document.getElementsByClassName('files-tree-title')[0].setAttribute('data-name', 'Files');
2022-09-28 02:06:22 +00:00
2022-02-10 23:20:36 +00:00
},
});
}
2022-10-03 19:38:45 +00:00
function getToggleMain(event) {
path = event.target.parentElement.getAttribute('data-path');
2022-09-28 02:06:22 +00:00
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-08-03 19:38:44 +00:00
2022-09-28 02:06:22 +00:00
2022-10-03 19:38:45 +00:00
function getDirView(event) {
path = event.target.parentElement.getAttribute('data-path');
2022-09-28 02:06:22 +00:00
if (document.getElementById(path).classList.contains('clicked')) {
var toggler = document.getElementById(path + "span");
2022-10-03 19:38:45 +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");
2022-09-28 02:06:22 +00:00
}
2022-10-03 19:38:45 +00:00
return;
2022-09-28 02:06:22 +00:00
} else {
$.ajax({
type: "GET",
url: '/ajax/get_zip_dir?id=-1& path=' + path,
dataType: 'text',
success: function (data) {
console.log("got response:");
dataArr = data.split('\n');
serverDir = dataArr.shift(); // Remove & return first element (server directory)
text = dataArr.join('\n');
try {
document.getElementById(path + "span").classList.add('tree-caret-down');
document.getElementById(path).innerHTML += text;
document.getElementById(path).classList.add("clicked");
} catch {
console.log("Bad")
}
var toggler = document.getElementById(path);
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 23:20:36 +00:00
}
}
2022-10-03 19:38:45 +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)
document.getElementById('main-tree-input-upload').setAttribute('value', data.path)
getTreeView(data.path);
show_file_tree();
2022-09-28 02:06:22 +00:00
2022-10-03 19:38:45 +00:00
$("#root_files_button").attr("disabled", "disabled");
$("#root_upload_button").attr("disabled", "disabled");
2022-10-02 19:54:13 +00:00
2022-10-03 19:38:45 +00:00
}, 5000);
});
2022-09-04 22:27:45 +00:00
}
2022-09-28 02:06:22 +00:00
2022-10-03 19:38:45 +00:00
function refreshCache() {
2022-09-28 02:06:22 +00:00
var token = getCookie("_xsrf")
document.getElementById("refresh-cache").classList.add("fa-spin")
$.ajax({
type: "POST",
2022-10-03 19:38:45 +00:00
headers: { 'X-XSRFToken': token },
url: '/ajax/jar_cache',
success: function () {
document.getElementById("refresh-cache").classList.remove("fa-sync");
document.getElementById("refresh-cache").classList.remove("fa-spin");
document.getElementById("refresh-cache").classList.add("fa-check");
setTimeout(function () {
location.reload();
2022-09-28 02:06:22 +00:00
}, 2000);
},
});
}
2023-02-02 22:47:54 +00:00
$('#file').change(function () {
console.log("File changed");
if ($('#file').val()) {
$('#upload-button').prop("disabled", false);
document.getElementById("fileLabel").innerHTML = $('#file').val().split('\\').pop().split('/').pop();
console.log("File changed good");
}
});
2022-10-02 19:54:13 +00:00
< / script >
< script type = "text/javascript" >
2022-10-03 19:38:45 +00:00
var text = '{% raw data["js_server_types"] %}';
var serverTypesLists = JSON.parse(text);
/* 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) {
2022-09-28 02:06:22 +00:00
// get the index of the selected option
var idx = document.getElementById('server_type').selectedIndex;
// get the value of the selected option
var cSelect = document.getElementById("server");
2022-09-04 22:27:45 +00:00
try {
2022-09-28 02:06:22 +00:00
var which = document.getElementById('server_type').options[idx].value;
} catch {
while (cSelect.options.length > 0) {
2022-10-03 19:38:45 +00:00
cSelect.remove(0);
2022-09-28 02:06:22 +00:00
}
2022-10-03 19:38:45 +00:00
return;
2022-09-04 22:27:45 +00:00
}
2022-09-28 02:06:22 +00:00
let server_type = which.split('|')[0];
let server = which.split('|')[1];
// use the selected option value to retrieve the list of items from the serverTypesLists array
let cList = serverTypesLists[server_type];
// 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);
2022-08-03 16:26:59 +00:00
}
2022-09-28 02:06:22 +00:00
var newOption;
// create new options ordered by ascending
cList[server].forEach(type => {
newOption = document.createElement("option");
2022-10-03 19:38:45 +00:00
newOption.value = which + "|" + type; // assumes option string and value are the same
newOption.text = type;
// add the new option
try {
cSelect.add(newOption); // this will fail in DOM browsers but is needed for IE
2022-09-28 02:06:22 +00:00
}
2022-10-03 19:38:45 +00:00
catch (e) {
cSelect.appendChild(newOption);
2022-09-28 02:06:22 +00:00
}
})
}
2022-10-03 19:38:45 +00:00
function serverJarChange(selectObj) {
let type_select = document.getElementById('server_jar')
2022-09-28 02:06:22 +00:00
let tidx = type_select.selectedIndex;
let val = type_select.options[tidx].value;
if (val == 'None') {
var jcSelect = document.getElementById("server_type");
while (jcSelect.options.length > 0) {
2022-10-03 19:38:45 +00:00
jcSelect.remove(0);
2022-09-28 02:06:22 +00:00
}
2022-10-03 19:38:45 +00:00
serverTypeChange(selectObj);
return;
2022-09-28 02:06:22 +00:00
}
// get the index of the selected option
var jidx = selectObj.selectedIndex;
// get the value of the selected option
var jwhich = selectObj.options[jidx].value;
// use the selected option value to retrieve the list of items from the serverTypesLists array
jcList = Object.keys(serverTypesLists[jwhich]);
// get the country select element via its known id
2022-08-03 01:08:53 +00:00
var jcSelect = document.getElementById("server_type");
2022-09-28 02:06:22 +00:00
// remove the current options from the country select
var jlen = jcSelect.options.length;
2022-08-03 01:08:53 +00:00
while (jcSelect.options.length > 0) {
jcSelect.remove(0);
}
2022-09-28 02:06:22 +00:00
var jnewOption;
// create new options ordered by ascending
jcList.forEach(type => {
jnewOption = document.createElement("option");
2022-10-03 19:38:45 +00:00
jnewOption.value = jwhich + "|" + type; // assumes option string and value are the same
jnewOption.text = type;
// add the new option
try {
jcSelect.add(jnewOption); // this will fail in DOM browsers but is needed for IE
2022-09-28 02:06:22 +00:00
}
2022-10-03 19:38:45 +00:00
catch (e) {
jcSelect.appendChild(jnewOption);
2022-09-28 02:06:22 +00:00
}
})
2022-08-03 01:08:53 +00:00
serverTypeChange(selectObj);
}
2022-10-02 19:54:13 +00:00
< / script >
{% end %}