新增自定义通知模板
This commit is contained in:
103
views/notifytpl/add.html
Normal file
103
views/notifytpl/add.html
Normal file
@@ -0,0 +1,103 @@
|
||||
<div class="layui-layout layui-layout-admin" style="padding-left: 40px;margin-top: 20px;">
|
||||
|
||||
<form class="layui-form" action="" method="post">
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板名称</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="text" name="tpl_name" id="tpl_name" lay-verify="required" autocomplete="off"
|
||||
placeholder="模板名称" class="layui-input" value="">
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板类型</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="radio" name="tpl_type" lay-verify="type" value="0" title="邮箱" checked>
|
||||
<input type="radio" name="tpl_type" lay-verify="type" value="1" title="短信" >
|
||||
<input type="radio" name="tpl_type" lay-verify="type" value="2" title="钉钉" >
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板标题</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="text" name="title" id="title" autocomplete="off"
|
||||
placeholder="模板标题" class="layui-input" value="">
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板内容</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<textarea rows="10" name="content" id="content" placeholder="请输入模板内容" class="layui-textarea"></textarea>
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux" style="padding: 0px 0px !important;">
|
||||
<pre class="layui-code" style="margin: 0;">
|
||||
|
||||
任务 ID {TaskId}
|
||||
任务名称 {TaskName}
|
||||
执行时间 {CreateTime}
|
||||
执行耗时 {ProcessTime}
|
||||
执行状态 {Status}
|
||||
任务输出 {TaskOut}
|
||||
|
||||
</pre>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">状态</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="radio" name="status" lay-verify="type" value="0" title="禁用" checked>
|
||||
<input type="radio" name="status" lay-verify="type" value="1" title="启用" >
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<input type="hidden" name="id" id="id" value="0">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200"></label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<button class="layui-btn" lay-submit="" lay-filter="sub">立即提交</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
<script>
|
||||
var $;
|
||||
layui.use(['form', 'element', 'layer', 'jquery'], function () {
|
||||
var form = layui.form; //只有执行了这一步,部分表单元素才会自动修饰成功
|
||||
var $ = layui.jquery;
|
||||
|
||||
var error_info = "{{.flash.error}}";
|
||||
if (error_info) {
|
||||
layer.msg(error_info, {icon: 2, shade: 0.3}, function () {
|
||||
window.history.go(-1)
|
||||
})
|
||||
return;
|
||||
}
|
||||
|
||||
form.on('submit(sub)', function (data) {
|
||||
var form_data = $("form").serialize();
|
||||
$.post('{{urlfor "NotifyTplController.AjaxSave"}}', form_data, function (out) {
|
||||
if (out.status == 0) {
|
||||
layer.msg("操作成功", {icon: 1, shade: 0.3, time: 1000}, function () {
|
||||
// window.history.go(-1)//
|
||||
window.location.reload()
|
||||
})
|
||||
} else {
|
||||
layer.msg(out.message)
|
||||
}
|
||||
}, "json");
|
||||
return false;
|
||||
});
|
||||
|
||||
//但是,如果你的HTML是动态生成的,自动渲染就会失效
|
||||
//因此你需要在相应的地方,执行下述方法来手动渲染,跟这类似的还有 element.init();
|
||||
form.render();
|
||||
});
|
||||
</script>
|
||||
103
views/notifytpl/edit.html
Normal file
103
views/notifytpl/edit.html
Normal file
@@ -0,0 +1,103 @@
|
||||
<div class="layui-layout layui-layout-admin" style="padding-left: 40px;margin-top: 20px;">
|
||||
|
||||
<form class="layui-form" action="" method="post">
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板名称</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="text" name="tpl_name" id="tpl_name" lay-verify="required" autocomplete="off"
|
||||
placeholder="模板名称" class="layui-input" value="{{.notifyTpl.tpl_name}}">
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板类型</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="radio" name="tpl_type" lay-verify="type" value="0" title="邮箱" {{if eq .notifyTpl.tpl_type 0}}checked{{end}}>
|
||||
<input type="radio" name="tpl_type" lay-verify="type" value="1" title="短信" {{if eq .notifyTpl.tpl_type 1}}checked{{end}}>
|
||||
<input type="radio" name="tpl_type" lay-verify="type" value="2" title="钉钉" {{if eq .notifyTpl.tpl_type 2}}checked{{end}}>
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板标题</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="text" name="title" id="title" autocomplete="off"
|
||||
placeholder="模板标题" class="layui-input" value="{{.notifyTpl.title}}">
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">模板内容</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<textarea rows="10" name="content" id="content" lay-verify="required" placeholder="请输入模板内容"
|
||||
class="layui-textarea">{{.notifyTpl.content}}</textarea>
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux" style="padding: 0px 0px !important;">
|
||||
<pre class="layui-code" style="margin: 0;">
|
||||
|
||||
任务 ID {TaskId}
|
||||
任务名称 {TaskName}
|
||||
执行时间 {CreateTime}
|
||||
执行耗时 {ProcessTime}
|
||||
执行状态 {Status}
|
||||
任务输出 {TaskOut}
|
||||
|
||||
</pre>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200">状态</label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<input type="radio" name="status" lay-verify="type" value="0" title="禁用" {{if eq .notifyTpl.status 0}}checked{{end}}>
|
||||
<input type="radio" name="status" lay-verify="type" value="1" title="启用" {{if eq .notifyTpl.status 1}}checked{{end}}>
|
||||
</div>
|
||||
<div class="layui-form-mid layui-word-aux"></div>
|
||||
</div>
|
||||
|
||||
<input type="hidden" name="id" id="id" value="{{.notifyTpl.id}}">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label mw200"></label>
|
||||
<div class="layui-input-inline mw400">
|
||||
<button class="layui-btn" lay-submit="" lay-filter="sub">立即保存</button>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
<script>
|
||||
var $;
|
||||
layui.use(['form', 'element', 'layer', 'jquery'], function () {
|
||||
var form = layui.form; //只有执行了这一步,部分表单元素才会自动修饰成功
|
||||
var $ = layui.jquery;
|
||||
var error_info = "{{.flash.error}}";
|
||||
if (error_info) {
|
||||
layer.msg(error_info, {icon: 2, shade: 0.3}, function () {
|
||||
window.history.go(-1)
|
||||
})
|
||||
return;
|
||||
}
|
||||
|
||||
form.on('submit(sub)', function (data) {
|
||||
var form_data = $("form").serialize();
|
||||
$.post('{{urlfor "NotifyTplController.AjaxSave"}}', form_data, function (out) {
|
||||
if (out.status == 0) {
|
||||
layer.msg("操作成功", {icon: 1, shade: 0.3, time: 1000}, function () {
|
||||
// window.history.go(-1)
|
||||
window.location.reload()
|
||||
})
|
||||
} else {
|
||||
layer.msg(out.message)
|
||||
}
|
||||
}, "json");
|
||||
return false;
|
||||
});
|
||||
|
||||
//但是,如果你的HTML是动态生成的,自动渲染就会失效
|
||||
//因此你需要在相应的地方,执行下述方法来手动渲染,跟这类似的还有 element.init();
|
||||
form.render();
|
||||
});
|
||||
</script>
|
||||
107
views/notifytpl/list.html
Normal file
107
views/notifytpl/list.html
Normal file
@@ -0,0 +1,107 @@
|
||||
<div class="layui-layout layui-layout-admin" style="padding-left: 20px;">
|
||||
<div class="layui-row" style="margin-top: 20px;">
|
||||
<div class="layui-col-xs6">
|
||||
<button class="layui-btn" data-type="tabAdd" id="add">新增</button>
|
||||
</div>
|
||||
<div class="layui-col-xs6 search_text">
|
||||
<form class="layui-form" action="" onsubmit="javascript:return false;">
|
||||
<div class="demoTable">
|
||||
<div class="layui-inline" style="width: 40%">
|
||||
<input class="layui-input" name="tplName" id="tplName" autocomplete="off" placeholder="模板名称">
|
||||
</div>
|
||||
<button class="layui-btn" data-type="reload">查询</button>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<table class="layui-hide" id="table_list" lay-filter="table_filter">
|
||||
</table>
|
||||
|
||||
<script type="text/html" id="bar">
|
||||
<a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
|
||||
<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
|
||||
</script>
|
||||
</div>
|
||||
<script>
|
||||
|
||||
layui.use(['table', 'form', 'element'], function () {
|
||||
var table = layui.table;
|
||||
var form = layui.form;
|
||||
var element = layui.element;
|
||||
var error_info = "{{.flash.error}}";
|
||||
if (error_info) {
|
||||
layer.msg(error_info, {icon: 2, shade: 0.3}, function () {
|
||||
window.history.go(-1)
|
||||
})
|
||||
return;
|
||||
}
|
||||
//方法级渲染
|
||||
table.render({
|
||||
elem: '#table_list'
|
||||
, url: '/notifytpl/table'
|
||||
, cols: [[
|
||||
{checkbox: true, fixed: true},
|
||||
{field: 'id', title: 'ID', align: 'center', sort: true, width: 150},
|
||||
{field: 'type', title: '类型'},
|
||||
{field: 'tpl_name', title: '模板名称'},
|
||||
{field: 'tpl_type_text', title: '模板类型'},
|
||||
{field: 'create_time', title: '创建时间'},
|
||||
{field: 'update_time', title: '更新时间'},
|
||||
{field: 'status_text', title: '状态', sort: true,},
|
||||
{fixed: 'right', width: 160, align: 'center', toolbar: '#bar'}
|
||||
]]
|
||||
, id: 'listReload'
|
||||
, page: true
|
||||
, height: "full-130"
|
||||
});
|
||||
|
||||
var $ = layui.$, active = {
|
||||
reload: function () {
|
||||
table.reload('listReload', {
|
||||
where: {
|
||||
tplName: $('#tplName').val(),
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
$("#add").on("click", function () {
|
||||
window.parent.openTab("/notifytpl/add", '新增模板', "notify_tpl_add-0", 'fa-plus');
|
||||
})
|
||||
|
||||
//监听工具条
|
||||
table.on('tool(table_filter)', function (obj) {
|
||||
var data = obj.data;
|
||||
var tplName = data.tpl_name
|
||||
if (obj.event === 'edit') {
|
||||
window.parent.openTab("/notifytpl/edit?id=" + data.id, tplName + '编辑', "notify_tpl_edit-" + data.id, 'fa-edit');
|
||||
} else if (obj.event === 'del') {
|
||||
layer.confirm('真的删除【' + data.tpl_name + '】模板么', function (index) {
|
||||
var jsData = {'id': data.id}
|
||||
$.post('{{urlfor "NotifyTplController.AjaxDel"}}', jsData, function (out) {
|
||||
if (out.status == 0) {
|
||||
layer.alert(out.message, {icon: 1}, function (index) {
|
||||
layer.close(index);
|
||||
window.location.reload();
|
||||
});
|
||||
} else {
|
||||
layer.msg(out.message)
|
||||
}
|
||||
}, "json");
|
||||
// obj.del();
|
||||
layer.close(index);
|
||||
})
|
||||
} else {
|
||||
layer.msg('操作不存在');
|
||||
}
|
||||
});
|
||||
|
||||
$('.demoTable .layui-btn').on('click', function () {
|
||||
var type = $(this).data('type');
|
||||
active[type] ? active[type].call(this) : '';
|
||||
});
|
||||
});
|
||||
|
||||
</script>
|
||||
Reference in New Issue
Block a user