2021-11-30 17:29:53 +00:00
|
|
|
{% extends ../base.html %}
|
|
|
|
|
|
|
|
{% block meta %}
|
|
|
|
{% end %}
|
|
|
|
|
2021-11-30 20:46:30 +00:00
|
|
|
{% block title %}Crafty Controller - {{ translate('serverDetails', 'serverDetails', data['lang']) }}{% end %}
|
2021-11-30 17:29:53 +00:00
|
|
|
|
|
|
|
{% block content %}
|
|
|
|
|
|
|
|
<div class="content-wrapper">
|
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
<!-- Page Title Header Starts-->
|
2021-11-30 17:29:53 +00:00
|
|
|
<div class="row page-title-header">
|
|
|
|
<div class="col-12">
|
|
|
|
<div class="page-header">
|
2021-11-30 20:46:30 +00:00
|
|
|
<h4 class="page-title">
|
|
|
|
{{ translate('serverDetails', 'serverDetails', data['lang']) }} - {{ data['server_stats']['server_id']['server_name'] }}
|
2022-03-26 22:37:08 +00:00
|
|
|
<br />
|
|
|
|
<small>UUID: {{ data['server_stats']['server_id']['server_uuid'] }}</small>
|
2021-11-30 20:46:30 +00:00
|
|
|
</h4>
|
2021-11-30 17:29:53 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
<!-- Page Title Header Ends-->
|
|
|
|
|
2022-06-22 22:58:06 +00:00
|
|
|
{% include "parts/details_stats.html" %}
|
2021-11-30 20:46:30 +00:00
|
|
|
|
2021-11-30 17:29:53 +00:00
|
|
|
<div class="row">
|
|
|
|
|
|
|
|
<div class="col-sm-12 grid-margin">
|
|
|
|
<div class="card">
|
|
|
|
<div class="card-body pt-0">
|
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
<span class="d-none d-sm-block">
|
2022-06-22 22:58:06 +00:00
|
|
|
{% include "parts/server_controls_list.html" %}
|
2022-03-26 22:37:08 +00:00
|
|
|
</span>
|
|
|
|
<span class="d-block d-sm-none">
|
2022-06-22 22:58:06 +00:00
|
|
|
{% include "parts/m_server_controls_list.html" %}
|
2022-03-26 22:37:08 +00:00
|
|
|
</span>
|
|
|
|
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-12 col-sm-12" style="overflow-x:auto;">
|
|
|
|
<div class="card">
|
|
|
|
<div class="card-header header-sm d-flex justify-content-between align-items-center">
|
|
|
|
<h4 class="card-title"><i class="fas fa-calendar"></i> Scheduled Tasks</h4>
|
2022-04-03 01:25:26 +00:00
|
|
|
{% if data['user_data']['hints'] %}
|
|
|
|
<span class="too_small" title="{{ translate('serverSchedules', 'cannotSee', data['lang']) }}" ,
|
2022-05-18 20:13:44 +00:00
|
|
|
data-content="{{ translate('serverSchedules', 'cannotSeeOnMobile', data['lang']) }}" ,
|
|
|
|
data-placement="bottom"></span>
|
2022-04-03 01:25:26 +00:00
|
|
|
{% end %}
|
|
|
|
<div><button
|
2022-05-18 20:13:44 +00:00
|
|
|
onclick="location.href=`/panel/add_schedule?id={{ data['server_stats']['server_id']['server_id'] }}`"
|
|
|
|
class="btn btn-info">Create New Schedule <i class="fas fa-pencil-alt"></i></button></div>
|
2022-03-26 22:37:08 +00:00
|
|
|
</div>
|
|
|
|
<div class="card-body">
|
2022-04-03 01:25:26 +00:00
|
|
|
<table class="table table-hover d-none d-lg-block responsive-table" id="schedule_table" width="100%"
|
2022-05-18 20:13:44 +00:00
|
|
|
style="table-layout:fixed;">
|
2022-03-26 22:37:08 +00:00
|
|
|
<thead>
|
|
|
|
<tr class="rounded">
|
|
|
|
<th style="width: 2%; min-width: 10px;">ID</th>
|
|
|
|
<th style="width: 23%; min-width: 50px;">Action</th>
|
|
|
|
<th style="width: 40%; min-width: 50px;">Command</th>
|
|
|
|
<th style="width: 10%; min-width: 50px;">Interval</th>
|
|
|
|
<th style="width: 10%; min-width: 50px;">Start Time</th>
|
|
|
|
<th style="width: 10%; min-width: 50px;">Enabled</th>
|
|
|
|
<th style="width: 10%; min-width: 50px;">Edit</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{% for schedule in data['schedules'] %}
|
|
|
|
<tr>
|
|
|
|
<td id="{{schedule.schedule_id}}" class="id">
|
|
|
|
<p>{{schedule.schedule_id}}</p>
|
|
|
|
</td>
|
|
|
|
<td id="{{schedule.action}}" class="action">
|
|
|
|
<p>{{schedule.action}}</p>
|
|
|
|
</td>
|
|
|
|
<td id="{{schedule.command}}" class="action" style="overflow: scroll; max-width: 30px;">
|
|
|
|
<p>{{schedule.command}}</p>
|
|
|
|
</td>
|
|
|
|
<td id="{{schedule.interval}}" class="action">
|
|
|
|
{% if schedule.interval != '' %}
|
|
|
|
<p>Every</p>
|
|
|
|
<p>{{schedule.interval}} {{schedule.interval_type}}</p>
|
|
|
|
{% elif schedule.interval_type == 'reaction' %}
|
|
|
|
<p>{{schedule.interval_type}}<br><br>child of ID: {{ schedule.parent }}</p>
|
|
|
|
{% else %}
|
|
|
|
<p>Cron String:</p>
|
|
|
|
<p>{{schedule.cron_string}}</p>
|
|
|
|
{% end %}
|
|
|
|
</td>
|
|
|
|
<td id="{{schedule.start_time}}" class="action">
|
|
|
|
<p>{{schedule.start_time}}</p>
|
|
|
|
</td>
|
|
|
|
<td id="{{schedule.enabled}}" class="action">
|
2022-06-22 22:58:06 +00:00
|
|
|
<input type="checkbox" class="schedule-enabled-toggle" data-schedule-id="{{schedule.schedule_id}}" data-schedule-enabled="{{ 'true' if schedule.enabled else 'false' }}">
|
2022-03-26 22:37:08 +00:00
|
|
|
</td>
|
|
|
|
<td id="{{schedule.action}}" class="action">
|
|
|
|
<button onclick="window.location.href='/panel/edit_schedule?id={{ data['server_stats']['server_id']['server_id'] }}&sch_id={{schedule.schedule_id}}'" class="btn btn-info">
|
|
|
|
<i class="fas fa-pencil-alt"></i>
|
|
|
|
</button>
|
2022-01-11 05:26:33 +00:00
|
|
|
<br>
|
|
|
|
<br>
|
|
|
|
<button data-sch={{ schedule.schedule_id }} class="btn btn-danger del_button">
|
|
|
|
<i class="fas fa-trash" aria-hidden="true"></i>
|
2022-03-26 22:37:08 +00:00
|
|
|
</button>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
{% end %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
<hr />
|
|
|
|
<table class="table table-hover d-block d-lg-none" id="mini_schedule_table" width="100%" style="table-layout:fixed;">
|
|
|
|
<thead>
|
|
|
|
<tr class="rounded">
|
|
|
|
<th style="width: 25%; min-width: 50px;">Action</th>
|
|
|
|
<th style="max-width: 40%; min-width: 50px;">Command</th>
|
|
|
|
<th style="width: 10%; min-width: 50px;">Enabled</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{% for schedule in data['schedules'] %}
|
|
|
|
<tr data-toggle="modal" data-target="#task_details_{{schedule.schedule_id}}">
|
|
|
|
<td id="{{schedule.action}}" class="action">
|
|
|
|
<p>{{schedule.action}}</p>
|
|
|
|
</td>
|
|
|
|
<td id="{{schedule.command}}" class="action" style="overflow: scroll; max-width: 30px;">
|
|
|
|
<p>{{schedule.command}}</p>
|
|
|
|
</td>
|
|
|
|
<td id="{{schedule.enabled}}" class="action">
|
|
|
|
{% if schedule.enabled %}
|
|
|
|
<span class="text-success">
|
|
|
|
<i class="fas fa-check-square"></i> Yes
|
|
|
|
</span>
|
|
|
|
{% else %}
|
|
|
|
<span class="text-danger">
|
|
|
|
<i class="far fa-times-square"></i> No
|
|
|
|
</span>
|
2021-11-30 20:46:30 +00:00
|
|
|
{% end %}
|
2022-03-26 22:37:08 +00:00
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
<!-- Modal -->
|
|
|
|
<div class="modal fade" id="task_details_{{schedule.schedule_id}}" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
|
|
|
|
<div class="modal-dialog" role="document">
|
|
|
|
<div class="modal-content">
|
|
|
|
<div class="modal-header">
|
|
|
|
<h5 class="modal-title" id="exampleModalLabel">Task Details</h5>
|
|
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
|
|
|
<span aria-hidden="true">×</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
<div class="modal-body">
|
|
|
|
<ul style="list-style: none;">
|
|
|
|
<li id="{{schedule.schedule_id}}" class="id" style="border-top: .1em solid gray;">
|
|
|
|
<h4>ID</h4>
|
|
|
|
<p>{{schedule.schedule_id}}</p>
|
|
|
|
</li>
|
|
|
|
<li id="{{schedule.action}}" class="action" style="border-top: .1em solid gray;">
|
|
|
|
<h4>Action</h4>
|
|
|
|
<p>{{schedule.action}}</p>
|
|
|
|
</li>
|
|
|
|
<li id="{{schedule.command}}" class="action" style="border-top: .1em solid gray;">
|
|
|
|
<h4>Command</h4>
|
|
|
|
<p>{{schedule.command}}</p>
|
|
|
|
</li>
|
|
|
|
<li id="{{schedule.interval}}" class="action" style="border-top: .1em solid gray;">
|
|
|
|
{% if schedule.interval != '' %}
|
|
|
|
<h4>Interval</h4>
|
|
|
|
<p>Every {{schedule.interval}} {{schedule.interval_type}}</p>
|
|
|
|
{% elif schedule.interval_type == 'reaction' %}
|
|
|
|
<h4>Interval</h4>
|
|
|
|
<p>{{schedule.interval_type}}<br><br>child of ID: {{ schedule.parent }}</p>
|
|
|
|
{% else %}
|
|
|
|
<h4>Interval</h4>
|
|
|
|
<p>Cron String: {{schedule.cron_string}}</p>
|
|
|
|
{% end %}
|
|
|
|
</li>
|
|
|
|
<li id="{{schedule.start_time}}" class="action" style="border-top: .1em solid gray;">
|
|
|
|
<h4>Start Time</h4>
|
|
|
|
<p>{{schedule.start_time}}</p>
|
|
|
|
</li>
|
|
|
|
<li id="{{schedule.enabled}}" class="action" style="border-top: .1em solid gray; border-bottom: .1em solid gray">
|
2022-07-13 10:42:43 +00:00
|
|
|
<h4>Enabled</h4>
|
2022-06-22 22:58:06 +00:00
|
|
|
<input type="checkbox" class="schedule-enabled-toggle" data-schedule-id="{{schedule.schedule_id}}" data-schedule-enabled="{{ 'true' if schedule.enabled else 'false' }}">
|
2022-03-26 22:37:08 +00:00
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
<div class="modal-footer">
|
|
|
|
<button onclick="window.location.href='/panel/edit_schedule?id={{ data['server_stats']['server_id']['server_id'] }}&sch_id={{schedule.schedule_id}}'" class="btn btn-info">
|
|
|
|
<i class="fas fa-pencil-alt"></i> Edit
|
|
|
|
</button>
|
|
|
|
<button data-sch={{ schedule.schedule_id }} class="btn btn-danger del_button">
|
|
|
|
<i class="fas fa-trash" aria-hidden="true"></i> Delete
|
|
|
|
</button>
|
|
|
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
|
2022-01-12 18:48:22 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-03-26 22:37:08 +00:00
|
|
|
</div>
|
2021-11-30 17:29:53 +00:00
|
|
|
</div>
|
2022-03-26 22:37:08 +00:00
|
|
|
{% end %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2021-11-30 17:29:53 +00:00
|
|
|
</div>
|
2022-03-26 22:37:08 +00:00
|
|
|
</div>
|
2021-11-30 17:29:53 +00:00
|
|
|
</div>
|
2022-03-26 22:37:08 +00:00
|
|
|
</div>
|
2021-11-30 17:29:53 +00:00
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2022-01-12 23:52:44 +00:00
|
|
|
<style>
|
2022-03-26 22:37:08 +00:00
|
|
|
.popover-body {
|
|
|
|
color: white !important;
|
|
|
|
;
|
|
|
|
}
|
2022-01-12 23:52:44 +00:00
|
|
|
</style>
|
2021-11-30 17:29:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
2022-01-12 01:26:39 +00:00
|
|
|
<style>
|
|
|
|
/* Hide scrollbar for Chrome, Safari and Opera */
|
2022-03-26 22:37:08 +00:00
|
|
|
td::-webkit-scrollbar {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Hide scrollbar for IE, Edge and Firefox */
|
|
|
|
td {
|
|
|
|
-ms-overflow-style: none;
|
|
|
|
/* IE and Edge */
|
|
|
|
scrollbar-width: none;
|
|
|
|
/* Firefox */
|
|
|
|
}
|
2022-01-12 01:26:39 +00:00
|
|
|
</style>
|
2021-11-30 17:29:53 +00:00
|
|
|
<!-- content-wrapper ends -->
|
|
|
|
|
|
|
|
{% end %}
|
|
|
|
|
|
|
|
{% block js %}
|
|
|
|
<script>
|
2022-02-27 17:26:54 +00:00
|
|
|
|
2022-06-22 22:58:06 +00:00
|
|
|
function debounce(func, timeout = 300){
|
|
|
|
let timer;
|
|
|
|
return (...args) => {
|
|
|
|
clearTimeout(timer);
|
|
|
|
timer = setTimeout(() => { func.apply(this, args); }, timeout);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
$(() => {
|
|
|
|
$('.schedule-enabled-toggle').bootstrapToggle({
|
|
|
|
on: 'Yes',
|
|
|
|
off: 'No',
|
|
|
|
onstyle: 'success',
|
|
|
|
offstyle: 'danger',
|
|
|
|
})
|
|
|
|
$('.schedule-enabled-toggle').each(function() {
|
|
|
|
const enabled = JSON.parse(this.getAttribute('data-schedule-enabled'));
|
|
|
|
$(this).bootstrapToggle(enabled ? 'on' : 'off')
|
|
|
|
})
|
|
|
|
$('.schedule-enabled-toggle').change(function() {
|
|
|
|
const id = this.getAttribute('data-schedule-id');
|
|
|
|
const enabled = this.checked;
|
|
|
|
|
|
|
|
fetch(`/api/v2/servers/{{data['server_id']}}/tasks/${id}`, {
|
|
|
|
method: 'PATCH',
|
|
|
|
body: JSON.stringify({enabled}),
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
})
|
|
|
|
});
|
|
|
|
})
|
|
|
|
|
2022-02-27 17:26:54 +00:00
|
|
|
const serverId = new URLSearchParams(document.location.search).get('id')
|
2022-03-26 22:37:08 +00:00
|
|
|
|
|
|
|
$(document).ready(function () {
|
2022-01-13 04:58:16 +00:00
|
|
|
console.log('ready for JS!')
|
|
|
|
$('#schedule_table').DataTable({
|
|
|
|
'order': [4, 'desc']
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
});
|
|
|
|
$(document).ready(function () {
|
|
|
|
console.log('ready for JS!')
|
|
|
|
$('#mini_schedule_table').DataTable({
|
|
|
|
'order': [2, 'desc']
|
|
|
|
}
|
|
|
|
);
|
|
|
|
document.getElementById('mini_schedule_table_wrapper').hidden = true;
|
|
|
|
});
|
|
|
|
$(document).ready(function () {
|
2022-01-12 23:52:44 +00:00
|
|
|
$('[data-toggle="popover"]').popover();
|
2022-03-26 22:37:08 +00:00
|
|
|
if ($(window).width() < 1000) {
|
2022-01-12 23:52:44 +00:00
|
|
|
$('.too_small').popover("show");
|
2022-01-13 05:30:35 +00:00
|
|
|
document.getElementById('schedule_table_wrapper').hidden = true;
|
2022-01-14 07:35:26 +00:00
|
|
|
document.getElementById('mini_schedule_table_wrapper').hidden = false;
|
2022-01-12 23:52:44 +00:00
|
|
|
}
|
2022-01-21 22:50:04 +00:00
|
|
|
|
2022-01-12 23:52:44 +00:00
|
|
|
});
|
2022-03-26 22:37:08 +00:00
|
|
|
$(window).ready(function () {
|
|
|
|
$('body').click(function () {
|
|
|
|
$('.too_small').popover("hide");
|
|
|
|
});
|
2022-01-12 23:52:44 +00:00
|
|
|
});
|
2022-03-26 22:37:08 +00:00
|
|
|
$(window).resize(function () {
|
2022-01-12 23:52:44 +00:00
|
|
|
// This will execute whenever the window is resized
|
2022-03-26 22:37:08 +00:00
|
|
|
if ($(window).width() < 1000) {
|
2022-01-12 23:52:44 +00:00
|
|
|
$('.too_small').popover("show");
|
2022-01-13 05:30:35 +00:00
|
|
|
document.getElementById('schedule_table_wrapper').hidden = true;
|
2022-01-14 07:35:26 +00:00
|
|
|
document.getElementById('mini_schedule_table_wrapper').hidden = false;
|
2022-01-12 23:52:44 +00:00
|
|
|
}
|
2022-03-26 22:37:08 +00:00
|
|
|
else {
|
2022-01-12 23:52:44 +00:00
|
|
|
$('.too_small').popover("hide");
|
2022-01-13 05:30:35 +00:00
|
|
|
document.getElementById('schedule_table_wrapper').hidden = false;
|
2022-01-14 07:35:26 +00:00
|
|
|
document.getElementById('mini_schedule_table_wrapper').hidden = true;
|
2022-01-12 23:52:44 +00:00
|
|
|
} // New width
|
|
|
|
});
|
2022-03-26 22:37:08 +00:00
|
|
|
</script>
|
2022-01-12 23:52:44 +00:00
|
|
|
<script>
|
2021-11-30 17:29:53 +00:00
|
|
|
|
|
|
|
|
2022-03-26 22:37:08 +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;
|
|
|
|
}
|
2021-11-30 17:29:53 +00:00
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
$(document).ready(function () {
|
|
|
|
console.log("ready!");
|
2021-11-30 17:29:53 +00:00
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
});
|
2021-11-30 17:29:53 +00:00
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
function yesnoCheck(that) {
|
|
|
|
if (that.value == "command") {
|
|
|
|
document.getElementById("ifYes").style.display = "block";
|
|
|
|
document.getElementById("command").required = true;
|
|
|
|
} else {
|
|
|
|
document.getElementById("ifYes").style.display = "none";
|
|
|
|
document.getElementById("command").required = false;
|
|
|
|
}
|
2021-11-30 20:46:30 +00:00
|
|
|
}
|
2022-01-08 23:03:45 +00:00
|
|
|
function basicAdvanced(that) {
|
|
|
|
if (that.value == "advanced") {
|
2022-03-26 22:37:08 +00:00
|
|
|
document.getElementById("ifAdvanced").style.display = "block";
|
|
|
|
document.getElementById("ifBasic").style.display = "none";
|
|
|
|
document.getElementById("interval").required = false;
|
|
|
|
document.getElementById("time").required = false;
|
2022-01-08 23:03:45 +00:00
|
|
|
} else {
|
2022-03-26 22:37:08 +00:00
|
|
|
document.getElementById("ifAdvanced").style.display = "none";
|
|
|
|
document.getElementById("ifBasic").style.display = "block";
|
|
|
|
document.getElementById("interval").required = true;
|
|
|
|
document.getElementById("time").required = true;
|
2022-01-08 23:03:45 +00:00
|
|
|
}
|
2022-03-26 22:37:08 +00:00
|
|
|
}
|
|
|
|
function ifDays(that) {
|
|
|
|
if (that.value == "days") {
|
2022-01-11 17:17:57 +00:00
|
|
|
document.getElementById("ifDays").style.display = "block";
|
|
|
|
document.getElementById("time").required = true;
|
2022-03-26 22:37:08 +00:00
|
|
|
} else {
|
2022-01-11 17:17:57 +00:00
|
|
|
document.getElementById("ifDays").style.display = "none";
|
|
|
|
document.getElementById("time").required = false;
|
2022-03-26 22:37:08 +00:00
|
|
|
}
|
2022-01-11 17:17:57 +00:00
|
|
|
}
|
2021-11-30 17:29:53 +00:00
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
$(".del_button").click(function () {
|
|
|
|
var sch_id = $(this).data('sch');
|
2022-01-11 05:26:33 +00:00
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
console.log(sch_id)
|
2022-01-11 05:26:33 +00:00
|
|
|
|
2022-03-26 22:37:08 +00:00
|
|
|
bootbox.confirm({
|
2022-01-11 23:51:07 +00:00
|
|
|
title: "{{ translate('serverSchedules', 'areYouSure', data['lang']) }}",
|
|
|
|
message: "{{ translate('serverSchedules', 'confirmDelete', data['lang']) }}",
|
2022-01-11 05:26:33 +00:00
|
|
|
buttons: {
|
2022-03-26 22:37:08 +00:00
|
|
|
cancel: {
|
|
|
|
label: '<i class="fas fa-times"></i> {{ translate("serverSchedules", "cancel", data['lang']) }}'
|
2022-01-11 05:26:33 +00:00
|
|
|
},
|
2022-03-26 22:37:08 +00:00
|
|
|
confirm: {
|
|
|
|
className: 'btn-outline-danger',
|
|
|
|
label: '<i class="fas fa-check"></i> {{ translate("serverSchedules", "confirm", data['lang']) }}'
|
2022-01-11 05:26:33 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
callback: function (result) {
|
2022-03-26 22:37:08 +00:00
|
|
|
console.log(result);
|
|
|
|
if (result == true) {
|
|
|
|
del_task(sch_id, serverId);
|
|
|
|
}
|
2022-01-11 05:26:33 +00:00
|
|
|
}
|
2022-03-26 22:37:08 +00:00
|
|
|
});
|
2022-01-11 05:26:33 +00:00
|
|
|
});
|
2022-03-26 22:37:08 +00:00
|
|
|
|
|
|
|
function del_task(sch_id, id) {
|
|
|
|
var token = getCookie("_xsrf")
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
type: "DELETE",
|
|
|
|
headers: { 'X-XSRFToken': token },
|
|
|
|
url: '/ajax/del_task?server_id=' + id + '&schedule_id=' + sch_id,
|
|
|
|
data: {
|
|
|
|
schedule_id: sch_id,
|
|
|
|
id: id
|
|
|
|
},
|
|
|
|
success: function (data) {
|
|
|
|
location.reload();
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
2022-01-11 05:26:33 +00:00
|
|
|
|
2021-11-30 17:29:53 +00:00
|
|
|
</script>
|
|
|
|
|
2022-06-22 22:58:06 +00:00
|
|
|
{% end %}
|