gocron/templates/task/task_form.html

431 lines
16 KiB
Go
Raw Normal View History

2017-04-07 01:13:36 +00:00
{{{ template "common/header" . }}}
<div class="ui grid">
{{{template "task/menu" .}}}
<div class="twelve wide column">
2017-04-07 09:26:46 +00:00
<div class="pageHeader">
<div class="segment">
<h3 class="ui dividing header">
<div class="content">
2017-04-17 10:04:30 +00:00
{{{.Title}}}
2017-04-07 09:26:46 +00:00
</div>
</h3>
</div>
</div>
2017-04-07 01:13:36 +00:00
<form class="ui form fluid vertical segment">
2017-04-17 10:04:30 +00:00
<input type="hidden" name="id" value="{{{.Task.Id}}}">
2017-04-07 01:13:36 +00:00
<div class="two fields">
<div class="field">
2017-04-24 05:57:39 +00:00
<label>
<div class="content"></div>
</label>
2017-04-23 06:11:53 +00:00
<div class="ui small input">
<input type="text" name="name" placeholder="订单量统计" value="{{{.Task.Name}}}">
2017-04-07 01:13:36 +00:00
</div>
</div>
</div>
<div class="two fields">
<div class="field">
2017-04-24 05:57:39 +00:00
<label>
2017-06-08 10:04:55 +00:00
<div class="content"></div>
<div class="ui message">
, <br>
2017-04-24 05:57:39 +00:00
</div>
</label>
2017-06-08 10:04:55 +00:00
<select name="level" id="level" {{{if .Task}}}disabled="disabled"{{{end}}}>
<option value="1" {{{if .Task}}} {{{if eq .Task.Level 1}}}selected{{{end}}} {{{end}}}></option>
<option value="2" {{{if .Task}}} {{{if eq .Task.Level 2}}}selected{{{end}}} {{{end}}}></option>
</select>
</div>
</div>
<div id="parent-task">
<div class="two fields">
<div class="field">
<label>
<div class="content"></div>
<div class="ui message">
: <br>
:
</div>
</label>
<select name="dependency_status" id="dependency_status">
<option value="1" {{{if .Task}}} {{{if eq .Task.DependencyStatus 1}}}selected{{{end}}} {{{end}}}></option>
<option value="2" {{{if .Task}}} {{{if eq .Task.DependencyStatus 2}}}selected{{{end}}} {{{end}}}></option>
</select>
</div>
<div class="field">
<label>
<div class="content">ID</div>
<div class="ui message">
ID <br>
</div>
</label>
<div class="ui small input">
<input type="text" name="dependency_task_id" placeholder="可选" value="{{{.Task.DependencyTaskId}}}">
</div>
</div>
</div>
<div class="two fields">
<div class="field">
<label>
<div class="content">
crontab
</div>
</label>
<div class="ui small input">
<input type="text" name="spec" value="{{{.Task.Spec}}}" placeholder="秒 分 时 天 月 周"/>
</div>
</div>
2017-04-07 01:13:36 +00:00
</div>
</div>
2017-04-24 05:57:39 +00:00
<div class="three fields">
2017-04-07 01:13:36 +00:00
<div class="field">
2017-05-04 02:47:14 +00:00
<label></label>
<select name="protocol" id="protocol">
<option value="2" {{{if .Task}}} {{{if eq .Task.Protocol 2}}}selected{{{end}}} {{{end}}}
data-validate-type="selectProtocol">SHELL</option>
<option value="1" {{{if .Task}}} {{{if eq .Task.Protocol 1}}}selected{{{end}}} {{{end}}}>HTTP</option>
</select>
2017-04-07 01:13:36 +00:00
</div>
2017-04-24 05:57:39 +00:00
</div>
<div class="fields" id="hostField">
2017-04-23 06:11:53 +00:00
<div class="field">
<label></label>
<div id="hostId">
2017-04-23 06:11:53 +00:00
{{{range $i, $v := .Hosts}}}
<label>
<input type="checkbox" value="{{{.Id}}}" {{{if $.Task}}}{{{if $v.Selected}}} checked {{{end}}}{{{end}}} style="width:25px;height: 25px;">{{{.Alias}}}-{{{.Name}}}
{{{if (HostFormat $i) }}}<br>{{{end}}}
</label>
{{{end}}}
</div> &nbsp; <br> <a class="ui blue button" href="/host/create" target="_blank"></a>
2017-04-28 03:54:46 +00:00
</div>
2017-04-23 06:11:53 +00:00
</div>
2017-04-21 05:36:45 +00:00
<div class="two fields">
<div class="field">
2017-04-24 05:57:39 +00:00
<label></label>
<textarea rows="5" name="command" placeholder="请输入系统命令" id="command">{{{.Task.Command}}}</textarea>
2017-04-21 05:36:45 +00:00
</div>
2017-04-07 01:13:36 +00:00
</div>
<div class="three fields">
2017-04-07 01:13:36 +00:00
<div class="field">
2017-06-08 10:04:55 +00:00
<label>(, 0-86400)</label>
<input type="text" name="timeout" placeholder="默认0, 不限制" value="{{{if .Task}}} {{{.Task.Timeout}}} {{{else}}}0{{{end}}}">
2017-04-07 01:13:36 +00:00
</div>
<div class="field">
2017-06-08 10:04:55 +00:00
<label> (0-10)</label>
<input type="text" name="retry_times" placeholder="默认0, 不重试" value="{{{if .Task}}} {{{.Task.RetryTimes}}} {{{else}}}0{{{end}}}">
</div>
<div class="field">
<label></label>
<select name="multi">
<option value="2" {{{if .Task}}} {{{if eq .Task.Multi 0}}}selected{{{end}}} {{{end}}}></option>
<option value="1"{{{if .Task}}} {{{if eq .Task.Multi 1}}}selected{{{end}}} {{{end}}}></option>
</select>
</div>
</div>
2017-04-30 17:12:07 +00:00
<div class="three fields">
<div class="field">
<label></label>
<select name="notify_status" id="task-status">
<option value="1"{{{if .Task}}} {{{if eq .Task.NotifyStatus 0}}}selected{{{end}}} {{{end}}}></option>
<option value="2" {{{if .Task}}} {{{if eq .Task.NotifyStatus 1}}}selected{{{end}}} {{{end}}}></option>
<option value="3" {{{if .Task}}} {{{if eq .Task.NotifyStatus 2}}}selected{{{end}}} {{{end}}}></option>
</select>
</div>
</div>
<div class="two fields" style="display: none" id="task-notify-type">
<div class="field" >
<label></label>
<select name="notify_type">
<option value="1"{{{if .Task}}} {{{if eq .Task.NotifyType 0}}}selected{{{end}}} {{{end}}}></option>
<option value="2" {{{if .Task}}} {{{if eq .Task.NotifyType 1}}}selected{{{end}}} {{{end}}}></option>
<option value="3" {{{if .Task}}} {{{if eq .Task.NotifyType 2}}}selected{{{end}}} {{{end}}}>Slack</option>
</select>
</div>
</div>
<div class="inline fields" style="display: none" id="receiver-id"></div>
2017-04-21 05:36:45 +00:00
<div class="two fields">
2017-04-07 01:13:36 +00:00
<div class="field">
<label></label>
2017-06-08 10:04:55 +00:00
<textarea rows="5" name="remark" placeholder="统计昨天的订单量">{{{.Task.Remark}}}</textarea>
2017-04-07 01:13:36 +00:00
</div>
</div>
<div class="ui primary submit button"></div> <a class="ui button" onclick="location.href='/task';"></a>
2017-04-07 01:13:36 +00:00
</form>
</div>
</div>
2017-04-30 17:12:07 +00:00
<script type="x-handlerbar-template" id="mail-template">
{{#each MailUsers}}
<div class="field">
<div class="ui checkbox">
<input type="checkbox" name="receiver[]" {{#if checked}}checked{{/if}} value="{{Id}}" />
<label>{{Username}}-{{Email}}</label>
</div>
</div>
{{else}}
<a class="ui blue button" href="/manage/mail/edit" target="_blank"></a><br><br>
2017-04-30 17:12:07 +00:00
{{/each}}
</script>
<script type="x-handlervar-template" id="slack-template">
{{#each Channels}}
<div class="field">
<div class="ui checkbox">
<input type="checkbox" name="receiver[]" {{#if checked}}checked{{/if}} value="{{Id}}" />
<label>{{Name}}</label>
</div>
</div>
{{else}}
<a class="ui blue button" href="/manage/slack/edit" target="_blank">Slack</a>
2017-04-30 17:12:07 +00:00
{{/each}}
</script>
2017-04-07 01:13:36 +00:00
<script type="text/javascript">
$(function() {
changeCommandPlaceholder();
2017-06-08 10:04:55 +00:00
changeLevel();
changeProtocol();
2017-04-30 17:12:07 +00:00
showNotify();
});
$('#protocol').change(function() {
changeCommandPlaceholder();
changeProtocol();
});
2017-06-08 10:04:55 +00:00
$('#level').change(function() {
changeLevel();
});
2017-04-30 17:12:07 +00:00
$('#task-status').change(function() {
var selected = $(this).val();
if (selected == 1) {
$('#task-notify-type').hide();
$('#receiver-id').hide();
$('#task-notify-type').find('select').val('1');
return;
}
$('#task-notify-type').show();
});
$('#task-notify-type').change(function() {
changeNotify();
});
function changeCommandPlaceholder() {
var selectedId = $('#protocol').val();
switch (selectedId) {
case '1':
$('#command').attr('placeholder', 'URL');
break;
case '2':
$('#command').attr('placeholder', 'shell');
break;
}
}
2017-04-30 17:12:07 +00:00
function showNotify() {
var notifyStatus = {{{.Task.NotifyStatus}}};
if (notifyStatus > 0) {
$('#task-notify-type').show();
}
var notifyReceiverIds = '{{{.Task.NotifyReceiverId}}}'.split(',');
changeNotify(notifyReceiverIds);
}
function changeNotify(notifyReceiverIds) {
var selectedId = $('#task-notify-type').find('select').val();
if (selectedId == 1) {
$('#receiver-id').hide();
$('#receiver-id').html('');
return;
}
if (selectedId == 2) {
showMail(notifyReceiverIds);
} else if (selectedId == 3) {
showSlack(notifyReceiverIds);
}
$('#receiver-id').show();
}
function showMail(notifyReceiverIds) {
2017-04-30 23:12:39 +00:00
util.get("/manage/mail", function(code, message, data) {
2017-04-30 17:12:07 +00:00
renderReceiver(notifyReceiverIds, $('#mail-template'), data, 'MailUsers');
})
}
function showSlack(notifyReceiverIds) {
2017-04-30 23:12:39 +00:00
util.get("/manage/slack", function(code, message, data) {
2017-04-30 17:12:07 +00:00
renderReceiver(notifyReceiverIds, $('#slack-template'), data, 'Channels');
})
}
function renderReceiver(notifyReceiverIds, $element, data, key) {
if (notifyReceiverIds !== undefined && notifyReceiverIds) {
console.log(data[key]);
for (i in data[key]) {
if ($.inArray(data[key][i].Id + '', notifyReceiverIds) != -1) {
data[key][i].checked = true;
}
}
}
var html = util.renderTemplate($($element), data);
$('#receiver-id').html(html);
$('.ui.checkbox').checkbox();
}
function changeProtocol() {
var protocol = $('#protocol').val();
if (protocol == 2) {
$('#hostField').show();
return;
}
$('#hostField').hide();
}
2017-04-07 09:26:46 +00:00
$('.ui.checkbox')
.checkbox()
;
2017-04-30 17:12:07 +00:00
function validateNotify() {
var selectedId = $('#task-status').val();
if (selectedId == 1) {
return true;
}
var checkedLength = $('#receiver-id input:checked').length;
if (checkedLength == 0) {
return false;
}
return true;
}
function parseNotifyReceiver() {
var receivers = [];
$('#receiver-id input:checked').each(function() {
receivers.push($(this).val());
});
return receivers.join(",");
}
function parseHostId() {
var hostIds = [];
$('#hostId input:checked').each(function () {
hostIds.push($(this).val());
});
return hostIds.join(",");
}
2017-06-08 10:04:55 +00:00
function changeLevel() {
var selected = $('#level').val();
if (selected == 1) {
// 主任务
$('#parent-task').show();
$('#child-task').hide();
} else {
// 子任务
$('#parent-task').hide();
$('#child-task').show();
}
}
var $uiForm = $('.ui.form');
registerSelectFormValidation("selectProtocol", $uiForm, $('#protocol'), 'protocol');
$($uiForm).form(
2017-04-07 09:26:46 +00:00
{
onSuccess: function(event, fields) {
2017-04-30 17:12:07 +00:00
if (!validateNotify()) {
swal('', '', 'error');
return false;
}
fields.notify_receiver_id = parseNotifyReceiver();
fields.host_id = parseHostId();
if (fields.protocol == 2 && fields.host_id == "") {
swal('', '');
return false;
}
2017-04-07 09:26:46 +00:00
util.post('/task/store', fields, function(code, message) {
location.href = "/task"
2017-04-07 09:26:46 +00:00
});
2017-04-07 01:13:36 +00:00
2017-04-07 09:26:46 +00:00
return false;
},
fields: {
name: {
identifier : 'name',
rules: [
{
type : 'empty',
prompt : ''
2017-05-05 08:31:24 +00:00
},
{
type : 'maxLength[32]',
prompt : '32'
2017-04-07 09:26:46 +00:00
}
]
},
command: {
identifier : 'command',
rules: [
{
type : 'empty',
prompt : ''
2017-05-05 08:31:24 +00:00
},
{
type : 'maxLength[256]',
prompt : '256'
2017-04-07 09:26:46 +00:00
}
]
},
hosts: {
identifier : 'host_id',
2017-04-07 09:26:46 +00:00
rules: [
{
type : 'selectProtocol',
2017-04-07 09:26:46 +00:00
prompt : ''
}
]
2017-05-05 08:31:24 +00:00
},
2017-05-26 13:59:01 +00:00
timeout: {
identifier : 'timeout',
rules: [
{
type : 'integer[0..86400]',
prompt : '0-86400'
}
]
},
retryTimes: {
identifier : 'retry_times',
rules: [
{
type : 'integer[0..10]',
prompt : '0-10'
}
]
},
2017-05-05 08:31:24 +00:00
remark: {
identifier : 'remark',
rules: [
{
type : 'maxLength[100]',
prompt : '100'
}
]
2017-04-07 09:26:46 +00:00
}
},
inline : true
});
2017-04-07 01:13:36 +00:00
</script>
{{{ template "common/footer" . }}}