Merge branch 'main' of http://10.10.14.176:3000/huanghai/QingLong
commit
ddc4959c57
@ -0,0 +1,416 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title></title>
|
||||
<link rel="stylesheet" href="../../../component/pear/css/pear.css" />
|
||||
<style>
|
||||
.require-star {
|
||||
position: absolute;
|
||||
width: 3px;
|
||||
height: 14px;
|
||||
background-color: #ea4335;
|
||||
top: 12px;
|
||||
right: 8px;
|
||||
border-radius: 1.5px;
|
||||
}
|
||||
|
||||
.input-width {
|
||||
max-width: 470px
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<form class="layui-form" action="">
|
||||
<div class="mainBox">
|
||||
<div class="main-container" style="margin-top: 20px;margin-bottom: 0;">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label" style="width: 100px !important;"></span>填报要求:</label>
|
||||
<div class="layui-input-block" style="margin-left: 90px !important;">
|
||||
<textarea name="memo" placeholder="请输入本级填报要求" class="layui-textarea input-width"></textarea>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label" style="width: 100px !important;"><span
|
||||
class="require-star"></span>截止日期:</label>
|
||||
<div class="layui-input-block" style="margin-left: 90px !important;">
|
||||
<input type="text" class="layui-input input-width" lay-verify="required" name="deadline_time"
|
||||
id="endDate" placeholder="请选择本级截止日期">
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item" style="margin-bottom: 0 !important;">
|
||||
<label class="layui-form-label" style="width: 100px !important;"><span
|
||||
class="require-star"></span>选择范围:</label>
|
||||
<div class="layui-input-block" style="margin-left: 134px !important;">
|
||||
<div class="layui-tab layui-tab-brief">
|
||||
<ul class="layui-tab-title" style="border-bottom-style:none">
|
||||
<li class="layui-this">按单位类型</li>
|
||||
<li>按指定单位</li>
|
||||
<li>按指定分组</li>
|
||||
</ul>
|
||||
<div class="layui-tab-content">
|
||||
|
||||
<div class="layui-tab-item layui-show">
|
||||
<input type="checkbox" id="zsxx" lay-skin="tag" title="下属学校">
|
||||
<input type="checkbox" id="szjf" lay-skin="tag" title="下属教辅单位">
|
||||
</div>
|
||||
|
||||
<div class="layui-tab-item">
|
||||
<div style="display: flex;align-items:flex-end">
|
||||
<div class="layui-input-inline" style="width: auto;">
|
||||
<div class="layui-btn-container tag" lay-filter="orgs" lay-allowclose="true"
|
||||
style="border-style:dashed;border-width:1px;border-color: #CCCCCC;height: 100px;width: 545px;padding: 10px;overflow: auto;">
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-input-inline" style="width: auto;">
|
||||
<button type="button" class="layui-btn layui-btn-primary layui-btn-xs"
|
||||
lay-on="saveGroup">保存到分组</button>
|
||||
</div>
|
||||
</div>
|
||||
<div id="tableDiv" style="width: 650px;">
|
||||
<div class="layui-table-tool" style="min-height: 38px !important">
|
||||
<div class="layui-input-inline"
|
||||
style="margin-left: -16px;width: 150px !important;">
|
||||
<select id="orgTypeId" lay-filter="orgTypeId">
|
||||
<option value="2,3">全部</option>
|
||||
<option value="2">学校</option>
|
||||
<option value="3">教辅单位</option>
|
||||
</select>
|
||||
</div>
|
||||
<div class="layui-input-group" style="margin-left: -16px;">
|
||||
<input type="text" id="org_name" placeholder="请输入单位名称"
|
||||
class="layui-input" lay-affix="clear" lay-filter="clear">
|
||||
<div class="layui-input-split layui-input-suffix"
|
||||
style="cursor: pointer;" lay-on="confirm">
|
||||
<i class="layui-icon layui-icon-search"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<table id="data-table"></table>
|
||||
|
||||
<script type="text/html" id="select-enable">
|
||||
<input type="checkbox" id="{{d.org_id}}" lay-skin="switch" lay-text="已选|未选" lay-filter="switchEnable"
|
||||
{{ d.sw == true ? "checked" : "" }}>
|
||||
</script>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-tab-item">
|
||||
<div id="tableDiv" style="width: 650px;">
|
||||
<table id="group-table"></table>
|
||||
<script type="text/html" id="group-bar">
|
||||
<button type="button" class="pear-btn pear-btn-danger pear-btn-xs" lay-event="delGroup">
|
||||
<i class="layui-icon layui-icon-delete"></i> 删除
|
||||
</button>
|
||||
</script>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="bottom">
|
||||
<div class="button-container" style="left: 15px !important">
|
||||
<button type="submit" class="pear-btn pear-btn-primary pear-btn-sm" lay-submit="" lay-filter="publish">
|
||||
<i class="layui-icon layui-icon-release"></i>
|
||||
转发
|
||||
</button>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
<script src="../../../component/layui/layui.js"></script>
|
||||
<script src="../../../component/pear/pear.js"></script>
|
||||
<script>
|
||||
layui.use(['tag'], function () {
|
||||
var form = layui.form;
|
||||
var $ = layui.jquery;
|
||||
var laydate = layui.laydate;
|
||||
var tab = layui.tab;
|
||||
var util = layui.util;
|
||||
var tag = layui.tag;
|
||||
var table = layui.table;
|
||||
|
||||
var bureauIds = [];
|
||||
var publishData = {};
|
||||
|
||||
var jobId = GetQueryString("job_id");
|
||||
|
||||
laydate.render({
|
||||
elem: '#endDate',
|
||||
min: 0
|
||||
});
|
||||
|
||||
renderBureauTable();
|
||||
|
||||
function renderBureauTable() {
|
||||
table.render({
|
||||
elem: '#data-table',
|
||||
id: 'myTable',
|
||||
url: '/QingLong/collect/getBureauList',
|
||||
where: {
|
||||
bureau_type_ids: $("#orgTypeId").val(),
|
||||
query_type_id: 2,
|
||||
org_name: $("#org_name").val()
|
||||
},
|
||||
// height: '374',
|
||||
page: {
|
||||
limit: 5
|
||||
, layout: ['count', 'prev', 'page', 'next', 'skip']
|
||||
, prev: "上一页"
|
||||
, next: "下一页"
|
||||
},
|
||||
cols: [[
|
||||
{ title: '序号', align: 'center', width: "5%", type: 'numbers' },
|
||||
{ title: '单位名称', field: 'org_name', align: 'center' },
|
||||
{ title: '单位类型', field: 'org_type_name', align: 'center', width: "20%" },
|
||||
{ title: '操作', align: 'center', width: "25%", templet: '#select-enable' }
|
||||
]],
|
||||
skin: 'line',
|
||||
// toolbar: '#table-toolbar',
|
||||
defaultToolbar: [],
|
||||
parseData: function (res) {
|
||||
var data = res.data;
|
||||
for (var i = 0; i < data.length; i++) {
|
||||
switch (data[i].org_type_id) {
|
||||
case 14:
|
||||
res.data[i].org_type_name = '教辅单位';
|
||||
break;
|
||||
case 16:
|
||||
res.data[i].org_type_name = '学校';
|
||||
break;
|
||||
default:
|
||||
res.data[i].org_type_name = '--';
|
||||
break;
|
||||
}
|
||||
|
||||
res.data[i].sw = false
|
||||
if (bureauIds.includes(data[i].org_id)) {
|
||||
res.data[i].sw = true
|
||||
}
|
||||
}
|
||||
return res;
|
||||
},
|
||||
done: function (res, curr, count) {
|
||||
var options = this;
|
||||
|
||||
// 获取当前行数据
|
||||
table.getRowData = function (tableId, elem) {
|
||||
var index = $(elem).closest('tr').data('index');
|
||||
return table.cache[tableId][index] || {};
|
||||
};
|
||||
|
||||
form.on('switch(switchEnable)', function (obj) {
|
||||
var data = table.getRowData(options.id, this);
|
||||
if (obj.elem.checked) {
|
||||
tag.add('orgs', { text: data.org_name, id: data.org_id });
|
||||
bureauIds.push(data.org_id);
|
||||
}
|
||||
else {
|
||||
tag.delete('orgs', data.org_id);
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
table.render({
|
||||
elem: '#group-table',
|
||||
id: 'groupTable',
|
||||
url: '/QingLong/collect/listGroup',
|
||||
height: 'full-180',
|
||||
cols: [[
|
||||
{ type: 'checkbox', width: "5%" },
|
||||
{ title: '序号', align: 'center', width: "5%", type: 'numbers' },
|
||||
{ title: '分名称', field: 'group_name', align: 'center' },
|
||||
{ title: '操作', toolbar: '#group-bar', align: 'center', width: "25%" }
|
||||
]],
|
||||
skin: 'line',
|
||||
defaultToolbar: []
|
||||
});
|
||||
|
||||
tag.on('delete(orgs)', function (data) {
|
||||
var orgId = data.elem.prevObject.prevObject[0].getAttribute("lay-id");
|
||||
bureauIds = bureauIds.filter(item => item !== orgId);
|
||||
var switchElem = $('#' + orgId);
|
||||
switchElem.prop('checked', false);
|
||||
form.render();
|
||||
});
|
||||
|
||||
util.on({
|
||||
confirm: function () {
|
||||
tableReload();
|
||||
},
|
||||
saveGroup: function () {
|
||||
if (Array.isArray(bureauIds) && bureauIds.length === 0) {
|
||||
layer.msg("请先选择单位!", {
|
||||
icon: 2,
|
||||
time: 1500
|
||||
});
|
||||
} else {
|
||||
layer.open({
|
||||
type: 2,
|
||||
title: '保存分组',
|
||||
shadeClose: true,
|
||||
shade: 0,
|
||||
area: ['600px', '200px'],
|
||||
content: '../org/save_group.html?bureau_ids=' + bureauIds.join(",")
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
form.on('select(orgTypeId)', function (data) {
|
||||
tableReload();
|
||||
});
|
||||
|
||||
form.on('input-affix(clear)', function (data) {
|
||||
tableReload();
|
||||
});
|
||||
|
||||
table.on('tool(groupTable)', function (obj) {
|
||||
if (obj.event === 'delGroup') {
|
||||
layer.confirm('确定要删除吗?', {
|
||||
icon: 3,
|
||||
title: '提示'
|
||||
}, function (index) {
|
||||
$.ajax({
|
||||
url: '/QingLong/collect/delGroup',
|
||||
type: 'post',
|
||||
data: { group_id: obj.data.group_id },
|
||||
success: function (result) {
|
||||
if (result.success) {
|
||||
layer.msg("删除成功!", {
|
||||
icon: 1,
|
||||
time: 1000
|
||||
}, function () {
|
||||
groupTableReload()
|
||||
});
|
||||
} else {
|
||||
layer.msg(result.message, {
|
||||
icon: 2,
|
||||
time: 2000
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
function tableReload() {
|
||||
renderBureauTable();
|
||||
// table.reloadData('myTable', {
|
||||
// where: {
|
||||
// query_type_id: 2,
|
||||
// exclude_self: 1,
|
||||
// org_type_id: $("#orgTypeId").val(),
|
||||
// org_name: $("#org_name").val()
|
||||
// },
|
||||
// scrollPos: false
|
||||
// });
|
||||
}
|
||||
|
||||
function groupTableReload() {
|
||||
table.reloadData('groupTable', {
|
||||
scrollPos: false
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
|
||||
form.on('submit(publish)', function (data) {
|
||||
|
||||
var checkStatus = table.checkStatus('groupTable');
|
||||
var groupIds = checkStatus.data.map(function (item) {
|
||||
return item.group_id;
|
||||
});
|
||||
|
||||
var xiaShuSchool = 0;
|
||||
var xiaShuJiaoFu = 0;
|
||||
var xiaShuJiaoYuJu = 0;
|
||||
|
||||
$('input[type="checkbox"]').each(function () {
|
||||
var isChecked = $(this).prop('checked');
|
||||
var checkboxText = $(this).attr('id');
|
||||
if (isChecked) {
|
||||
if (checkboxText == 'zsxx') {
|
||||
xiaShuSchool = 1;
|
||||
} else if (checkboxText == 'szjf') {
|
||||
xiaShuJiaoFu = 1;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
if (xiaShuSchool === 0 && xiaShuJiaoFu === 0 && Array.isArray(bureauIds) && bureauIds.length === 0 && Array.isArray(groupIds) && groupIds.length === 0) {
|
||||
layer.msg("请选择发布范围!", {
|
||||
icon: 3,
|
||||
time: 1500
|
||||
});
|
||||
}
|
||||
else {
|
||||
|
||||
publishData.job_id = jobId;
|
||||
publishData.xiaShuSchool = xiaShuSchool;
|
||||
publishData.xiaShuJiaoFu = xiaShuJiaoFu;
|
||||
publishData.bureauIds = bureauIds.join(",");
|
||||
publishData.groupIds = groupIds.join(",");
|
||||
publishData.deadline_time = data.field.deadline_time;
|
||||
publishData.memo = data.field.memo;
|
||||
|
||||
$.ajax({
|
||||
url: '/QingLong/collect/ForwardJob',
|
||||
type: 'post',
|
||||
data: publishData,
|
||||
success: function (result) {
|
||||
if (result.success) {
|
||||
layer.msg("发布成功!", {
|
||||
icon: 1,
|
||||
time: 1000
|
||||
}, function () {
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
parent.refresh();
|
||||
});
|
||||
} else {
|
||||
layer.msg(result.message, {
|
||||
icon: 2,
|
||||
time: 2000
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
return false;
|
||||
});
|
||||
|
||||
|
||||
window.publish_save = function (param) {
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
function GetQueryString(name, istop) {
|
||||
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
|
||||
var r = window.location.search.substr(1).match(reg);
|
||||
if (typeof (istop) != "undefined") r = top.location.search.substr(1).match(reg);
|
||||
|
||||
if (r != null) return unescape(r[2]);
|
||||
return null;
|
||||
}
|
||||
});
|
||||
</script>
|
||||
<script>
|
||||
</script>
|
||||
</body>
|
||||
|
||||
</html>
|
Loading…
Reference in new issue