wg-basic/service-department/src/main/resources/templates/department/save-split.html

423 lines
22 KiB
HTML
Raw Normal View History

2021-01-29 15:02:37 +08:00
<!doctype html>
2021-02-14 22:09:36 +08:00
<html xmlns:th="http://www.thymeleaf.org">
2021-01-29 15:02:37 +08:00
<head>
2021-02-14 22:09:36 +08:00
<base th:href="${#request.getContextPath() + '/'}">
2021-01-29 15:02:37 +08:00
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
<style>
html, body {height: 100%;}
.layui-form-select dl {max-height: 150px !important; z-index: 10010 !important;}
</style>
</head>
<body>
<div class="layui-fluid layui-anim layui-anim-fadein" style="padding: 0; height: 100%;">
<div class="layui-card">
<div class="layui-card-header">
<span class="layui-breadcrumb" lay-filter="breadcrumb" style="visibility: visible;">
<a class="close" href="javascript:void(0);">上级列表</a><span lay-separator="">/</span>
<a href="javascript:void(0);"><cite>新增内容</cite></a>
</span>
</div>
<div class="layui-card-body" style="padding: 15px;">
<form class="layui-form layui-form-pane" lay-filter="dataForm">
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织名称 *</label>
<div class="layui-input-block">
<input id="departmentName" type="text" name="departmentName" lay-verify="required" placeholder="请输入组织名称" class="layui-input" maxlength="50">
</div>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">名称(英文)</label>
<div class="layui-input-block">
2021-02-17 21:06:29 +08:00
<input type="text" name="departmentNameEn" placeholder="请输入名称(英文)" class="layui-input" maxlength="255">
2021-01-29 15:02:37 +08:00
</div>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">名称(其他)</label>
<div class="layui-input-block">
2021-02-17 21:06:29 +08:00
<input type="text" name="departmentNameOther" placeholder="请输入名称(其他)" class="layui-input" maxlength="255">
2021-01-29 15:02:37 +08:00
</div>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织说明</label>
<div class="layui-input-block">
2021-02-17 21:06:29 +08:00
<input type="text" name="departmentSummary" placeholder="请输入组织说明" class="layui-input" maxlength="255">
2021-01-29 15:02:37 +08:00
</div>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织类型 *</label>
<div class="layui-input-block">
<select name="departmentType" lay-verify="required">
<option value="1" selected>机构</option>
<option value="2">部门</option>
</select>
</div>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织状态 *</label>
<div class="layui-input-block">
<select name="departmentState" lay-verify="required">
<option value="1" selected>正常</option>
<option value="2">异常</option>
<option value="3">停用</option>
</select>
</div>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">负责人</label>
<div class="layui-input-block">
<input id="departmentMaster" type="hidden" class="layui-input" name="departmentMaster">
<input id="departmentMasterName" type="text" class="layui-input" name="departmentMasterName" placeholder="请选择组织负责人" readonly style="cursor: pointer;">
</div>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织传真</label>
<div class="layui-input-block">
2021-02-17 21:06:29 +08:00
<input type="text" class="layui-input" name="departmentFax" placeholder="请输入组织传真" maxlength="255">
2021-01-29 15:02:37 +08:00
</div>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织电话</label>
<div class="layui-input-block">
2021-02-17 21:06:29 +08:00
<input type="text" class="layui-input" name="departmentTel" placeholder="请输入组织电话" maxlength="255">
2021-01-29 15:02:37 +08:00
</div>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织职责</label>
<div class="layui-input-block">
2021-02-17 21:06:29 +08:00
<input type="text" class="layui-input" name="departmentDuty" placeholder="请输入组织职责" maxlength="255">
2021-01-29 15:02:37 +08:00
</div>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织排序</label>
<div class="layui-input-block">
<input type="number" class="layui-input" name="departmentOrder" placeholder="请输入组织排序" value="0">
</div>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">1级区域</label>
<div class="layui-input-block layui-form" id="departmentArea1IdSelectTemplateBox" lay-filter="departmentArea1IdSelectTemplateBox"></div>
<script id="departmentArea1IdSelectTemplate" type="text/html">
<select id="departmentArea1Id" name="departmentArea1Id" lay-filter="departmentArea1Id" lay-search>
<option value="">请选择1级区域</option>
{{# for(var i = 0, item; item = d[i++];) { }}
<option value="{{item.areaId}}">{{item.areaName}}</option>
{{# } }}
</select>
</script>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">2级区域</label>
<div class="layui-input-block layui-form" id="departmentArea2IdSelectTemplateBox" lay-filter="departmentArea2IdSelectTemplateBox"></div>
<script id="departmentArea2IdSelectTemplate" type="text/html">
<select id="departmentArea2Id" name="departmentArea2Id" lay-filter="departmentArea2Id" lay-search>
<option value="">请选择2级区域</option>
{{# for(var i = 0, item; item = d[i++];) { }}
<option value="{{item.areaId}}">{{item.areaName}}</option>
{{# } }}
</select>
</script>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">3级区域</label>
<div class="layui-input-block layui-form" id="departmentArea3IdSelectTemplateBox" lay-filter="departmentArea3IdSelectTemplateBox"></div>
<script id="departmentArea3IdSelectTemplate" type="text/html">
<select id="departmentArea3Id" name="departmentArea3Id" lay-filter="departmentArea3Id" lay-search>
<option value="">请选择3级区域</option>
{{# for(var i = 0, item; item = d[i++];) { }}
<option value="{{item.areaId}}">{{item.areaName}}</option>
{{# } }}
</select>
</script>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">4级区域</label>
<div class="layui-input-block layui-form" id="departmentArea4IdSelectTemplateBox" lay-filter="departmentArea4IdSelectTemplateBox"></div>
<script id="departmentArea4IdSelectTemplate" type="text/html">
<select id="departmentArea4Id" name="departmentArea4Id" lay-filter="departmentArea4Id" lay-search>
<option value="">请选择4级区域</option>
{{# for(var i = 0, item; item = d[i++];) { }}
<option value="{{item.areaId}}">{{item.areaName}}</option>
{{# } }}
</select>
</script>
</div>
</div>
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">5级区域</label>
<div class="layui-input-block layui-form" id="departmentArea5IdSelectTemplateBox" lay-filter="departmentArea5IdSelectTemplateBox"></div>
<script id="departmentArea5IdSelectTemplate" type="text/html">
<select id="departmentArea5Id" name="departmentArea5Id" lay-search>
<option value="">请选择5级区域</option>
{{# for(var i = 0, item; item = d[i++];) { }}
<option value="{{item.areaId}}">{{item.areaName}}</option>
{{# } }}
</select>
</script>
</div>
</div>
</div>
<div class="layui-row">
<div class="layui-col-md12 layui-col-sm12 layui-col-xs12">
<div class="layui-form-item">
<label class="layui-form-label">组织地址</label>
<div class="layui-input-block">
2021-02-17 21:06:29 +08:00
<input type="text" class="layui-input" name="departmentAddress" placeholder="请输入组织地址" maxlength="255">
2021-01-29 15:02:37 +08:00
</div>
</div>
</div>
</div>
<div class="layui-form-item layui-layout-admin">
<div class="layui-input-block">
<div class="layui-footer" style="left: 0;">
<button type="button" class="layui-btn" lay-submit lay-filter="submitForm">提交新增</button>
<button type="button" class="layui-btn layui-btn-primary close">返回上级</button>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script>
layui.config({
base: 'assets/layuiadmin/' //静态资源所在路径
}).extend({
index: 'lib/index' //主入口模块
}).use(['index', 'form', 'laydate'], function(){
var $ = layui.$;
var form = layui.form;
var laytpl = layui.laytpl;
var departmentParentId = top.restAjax.params(window.location.href).departmentParentId;
function closeBox() {
parent.layer.close(parent.layer.getFrameIndex(window.name));
}
// 初始化选择框、单选、复选模板
function initSelectRadioCheckboxTemplate(templateId, templateBoxId, data, callback) {
laytpl(document.getElementById(templateId).innerHTML).render(data, function(html) {
document.getElementById(templateBoxId).innerHTML = html;
});
form.render('select', templateBoxId);
if(callback) {
callback();
}
}
// 初始化1级区域下拉选择
function initDepartmentArea1CodeSelect() {
2021-02-14 22:09:36 +08:00
top.restAjax.get(top.restAjax.path('api/area/listbyparentid/0', []), {}, null, function(code, data, args) {
2021-01-29 15:02:37 +08:00
initSelectRadioCheckboxTemplate('departmentArea1IdSelectTemplate', 'departmentArea1IdSelectTemplateBox', data);
}, function(code, data) {
top.dialog.msg(data.msg);
});
}
// 初始化2级区域下拉选择
function initDepartmentArea2CodeSelect(area1) {
if(!area1) {
initSelectRadioCheckboxTemplate('departmentArea2IdSelectTemplate', 'departmentArea2IdSelectTemplateBox', []);
return;
}
2021-02-14 22:09:36 +08:00
top.restAjax.get(top.restAjax.path('api/area/listbyparentid/{area1}', [area1]), {}, null, function(code, data, args) {
2021-01-29 15:02:37 +08:00
initSelectRadioCheckboxTemplate('departmentArea2IdSelectTemplate', 'departmentArea2IdSelectTemplateBox', data);
}, function(code, data) {
top.dialog.msg(data.msg);
});
}
// 初始化3级区域下拉选择
function initDepartmentArea3CodeSelect(area2) {
if(!area2) {
initSelectRadioCheckboxTemplate('departmentArea3IdSelectTemplate', 'departmentArea3IdSelectTemplateBox', []);
return;
}
2021-02-14 22:09:36 +08:00
top.restAjax.get(top.restAjax.path('api/area/listbyparentid/{area2}', [area2]), {}, null, function(code, data, args) {
2021-01-29 15:02:37 +08:00
initSelectRadioCheckboxTemplate('departmentArea3IdSelectTemplate', 'departmentArea3IdSelectTemplateBox', data);
}, function(code, data) {
top.dialog.msg(data.msg);
});
}
// 初始化4级区域下拉选择
function initDepartmentArea4CodeSelect(area3) {
if(!area3) {
initSelectRadioCheckboxTemplate('departmentArea4IdSelectTemplate', 'departmentArea4IdSelectTemplateBox', []);
return;
}
2021-02-14 22:09:36 +08:00
top.restAjax.get(top.restAjax.path('api/area/listbyparentid/{area3}', [area3]), {}, null, function(code, data, args) {
2021-01-29 15:02:37 +08:00
initSelectRadioCheckboxTemplate('departmentArea4IdSelectTemplate', 'departmentArea4IdSelectTemplateBox', data);
}, function(code, data) {
top.dialog.msg(data.msg);
});
}
// 初始化5级区域下拉选择
function initDepartmentArea5CodeSelect(area4) {
if(!area4) {
initSelectRadioCheckboxTemplate('departmentArea5IdSelectTemplate', 'departmentArea5IdSelectTemplateBox', []);
return;
}
2021-02-14 22:09:36 +08:00
top.restAjax.get(top.restAjax.path('api/area/listbyparentid/{area4}', [area4]), {}, null, function(code, data, args) {
2021-01-29 15:02:37 +08:00
initSelectRadioCheckboxTemplate('departmentArea5IdSelectTemplate', 'departmentArea5IdSelectTemplateBox', data);
}, function(code, data) {
top.dialog.msg(data.msg);
});
}
// 初始化
function initData() {}
initData();
initDepartmentArea1CodeSelect();
initDepartmentArea2CodeSelect();
initDepartmentArea3CodeSelect();
initDepartmentArea4CodeSelect();
initDepartmentArea5CodeSelect();
// 选择负责人
$(document).on('click', '#departmentMasterName', function() {
top.dialog.dialogData.selectedUserIds = $('#departmentMaster').val();
top.dialog.open({
2021-02-17 21:06:29 +08:00
url: top.restAjax.path('route/department/user/select-user', []),
title: '选择用户',
2021-01-29 15:02:37 +08:00
width: '500px',
height: '500px',
onClose: function() {
var selectedUsers = top.dialog.dialogData.selectedDepartmentUsers;
if(selectedUsers != null && selectedUsers.length > 0) {
if(selectedUsers.length > 1) {
top.dialog.msg('负责人只能选择一人');
return;
}
$('#departmentMaster').val(selectedUsers[0].userId);
$('#departmentMasterName').val(selectedUsers[0].userName);
} else {
$('#departmentMaster').val('');
$('#departmentMasterName').val('');
}
}
});
})
// 提交表单
form.on('submit(submitForm)', function(formData) {
top.dialog.confirm(top.dataMessage.commit, function(index) {
top.dialog.close(index);
formData.field.departmentId = new Date().getTime();
formData.field.departmentParentId = departmentParentId;
parent.splitDepartmentArray.push(formData.field);
closeBox();
});
return false;
});
$('.close').on('click', function() {
closeBox();
});
// departmentArea1Id 选择事件
form.on('select(departmentArea1Id)', function(data) {
initDepartmentArea2CodeSelect(data.value);
initDepartmentArea3CodeSelect(data.value);
initDepartmentArea4CodeSelect(data.value);
initDepartmentArea5CodeSelect(data.value);
});
// departmentArea2Id 选择事件
form.on('select(departmentArea2Id)', function(data) {
initDepartmentArea3CodeSelect(data.value);
initDepartmentArea4CodeSelect(data.value);
initDepartmentArea5CodeSelect(data.value);
});
// departmentArea3Id 选择事件
form.on('select(departmentArea3Id)', function(data) {
initDepartmentArea4CodeSelect(data.value);
initDepartmentArea5CodeSelect(data.value);
});
// departmentArea4Id 选择事件
form.on('select(departmentArea4Id)', function(data) {
initDepartmentArea5CodeSelect(data.value);
});
// 校验部门是否存在
var checkDepartmentNameTimeout;
$(document).on('keydown', '#departmentName', function() {
var self = this;
if(checkDepartmentNameTimeout) {
clearTimeout(checkDepartmentNameTimeout);
}
checkDepartmentNameTimeout = setTimeout(function() {
if(!self.value) {
return;
}
2021-02-14 22:09:36 +08:00
top.restAjax.get(top.restAjax.path('api/department/countbyparentidandname/{departmentParentId}/{departmentName}', [departmentParentId, encodeURI(self.value)]), {}, null, function(code, data) {
2021-01-29 15:02:37 +08:00
if(data.data > 0) {
top.dialog.msg('【'+ self.value +'】在本级已经存在');
self.value = '';
return;
}
// 判断已经拆分的列表
for(var i = 0, item; item = parent.splitDepartmentArray[i++];) {
if(item.departmentName == self.value) {
top.dialog.msg('【'+ self.value +'】在本级已经存在');
self.value = '';
return;
}
}
}, function(code, data) {
top.dialog.msg(data.msg);
});
}, 500);
});
});
</script>
</body>
</html>