You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
202 lines
6.1 KiB
202 lines
6.1 KiB
<!DOCTYPE html>
|
|
<html lang="zh" xmlns:th="http://www.thymeleaf.org" >
|
|
<head>
|
|
<th:block th:include="include :: header('修改单位')" />
|
|
</head>
|
|
<body class="white-bg">
|
|
<div class="wrapper wrapper-content animated fadeInRight ibox-content" id="app">
|
|
<form class="form-horizontal m" id="form-dept-edit" th:object="${dept}">
|
|
<input name="deptId" type="hidden" th:field="*{deptId}" />
|
|
<input id="treeId" name="parentId" type="hidden" th:field="*{parentId}" />
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">上级单位:</label>
|
|
<div class="col-sm-8">
|
|
<div class="input-group">
|
|
<input class="form-control" type="text" id="treeName" onclick="selectDeptTree()" readonly="true" th:field="*{parentName}">
|
|
<span class="input-group-addon"><i class="fa fa-search"></i></span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label is-required">所属地市:</label>
|
|
<div class="col-sm-8">
|
|
<select id="City" name="framework" required @change="getAreaList()" v-model="City" class="form-control m-b">
|
|
<option value="">请选择</option>
|
|
<option v-for="option in CityList" :value="option.id" :key="option.id">
|
|
{{ option.name }}
|
|
</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label is-required">所属区县:</label>
|
|
<div class="col-sm-8">
|
|
<select id="Area" name="area" required v-model="Area" class="form-control m-b">
|
|
<option value="">请选择</option>
|
|
<option v-for="option in AreaList" :value="option.id" :key="option.id">
|
|
{{ option.name }}
|
|
</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label is-required">单位名称:</label>
|
|
<div class="col-sm-8">
|
|
<input class="form-control" type="text" name="deptName" th:field="*{deptName}" id="deptName" required>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label is-required">显示排序:</label>
|
|
<div class="col-sm-8">
|
|
<input class="form-control" type="text" name="orderNum" th:field="*{orderNum}" required>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">负责人:</label>
|
|
<div class="col-sm-8">
|
|
<input class="form-control" type="text" name="leader" th:field="*{leader}">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">联系电话:</label>
|
|
<div class="col-sm-8">
|
|
<input class="form-control" type="text" name="phone" th:field="*{phone}">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">邮箱:</label>
|
|
<div class="col-sm-8">
|
|
<input class="form-control" type="text" name="email" th:field="*{email}">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-3 control-label">单位状态:</label>
|
|
<div class="col-sm-8">
|
|
<div class="radio-box" th:each="dict : ${@dict.getType('sys_normal_disable')}">
|
|
<input type="radio" th:id="${dict.dictCode}" name="status" th:value="${dict.dictValue}" th:field="*{status}">
|
|
<label th:for="${dict.dictCode}" th:text="${dict.dictLabel}"></label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
<th:block th:include="include :: footer" />
|
|
<script type="text/javascript">
|
|
var prefix = ctx + "system/dept";
|
|
$("#form-dept-edit").validate({
|
|
onkeyup: false,
|
|
rules:{
|
|
deptName:{
|
|
remote: {
|
|
url: prefix + "/checkDeptNameUnique",
|
|
type: "post",
|
|
dataType: "json",
|
|
data: {
|
|
"deptId": function() {
|
|
return $("#deptId").val();
|
|
},
|
|
"parentId": function() {
|
|
return $("input[name='parentId']").val();
|
|
},
|
|
"deptName": function() {
|
|
return $.common.trim($("#deptName").val());
|
|
}
|
|
}
|
|
}
|
|
},
|
|
orderNum:{
|
|
digits:true
|
|
},
|
|
email:{
|
|
email:true,
|
|
},
|
|
phone:{
|
|
isPhone:true,
|
|
},
|
|
},
|
|
messages: {
|
|
"deptName": {
|
|
remote: "单位已经存在"
|
|
}
|
|
},
|
|
focusCleanup: true
|
|
});
|
|
|
|
function submitHandler() {
|
|
if ($.validate.form()) {
|
|
$.operate.save(prefix + "/edit", $('#form-dept-edit').serialize());
|
|
}
|
|
}
|
|
|
|
/*单位管理-修改-选择单位树*/
|
|
function selectDeptTree() {
|
|
var deptId = $("#treeId").val();
|
|
var excludeId = $("input[name='deptId']").val();
|
|
if(deptId > 0) {
|
|
var options = {
|
|
title: '单位选择',
|
|
width: "380",
|
|
url: prefix + "/selectDeptTree/" + $("#treeId").val() + "/" + excludeId,
|
|
callBack: doSubmit
|
|
};
|
|
$.modal.openOptions(options);
|
|
} else {
|
|
$.modal.alertError("父单位不能选择");
|
|
}
|
|
}
|
|
|
|
function doSubmit(index, layero){
|
|
var tree = layero.find("iframe")[0].contentWindow.$._tree;
|
|
if ($.tree.notAllowLastLevel(tree)) {
|
|
var body = $.modal.getChildFrame(index);
|
|
$("#treeId").val(body.find('#treeId').val());
|
|
$("#treeName").val(body.find('#treeName').val());
|
|
$.modal.close(index);
|
|
}
|
|
}
|
|
var app = new Vue({
|
|
el: '#app',
|
|
data: {
|
|
CityList: [],
|
|
AreaList:[],
|
|
City:[[${dept.framework}]],
|
|
Area:[[${dept.area}]],
|
|
params:{
|
|
parentId:'',
|
|
}
|
|
},
|
|
mounted(){
|
|
// 初始化地市列表
|
|
this.getCityList();
|
|
if (this.City){
|
|
this.getAreaList()
|
|
}
|
|
},
|
|
methods:{
|
|
getCityList(){
|
|
$.ajax({
|
|
url: ctx + "system/area/getSysAreaList",
|
|
type: 'GET',
|
|
data:this.params ,
|
|
success:((res)=>{
|
|
this.CityList = res.data
|
|
}) ,
|
|
});
|
|
},
|
|
getAreaList(){
|
|
this.params.parentId = this.City
|
|
$.ajax({
|
|
url: ctx + "system/area/getSysAreaList",
|
|
type: 'GET',
|
|
data:this.params,
|
|
success:((res)=>{
|
|
this.AreaList = res.data
|
|
}) ,
|
|
});
|
|
}
|
|
}
|
|
})
|
|
</script>
|
|
</body>
|
|
</html>
|