crafty-4/app/frontend/templates/panel/server_webhook_edit.html

242 lines
9.1 KiB
HTML
Raw Normal View History

2023-06-03 13:36:38 -04:00
{% extends ../base.html %}
{% block meta %}
{% end %}
{% block title %}Crafty Controller - {{ translate('serverDetails', 'serverDetails', data['lang']) }}{% end %}
{% block content %}
2023-06-03 18:10:39 -04:00
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/css/bootstrap-select.min.css">
2023-06-03 13:36:38 -04:00
<div class="content-wrapper">
<!-- Page Title Header Starts-->
<div class="row page-title-header">
<div class="col-12">
<div class="page-header">
<h4 class="page-title">
{{ translate('serverDetails', 'serverDetails', data['lang']) }} - {{
data['server_stats']['server_id']['server_name'] }}
<br />
<small>UUID: {{ data['server_stats']['server_id']['server_uuid'] }}</small>
</h4>
</div>
</div>
</div>
<!-- Page Title Header Ends-->
{% include "parts/details_stats.html" %}
<div class="row">
<div class="col-sm-12 grid-margin">
<div class="card">
<div class="card-body pt-0">
{% include "parts/server_controls_list.html" %}
<div class="row">
<div class="col-md-8 col-sm-8">
{% if data['new_webhook'] == True %}
<form class="forms-sample" method="post" id="new_webhook_form"
action="/panel/new_webhook?id={{ data['server_stats']['server_id']['server_id'] }}">
2023-06-03 18:10:39 -04:00
{% else %}
<form class="forms-sample" method="post" id="schedule_form"
action="/panel/edit_webhook?id={{ data['server_stats']['server_id']['server_id'] }}&sch_id={{ data['webhook']['id'] }}">
{% end %}
<select class="form-select form-control form-control-lg select-css" id="webhook_type" name="webhook_type">
{% for type in data['providers'] %}
<option value="{{type}}">{{type}}</option>
{% end %}
2023-06-03 13:36:38 -04:00
</select>
<br>
<br>
2023-06-03 18:10:39 -04:00
<div class="form-group">
<label for="name">{{ translate('serverSchedules', 'name' , data['lang']) }}</label>
<input type="input" class="form-control" name="name" id="name_input"
value="{{ data['webhook']['name']}}" maxlength="30" placeholder="Name" required>
</div>
<div class="form-group">
<label for="url">Webhook URL</label>
<input type="input" class="form-control" name="url" id="url"
value="{{ data['webhook']['url']}}" placeholder="https://webhooks.craftycontrol.com/fakeurl" required>
</div>
<div class="form-group">
<label for="bot_name">Bot {{ translate('serverSchedules', 'name' , data['lang']) }}</label>
<input type="input" class="form-control" name="bot_name" id="bot_name_input"
value="{{ data['webhook']['bot_name']}}" maxlength="30" placeholder="Crafty Controller" required>
</div>
<div class="form-group">
<label for="trigger">Trigger</label>
<select class="form-control selectpicker show-tick" name="trigger" id="trigger-select" data-icon-base="fas" data-tick-icon="fa-check" multiple data-style="custom-picker">
{% for trigger in data['triggers'] %}
{% if trigger in data["webhook"]["trigger"] %}
<option selected>{{trigger}}</option>
{% else %}
<option>{{trigger}}</option>
{% end %}
{% end %}
</select>
</div>
<div class="form-group">
<label for="body">Body</label>
<textarea id="body-input" name="body" rows="4" cols="50">
{{ data["webhook"]["body"] }}
</textarea>
</div>
<div class="form-check-flat">
<label for="enabled" class="form-check-label ml-4 mb-4">
<input type="checkbox" class="form-check-input" id="enabled" name="enabled" checked=""
value="1">{{ translate('serverScheduleConfig', 'enabled' , data['lang']) }}
</label>
</div>
2023-06-03 13:36:38 -04:00
<button type="submit" class="btn btn-success mr-2"><i class="fas fa-save"></i> {{
translate('serverConfig', 'save', data['lang']) }}</button>
<button type="reset"
2023-06-03 18:10:39 -04:00
onclick="location.href=`/panel/server_detail?id={{ data['server_stats']['server_id']['server_id'] }}&subpage=webhooks`"
2023-06-03 13:36:38 -04:00
class="btn btn-light"><i class="fas fa-times"></i> {{ translate('serverConfig', 'cancel',
data['lang']) }}</button>
</form>
</div>
</div>
</div>
</div>
</div>
</div>
2023-06-03 18:10:39 -04:00
<style>
#body-input {
background-color: var(--card-banner-bg);
outline-color: var(--outline);
color: var(--base-text);
width: 100%;
}
</style>
2023-06-03 13:36:38 -04:00
<!-- content-wrapper ends -->
{% end %}
{% block js %}
<script>
//used to get cookies from browser - this is part of tornados xsrf protection - it's for extra security
function getCookie(name) {
var r = document.cookie.match("\\b" + name + "=([^;]*)\\b");
return r ? r[1] : undefined;
}
function replacer(key, value) {
if (key != "start_time" && key != "cron_string" && key != "interval_type") {
if (typeof value == "boolean") {
return value
}
console.log(key)
if (key === "interval" && value === ""){
return 0;
}
if (key === "command" && typeof(value === "integer")){
return value.toString();
}else {
return (isNaN(value) ? value : +value);
}
} else {
if (value === "" && key == "start_time"){
return "00:00";
}else{
return value;
}
}
}
const serverId = new URLSearchParams(document.location.search).get('id');
2023-06-03 18:10:39 -04:00
const webhookId = new URLSearchParams(document.location.search).get('webhook_id');
2023-06-03 13:36:38 -04:00
$(document).ready(function () {
console.log("ready!");
2023-06-03 18:10:39 -04:00
console.log('ready for JS!');
$('.selectpicker').selectpicker("refresh");
$("#new_webhook_form").on("submit", async function (e) {
2023-06-03 13:36:38 -04:00
e.preventDefault();
var token = getCookie("_xsrf")
2023-06-03 18:10:39 -04:00
let webhookForm = document.getElementById("new_webhook_form");
let select_val = JSON.stringify($('#trigger-select').val());
select_val = JSON.parse(select_val);
2023-06-03 13:36:38 -04:00
2023-06-03 18:10:39 -04:00
let formData = new FormData(webhookForm);
2023-06-03 13:36:38 -04:00
//Create an object from the form data entries
let formDataObject = Object.fromEntries(formData.entries());
//We need to make sure these are sent regardless of whether or not they're checked
formDataObject.enabled = $("#enabled").prop('checked');
2023-06-03 18:10:39 -04:00
formDataObject.trigger = select_val;
2023-06-03 13:36:38 -04:00
console.log(formDataObject);
// Format the plain form data as JSON
let formDataJsonString = JSON.stringify(formDataObject, replacer);
2023-06-03 18:10:39 -04:00
let res = await fetch(`/api/v2/servers/${serverId}/webhook/`, {
2023-06-03 13:36:38 -04:00
method: 'POST',
headers: {
'X-XSRFToken': token,
"Content-Type": "application/json",
},
body: formDataJsonString,
});
let responseData = await res.json();
if (responseData.status === "ok") {
2023-06-03 18:10:39 -04:00
window.location.href = `/panel/server_detail?id=${serverId}&subpage=webhooks`;
2023-06-03 13:36:38 -04:00
} else {
bootbox.alert({
title: responseData.status,
message: responseData.error
});
}
});
$("#schedule_form").on("submit", async function (e) {
e.preventDefault();
2023-06-03 18:10:39 -04:00
var token = getCookie("_xsrf");
let webhookForm = document.getElementById("new_webhook_form");
let select_val = JSON.stringify($('#trigger-select').val());
select_val = JSON.parse(select_val);
2023-06-03 13:36:38 -04:00
2023-06-03 18:10:39 -04:00
let formData = new FormData(webhookForm);
2023-06-03 13:36:38 -04:00
//Create an object from the form data entries
let formDataObject = Object.fromEntries(formData.entries());
//We need to make sure these are sent regardless of whether or not they're checked
formDataObject.enabled = $("#enabled").prop('checked');
2023-06-03 18:10:39 -04:00
formDataObject.trigger = select_val;
2023-06-03 13:36:38 -04:00
console.log(formDataObject);
// Format the plain form data as JSON
let formDataJsonString = JSON.stringify(formDataObject, replacer);
2023-06-03 18:10:39 -04:00
let res = await fetch(`/api/v2/servers/${serverId}/webhooks/${webhookId}`, {
2023-06-03 13:36:38 -04:00
method: 'PATCH',
headers: {
'X-XSRFToken': token,
"Content-Type": "application/json",
},
body: formDataJsonString,
});
let responseData = await res.json();
if (responseData.status === "ok") {
2023-06-03 18:10:39 -04:00
window.location.href = `/panel/server_detail?id=${serverId}&subpage=webhooks`;
2023-06-03 13:36:38 -04:00
} else {
bootbox.alert({
title: responseData.error,
message: responseData.error_data
});
}
});
});
window.onload(startup())
</script>
2023-06-03 18:10:39 -04:00
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/js/bootstrap-select.min.js"></script>
2023-06-03 13:36:38 -04:00
{% end %}