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

278 lines
11 KiB
HTML
Raw Normal View History

2023-06-03 17:36:38 +00:00
{% extends ../base.html %}
{% block meta %}
{% end %}
{% block title %}Crafty Controller - {{ translate('serverDetails', 'serverDetails', data['lang']) }}{% end %}
{% block content %}
2023-06-03 22:10:39 +00:00
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/css/bootstrap-select.min.css">
2023-06-03 17:36:38 +00: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 22:10:39 +00:00
{% else %}
2023-06-04 02:40:39 +00:00
<form class="forms-sample" method="post" id="webhook_form"
2023-06-03 22:10:39 +00:00
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">
2023-10-05 22:05:12 +00:00
<option value="{{data['webhook']['webhook_type']}}">{{data['webhook']['webhook_type']}}</option>
2023-06-03 22:10:39 +00:00
{% for type in data['providers'] %}
2023-10-05 22:05:12 +00:00
{% if type != data['webhook']['webhook_type'] %}
2023-06-03 22:10:39 +00:00
<option value="{{type}}">{{type}}</option>
2023-10-05 22:05:12 +00:00
{%end%}
2023-06-03 22:10:39 +00:00
{% end %}
2023-06-03 17:36:38 +00:00
</select>
<br>
<br>
2023-06-03 22:10:39 +00:00
<div class="form-group">
2023-06-03 22:38:44 +00:00
<label for="name">{{ translate('webhooks', 'name' , data['lang']) }}</label>
2023-06-03 22:10:39 +00:00
<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">
2023-06-03 22:38:44 +00:00
<label for="url">{{ translate('webhooks', 'url', data['lang']) }}</label>
2023-06-03 22:10:39 +00:00
<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">
2023-06-03 22:38:44 +00:00
<label for="bot_name">{{ translate('webhooks', 'bot_name' , data['lang']) }}</label>
2023-06-03 22:10:39 +00:00
<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">
2023-06-03 22:38:44 +00:00
<label for="trigger">{{ translate('webhooks', 'trigger', data['lang']) }}</label>
2023-06-03 22:10:39 +00:00
<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"] %}
2023-09-28 21:47:03 +00:00
<option value="{{trigger}}" selected>{{translate('webhooks', trigger , data['lang'])}}</option>
2023-06-03 22:10:39 +00:00
{% else %}
2023-09-28 21:47:03 +00:00
<option value="{{trigger}}">{{translate('webhooks', trigger , data['lang'])}}</option>
2023-06-03 22:10:39 +00:00
{% end %}
{% end %}
</select>
</div>
<div class="form-group">
2023-06-03 22:38:44 +00:00
<label for="body">{{ translate('webhooks', 'webhook_body', data['lang']) }}</label>
2023-06-03 22:10:39 +00:00
<textarea id="body-input" name="body" rows="4" cols="50">
{{ data["webhook"]["body"] }}
</textarea>
</div>
2023-09-28 23:07:03 +00:00
<div class="form-group">
<label for="bot_name">{{ translate('webhooks', 'color' , data['lang']) }}</label>
<input type="color" class="form-control" name="color" id="color" value='{{data["webhook"]["color"]}}'>
</div>
<div class="form-group">
<div class="custom-control custom-switch">
<input type="checkbox" class="custom-control-input" id="enabled" name="enabled" {% if data['webhook']['enabled'] %}checked{%end%}
value="1">
<label for="enabled" class="custom-control-label">{{ translate('webhooks', 'enabled', data['lang']) }}</label>
</div>
2023-06-03 22:10:39 +00:00
</div>
2023-06-03 17:36:38 +00: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 22:10:39 +00:00
onclick="location.href=`/panel/server_detail?id={{ data['server_stats']['server_id']['server_id'] }}&subpage=webhooks`"
2023-06-03 17:36:38 +00: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 22:10:39 +00:00
<style>
.custom-control-input:checked~.custom-control-label::before {
color: black !important;
background-color: blueviolet !important;
border-color: var(--outline) !important;
}
.custom-control-label::before {
background-color: white !important;
top: calc(-0.2rem);
}
.custom-switch .custom-control-label::after {
top: calc(-0.125rem + 1px);
}
2023-06-03 22:10:39 +00:00
#body-input {
background-color: var(--card-banner-bg);
outline-color: var(--outline);
color: var(--base-text);
width: 100%;
}
</style>
2023-06-03 17:36:38 +00:00
<!-- content-wrapper ends -->
{% end %}
{% block js %}
<script>
$(function () {
$('.form-check-input').bootstrapToggle({
on: '',
off: ''
});
})
2023-06-03 17:36:38 +00:00
//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 22:10:39 +00:00
const webhookId = new URLSearchParams(document.location.search).get('webhook_id');
2023-06-03 17:36:38 +00:00
$(document).ready(function () {
console.log("ready!");
2023-06-03 22:10:39 +00:00
console.log('ready for JS!');
$('.selectpicker').selectpicker("refresh");
$("#new_webhook_form").on("submit", async function (e) {
2023-06-03 17:36:38 +00:00
e.preventDefault();
var token = getCookie("_xsrf")
2023-06-03 22:10:39 +00: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 17:36:38 +00:00
2023-06-03 22:10:39 +00:00
let formData = new FormData(webhookForm);
2023-06-03 17:36:38 +00: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 22:10:39 +00:00
formDataObject.trigger = select_val;
2023-06-03 17:36:38 +00:00
console.log(formDataObject);
// Format the plain form data as JSON
let formDataJsonString = JSON.stringify(formDataObject, replacer);
2023-06-03 22:10:39 +00:00
let res = await fetch(`/api/v2/servers/${serverId}/webhook/`, {
2023-06-03 17:36:38 +00: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 22:10:39 +00:00
window.location.href = `/panel/server_detail?id=${serverId}&subpage=webhooks`;
2023-06-03 17:36:38 +00:00
} else {
bootbox.alert({
title: responseData.status,
message: responseData.error
});
}
});
2023-06-04 02:40:39 +00:00
$("#webhook_form").on("submit", async function (e) {
2023-06-03 17:36:38 +00:00
e.preventDefault();
2023-06-03 22:10:39 +00:00
var token = getCookie("_xsrf");
2023-06-04 02:40:39 +00:00
let webhookForm = document.getElementById("webhook_form");
2023-06-03 22:10:39 +00:00
let select_val = JSON.stringify($('#trigger-select').val());
select_val = JSON.parse(select_val);
2023-06-03 17:36:38 +00:00
2023-06-03 22:10:39 +00:00
let formData = new FormData(webhookForm);
2023-06-03 17:36:38 +00: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 22:10:39 +00:00
formDataObject.trigger = select_val;
2023-09-28 23:07:03 +00:00
if(formDataObject.webhook_type != "Discord"){
delete formDataObject.color
}
2023-06-03 22:10:39 +00:00
2023-06-03 17:36:38 +00:00
console.log(formDataObject);
// Format the plain form data as JSON
let formDataJsonString = JSON.stringify(formDataObject, replacer);
2023-06-04 02:40:39 +00:00
let res = await fetch(`/api/v2/servers/${serverId}/webhook/${webhookId}`, {
2023-06-03 17:36:38 +00: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 22:10:39 +00:00
window.location.href = `/panel/server_detail?id=${serverId}&subpage=webhooks`;
2023-06-03 17:36:38 +00:00
} else {
bootbox.alert({
2023-06-04 02:40:39 +00:00
title: responseData.status,
message: responseData.error
2023-06-03 17:36:38 +00:00
});
}
});
});
2023-09-28 23:07:03 +00:00
function hexToDiscordInt(hexColor) {
// Remove the hash at the start if it's there
const sanitizedHex = hexColor.startsWith('#') ? hexColor.slice(1) : hexColor;
// Convert the hex to an integer
return parseInt(sanitizedHex, 16);
}
2023-06-03 17:36:38 +00:00
</script>
2023-06-03 22:10:39 +00:00
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/js/bootstrap-select.min.js"></script>
2023-06-03 17:36:38 +00:00
{% end %}