2023-01-09 23:52:45 +00:00
|
|
|
|
{% extends ../base.html %}
|
|
|
|
|
|
|
|
|
|
{% block meta %}
|
|
|
|
|
{% end %}
|
|
|
|
|
|
|
|
|
|
{% block title %}Crafty Controller - {{ translate('panelConfig', 'pageTitle', data['lang']) }}{% end %}
|
|
|
|
|
|
|
|
|
|
{% block content %}
|
2023-02-06 00:05:20 +00:00
|
|
|
|
<link rel="stylesheet"
|
|
|
|
|
href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/css/bootstrap-select.min.css">
|
2023-01-19 19:09:21 +00:00
|
|
|
|
|
2023-01-09 23:52:45 +00:00
|
|
|
|
|
|
|
|
|
<div class="content-wrapper">
|
|
|
|
|
<!-- Page Title Header Starts-->
|
|
|
|
|
<div class="row page-title-header">
|
|
|
|
|
<div class="col-12">
|
|
|
|
|
<div class="page-header">
|
2023-01-21 11:29:08 +00:00
|
|
|
|
<h4 class="page-title">
|
|
|
|
|
{{ translate('panelConfig', 'title', data['lang']) }}
|
|
|
|
|
<br />
|
|
|
|
|
</h4>
|
2023-01-09 23:52:45 +00:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<!-- Page Title Header Ends-->
|
|
|
|
|
|
|
|
|
|
<div class="row">
|
|
|
|
|
<div class="col-md-12 grid-margin">
|
|
|
|
|
<div class="card">
|
|
|
|
|
<div class="card-body">
|
2023-01-21 11:29:08 +00:00
|
|
|
|
|
|
|
|
|
{% if data['superuser'] %}
|
|
|
|
|
{% include "parts/crafty_config_list.html %}
|
|
|
|
|
{% end %}
|
|
|
|
|
|
|
|
|
|
<!-- Page Title Header Starts-->
|
|
|
|
|
<div class="row page-title-header">
|
|
|
|
|
<div class="col-12">
|
|
|
|
|
<div class="page-header">
|
|
|
|
|
<!-- TODO: Translate the following -->
|
|
|
|
|
<h4 class="page-title">Config.json</h4>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
<!-- Page Title Header Ends-->
|
|
|
|
|
|
2023-01-10 19:12:33 +00:00
|
|
|
|
<form id="config-form" class="forms-sample" method="post" action="/panel/config_json">
|
|
|
|
|
{% raw xsrf_form_html() %}
|
2023-01-18 21:01:23 +00:00
|
|
|
|
|
2023-01-09 23:52:45 +00:00
|
|
|
|
{% for item in data['config-json'].items() %}
|
2023-01-29 22:25:44 +00:00
|
|
|
|
{% if item[0] == "reset_secrets_on_next_boot" %}
|
|
|
|
|
<div class="form-group" style="background: rgba(243, 21, 6, 0.3); outline: 1px solid red; padding: 10px;">
|
2023-02-06 00:05:20 +00:00
|
|
|
|
{% else %}
|
|
|
|
|
<div class="form-group">
|
2023-01-18 21:01:23 +00:00
|
|
|
|
{% end %}
|
2023-02-06 00:05:20 +00:00
|
|
|
|
<label class="form" for="{{item[0]}}">{{item[0]}}
|
|
|
|
|
<small class="text-muted ml-1">
|
|
|
|
|
</small> </label><br />
|
|
|
|
|
{% if item[0] == 'language' %}
|
|
|
|
|
<select name="{{item[0]}}" class="form-control">
|
|
|
|
|
{% for lang in data['availables_languages'] %}
|
|
|
|
|
{% if lang == item[1] %}
|
2023-01-21 08:53:46 +00:00
|
|
|
|
<option selected>{{lang}}</option>
|
|
|
|
|
{% else %}
|
|
|
|
|
<option>{{lang}}</option>
|
|
|
|
|
{% end %}
|
|
|
|
|
{% end %}
|
|
|
|
|
</select>
|
2023-02-06 00:05:20 +00:00
|
|
|
|
{% elif item[0] == 'disabled_language_files' %}
|
|
|
|
|
<div class="input-group">
|
|
|
|
|
<button type="button" class="btn btn-outline-default custom-picker" onclick="$('option', $('#lang_select')).each(function(element) {
|
|
|
|
|
$(this).removeAttr('selected').prop('selected', false); $('.selectpicker').selectpicker('refresh')
|
2023-02-06 01:11:21 +00:00
|
|
|
|
});">{{ translate('panelConfig', 'enableLang', data['lang']) }}</button>
|
2023-02-06 00:05:20 +00:00
|
|
|
|
<select id="lang_select" class="form-control selectpicker show-tick" data-icon-base="fas"
|
|
|
|
|
data-tick-icon="fa-check" multiple data-style="custom-picker">
|
|
|
|
|
{% for lang in data['all_languages'] %}
|
|
|
|
|
{% if lang in item[1] %}
|
|
|
|
|
<option selected>{{lang}}</option>
|
|
|
|
|
{% else %}
|
|
|
|
|
<option>{{lang}}</option>
|
|
|
|
|
{% end %}
|
|
|
|
|
{% end %}
|
|
|
|
|
</select>
|
|
|
|
|
<textarea id="disabled_lang" name="{{item[0]}}" class="form-control list hidden"
|
|
|
|
|
rows="{{ len(data['all_languages']) }}" value="{{','.join(item[1])}}"
|
|
|
|
|
hidden>{{','.join(item[1])}}</textarea>
|
|
|
|
|
</div>
|
|
|
|
|
{% elif item[0] == 'monitored_mounts'%}
|
|
|
|
|
<div class="input-group">
|
|
|
|
|
<button type="button" class="btn btn-outline-default custom-picker" onclick="$('option', $('#mount_select')).each(function(element) {
|
|
|
|
|
$(this).removeAttr('selected').prop('selected', false); $('.selectpicker').selectpicker('refresh')
|
2023-02-06 01:11:21 +00:00
|
|
|
|
});">{{ translate('panelConfig', 'noMounts', data['lang']) }}</button>
|
2023-02-06 00:05:20 +00:00
|
|
|
|
<select id="mount_select" class="form-control selectpicker show-tick" data-icon-base="fas"
|
|
|
|
|
data-tick-icon="fa-check" multiple data-style="custom-picker">
|
|
|
|
|
{% for mount in data['all_partitions'] %}
|
|
|
|
|
{% if mount in item[1] %}
|
|
|
|
|
<option selected>{{mount}}</option>
|
|
|
|
|
{% else %}
|
|
|
|
|
<option>{{mount}}</option>
|
|
|
|
|
{% end %}
|
|
|
|
|
{% end %}
|
|
|
|
|
</select>
|
|
|
|
|
<textarea id="monitored_mounts" name="{{item[0]}}" class="form-control list hidden"
|
|
|
|
|
rows="{{ len(data['all_partitions']) }}" value="{{','.join(item[1])}}"
|
|
|
|
|
hidden>{{','.join(item[1])}}</textarea>
|
|
|
|
|
</div>
|
|
|
|
|
{% elif isinstance(item[1], list) %}
|
|
|
|
|
<textarea value="{{','.join(item[1])}}" type="text" name="{{item[0]}}"
|
|
|
|
|
class="form-control list">{{','.join(item[1])}}</textarea>
|
|
|
|
|
{% elif isinstance(item[1], bool) %}
|
|
|
|
|
<div style="margin-left: 30px;">
|
|
|
|
|
{% if item[1] == True %}
|
|
|
|
|
<input type="radio" class="form-check-input" name="{{item[0]}}" id="True" value="True" checked>
|
|
|
|
|
<label for="True">True</label><br>
|
|
|
|
|
<input type="radio" class="form-check-input" name="{{item[0]}}" id="False" value="False">
|
|
|
|
|
<label for="False">False</label>
|
|
|
|
|
{% else %}
|
|
|
|
|
<input type="radio" class="form-check-input" name="{{item[0]}}" id="True" value="True">
|
|
|
|
|
<label for="True">True</label><br>
|
|
|
|
|
<input type="radio" class="form-check-input" name="{{item[0]}}" id="False" value="False" checked>
|
|
|
|
|
<label for="False">False</label>
|
|
|
|
|
{% end %}
|
|
|
|
|
</div>
|
|
|
|
|
{% elif isinstance(item[1], int) %}
|
|
|
|
|
<input type="number" class="form-control" name="{{item[0]}}" id="{{item[0]}}" value="{{ item[1] }}"
|
|
|
|
|
step="1" min="0" required>
|
|
|
|
|
{% else %}
|
|
|
|
|
<input type="text" class="form-control" name="{{item[0]}}" id="{{item[0]}}" value="{{ item[1] }}"
|
|
|
|
|
step="2" min="0" required>
|
|
|
|
|
{% end %}
|
2023-01-29 22:05:17 +00:00
|
|
|
|
</div>
|
2023-01-18 21:01:23 +00:00
|
|
|
|
{% end %}
|
2023-02-06 00:05:20 +00:00
|
|
|
|
<button class="btn btn-success" type="submit">Submit</button> <span id="submit-status"></span>
|
2023-01-09 23:52:45 +00:00
|
|
|
|
</form>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<style>
|
2023-01-21 08:53:46 +00:00
|
|
|
|
.custom-picker {
|
|
|
|
|
border: 1px solid var(--outline);
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-19 19:09:21 +00:00
|
|
|
|
.dropdown-menu.inner {
|
|
|
|
|
display: inline-block !important;
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-09 23:52:45 +00:00
|
|
|
|
.popover-body {
|
|
|
|
|
color: white !important;
|
|
|
|
|
;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
input[type="radio"] {
|
|
|
|
|
-ms-transform: scale(1.5);
|
|
|
|
|
/* IE 9 */
|
|
|
|
|
-webkit-transform: scale(1.5);
|
|
|
|
|
/* Chrome, Safari, Opera */
|
|
|
|
|
transform: scale(1.5);
|
|
|
|
|
}
|
|
|
|
|
</style>
|
|
|
|
|
<!-- content-wrapper ends -->
|
|
|
|
|
|
|
|
|
|
{% end %}
|
|
|
|
|
|
|
|
|
|
{% block js %}
|
|
|
|
|
<script>
|
2023-01-15 23:57:22 +00:00
|
|
|
|
$("#config-form").submit(function (e) {
|
|
|
|
|
let uuid = uuidv4();
|
|
|
|
|
var token = getCookie("_xsrf")
|
|
|
|
|
e.preventDefault();
|
2023-01-18 21:01:23 +00:00
|
|
|
|
|
2023-01-18 23:00:50 +00:00
|
|
|
|
$("#submit-status").html('<i class="fa fa-spinner fa-spin"></i>');
|
2023-01-18 21:01:23 +00:00
|
|
|
|
/* Convert multiple select to text list */
|
|
|
|
|
let selected_Lang = $('#lang_select').val();
|
|
|
|
|
$('#disabled_lang').val(selected_Lang);
|
|
|
|
|
|
2023-02-06 00:05:20 +00:00
|
|
|
|
let mounts = $('#mount_select').val();
|
|
|
|
|
$('#monitored_mounts').val(mounts);
|
|
|
|
|
|
2023-01-15 23:57:22 +00:00
|
|
|
|
let class_list = document.getElementsByClassName("list");
|
|
|
|
|
let form_json = convertFormToJSON($("#config-form"));
|
|
|
|
|
for (let i = 0; i < class_list.length; i++) {
|
|
|
|
|
let str = String($(class_list.item(i)).val())
|
|
|
|
|
form_json[$(class_list.item(i)).attr("name")] = uuid + "," + str.replace(/\s/g, '');
|
|
|
|
|
};
|
|
|
|
|
form_json['uuid'] = uuid;
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: "POST",
|
|
|
|
|
headers: { 'X-XSRFToken': token },
|
2023-01-18 23:00:50 +00:00
|
|
|
|
dataType: "text",
|
2023-01-15 23:57:22 +00:00
|
|
|
|
url: '/panel/config_json',
|
|
|
|
|
data: form_json,
|
2023-01-18 23:00:50 +00:00
|
|
|
|
success: function (data) {
|
|
|
|
|
$("#submit-status").html('<i class="fa fa-check"></i>');
|
2023-01-15 23:57:22 +00:00
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
function uuidv4() {
|
|
|
|
|
return ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, c =>
|
|
|
|
|
(c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16)
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
function convertFormToJSON(form) {
|
|
|
|
|
const array = $(form).serializeArray(); // Encodes the set of form elements as an array of names and values.
|
|
|
|
|
const json = {};
|
|
|
|
|
$.each(array, function () {
|
|
|
|
|
json[this.name] = this.value || "";
|
|
|
|
|
});
|
|
|
|
|
return json;
|
|
|
|
|
}
|
|
|
|
|
|
2023-01-09 23:52:45 +00:00
|
|
|
|
$(document).ready(function () {
|
|
|
|
|
$('[data-toggle="popover"]').popover();
|
|
|
|
|
if ($(window).width() < 1000) {
|
|
|
|
|
$('.too_small').popover("show");
|
|
|
|
|
$('.too_small2').popover("show");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
$(window).ready(function () {
|
|
|
|
|
$('body').click(function () {
|
|
|
|
|
$('.too_small').popover("hide");
|
|
|
|
|
$('.too_small2').popover("hide");
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
$(window).resize(function () {
|
|
|
|
|
// This will execute whenever the window is resized
|
|
|
|
|
if ($(window).width() < 1000) {
|
|
|
|
|
$('.too_small').popover("show");
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$('.too_small').popover("hide");
|
|
|
|
|
} // New width
|
|
|
|
|
if ($(window).width() < 1000) {
|
|
|
|
|
$('.too_small2').popover("show");
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$('.too_small2').popover("hide");
|
|
|
|
|
} // New width
|
|
|
|
|
});
|
|
|
|
|
$('#file').change(function () {
|
|
|
|
|
console.log("File changed");
|
|
|
|
|
if ($('#file').val()) {
|
|
|
|
|
$('#upload-button').prop("disabled", false);
|
|
|
|
|
console.log("File changed good");
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
<script>
|
|
|
|
|
|
|
|
|
|
$(document).ready(function () {
|
2023-01-19 19:09:21 +00:00
|
|
|
|
console.log('ready for JS!');
|
|
|
|
|
$('.selectpicker').selectpicker("refresh");
|
2023-01-09 23:52:45 +00:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$(".show_button").click(function () {
|
|
|
|
|
console.log("showing key");
|
|
|
|
|
api_key = $(this).attr("data-id");
|
|
|
|
|
bootbox.alert({
|
|
|
|
|
backdrop: true,
|
|
|
|
|
title: '',
|
|
|
|
|
message: api_key,
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$('.clear-comm').click(function () {
|
|
|
|
|
var token = getCookie("_xsrf")
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: "POST",
|
|
|
|
|
headers: { 'X-XSRFToken': token },
|
|
|
|
|
url: '/ajax/clear_comm',
|
|
|
|
|
success: function (data) {
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
$('.delete-photo').click(function () {
|
|
|
|
|
var token = getCookie("_xsrf")
|
|
|
|
|
let photo = $('#photo').find(":selected").val();
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: "POST",
|
|
|
|
|
headers: { 'X-XSRFToken': token },
|
|
|
|
|
url: '/ajax/delete_photo?photo=' + photo,
|
|
|
|
|
success: function (data) {
|
|
|
|
|
location.reload();
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
$('.select-photo').click(function () {
|
|
|
|
|
var token = getCookie("_xsrf")
|
|
|
|
|
let photo = $('#photo').find(":selected").val();
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: "POST",
|
|
|
|
|
headers: { 'X-XSRFToken': token },
|
|
|
|
|
url: '/ajax/select_photo?photo=' + photo,
|
|
|
|
|
success: function (data) {
|
|
|
|
|
window.location.reload();
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
</script>
|
2023-01-19 19:09:21 +00:00
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/js/bootstrap-select.min.js">
|
|
|
|
|
</script>
|
2023-01-09 23:52:45 +00:00
|
|
|
|
{% end %}
|