Files
2026-01-16 14:13:44 +08:00

378 lines
18 KiB
Plaintext
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<%@page import="com.sipai.entity.activiti.ProcessType"%>
<%@page import="com.sipai.entity.maintenance.MaintenanceCommString"%>
<%@ page language="java" pageEncoding="UTF-8"%>
<%request.setAttribute("MAINTENANCE_TYPE_OVERHAUL",MaintenanceCommString.MAINTENANCE_TYPE_OVERHAUL); %>
<%request.setAttribute("MAINTENANCE_TYPE_MAINTAIN",MaintenanceCommString.MAINTENANCE_TYPE_MAINTAIN); %>
<%request.setAttribute("MAINTENANCE_TYPE_REPAIR",MaintenanceCommString.MAINTENANCE_TYPE_REPAIR); %>
<%request.setAttribute("MAINTENANCE_TYPE_DEFECT",MaintenanceCommString.MAINTENANCE_TYPE_DEFECT); %>
<%request.setAttribute("ProcessType_Business_Maintenance", ProcessType.B_Maintenance.getId()); %>
<style type="text/css">
.select2-container .select2-selection--single{
height:34px;
line-height: 34px;
}
.select2-selection__arrow{
margin-top:3px;
}
</style>
<script type="text/javascript">
var initTable = function(id) {
$("#table1").bootstrapTable({ // 对应table标签的id
url: ext.contextPath + '/activiti/workflow/model/modelNode.do', // 获取表格数据的url
cache: false, // 设置为 false 禁用 AJAX 数据缓存, 默认为true
striped: true, //表格显示条纹默认为false
pagination: true, // 在表格底部显示分页组件默认false
pageList: [10, 20,50], // 设置页面可以显示的数据条数
pageSize: 50, // 页面数据条数
pageNumber: 1, // 首页页码
sidePagination: 'server', // 设置为服务器端分页
queryParams: function (params) { // 请求服务器数据时发送的参数可以在这里添加额外的查询参数返回false则终止请求
return {
rows: params.limit, // 每页要显示的数据条数
page: params.offset/params.limit+1, // 每页显示数据的开始页码
sort: params.sort, // 要排序的字段
order: params.order, // 排序规则
search_name: $('#search_name').val(),
modelid:id
}
},
sortName: 'resourceId', // 要排序的字段
sortOrder: 'desc', // 排序规则
columns: [
/* {
field: 'properties', // 返回json数据中的name
title: '业务/流程节点id', // 表格表头显示文字
sortable : true,
align: 'center', // 左右居中
valign: 'middle', // 上下居中
formatter:function(value,row,index){
return value.overrideid;
}
},{
field: 'stencil', // 返回json数据中的name
title: '节点类型', // 表格表头显示文字
sortable : true,
align: 'center', // 左右居中
valign: 'middle', // 上下居中
formatter:function(value,row,index){
return value.id;
}
}, {
field: 'stencil', // 返回json数据中的name
title: '节点类型', // 表格表头显示文字
sortable : true,
align: 'center', // 左右居中
valign: 'middle', // 上下居中
formatter:function(value,row,index){
return value.id;
}
}, */
/* {
field: 'resourceId', // 返回json数据中的name
title: '流程节点ID', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle', // 上下居中
}, */{
field: 'properties', // 返回json数据中的name
title: '流程节点名称', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle', // 上下居中
formatter:function(value,row,index){
return value.name;
}
},{
field: 'businessunit', // 返回json数据中的name
title: '节点业务名称', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle', // 上下居中
formatter:function(value,row,index){
if(value !=null){
return value.name;
}else{
return '';
}
}
},{
field: 'jobNames', // 返回json数据中的name
title: '<span>节点职位<span/><span><i style="float: right;padding-top: 5px;" class="fa fa-question-circle" aria-hidden="true" title="未选职位默认为全部人员"></i><span/>', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle', // 上下居中
formatter:function(value,row,index){
return value;
}
},{
title: "操作",
field: 'resourceId',
align: 'center',
valign: 'middle',
width: 120, // 定义列的宽度单位为像素px
formatter: function (value, row, index) {
var processTypeId=$('#processType').val();
var companyid=$('#companyid').val();
var jobIds = row.jobIds;
var buts = '<button class="btn btn-default btn-sm" onclick="editNodeFun(\'' + id + '\',\'' + value + '\',\'' + processTypeId + '\',\'' + companyid + '\')" data-toggle="tooltip" title="编辑"><i class="fa fa-edit"></i><span class="hidden-md hidden-lg"> 编辑</span></button>';
buts += '<button class="btn btn-default btn-sm" onclick="editJobFun(\'' + id + '\',\'' + value + '\',\'' + companyid + '\',\'' + jobIds + '\')" data-toggle="tooltip" title="编辑职位"><i class="fa fa-users"></i><span class="hidden-md hidden-lg"> 编辑职位</span></button>';
buts = '<div class="btn-group" >' + buts + '</div>';
return buts;
/* return '<i class="fa fa-edit" onclick="editFun()(\'' + row.id + '\')></i>'; */
}
}
],
onLoadSuccess: function(){ //加载成功时执行
adjustBootstrapTableView("table1");
$("#table1").bootstrapTable("hideRow",1)
},
onLoadError: function(){ //加载失败时执行
console.info("加载数据失败");
}
})
};
var editJobFun = function (modelid,resourceid,bizid,jobIds) {
$.post(ext.contextPath + '/user/showJob4Selects.do', {modelid:modelid,resourceid:resourceid, bizid: bizid,jobIds:jobIds }, function (data) {
$("#subDiv_Job").html(data);
openModal('jobModal');
});
};
var modelid = $("#id").val();
$(function() {
initTable(modelid);
});
var editFlowFun = function(id) {
$.post(ext.contextPath + '/activiti/workflow/model/editFlow.do', {id:id} , function(data) {
$("#subDiv1").html(data);
openModal('modelEditModal');
});
/* var w = window.screen.width*0.7;
var h = window.screen.height*0.7;
var l = window.screen.width*(1-0.7)/2;
window.open(ext.contextPath + '/modeler.html?modelId=' + id,'_black',
"left="+ l
+ ",top=50,scrollbars=yes,location=no,status=no,toolbar=no,resizable=yes"
+ ",width="+w
+ ",height="+h); */
};
/* 部署 */
var deployFun = function(id) {
$.post(ext.contextPath + '/activiti/workflow/model/deploy.do',{modelId:id}, function(data) {
if(data.res=='1'){
showAlert('s','部署成功');
}else{
showAlert('d',data.restr);
}
},'json');
};
function doupdate() {
$("#subForm").bootstrapValidator('validate');//提交验证
if ($("#subForm").data('bootstrapValidator').isValid()) {//获取验证结果,如果成功,执行下面代码
$.post(ext.contextPath + "/activiti/workflow/model/update.do", $("#subForm").serialize(), function(data) {
if (data != null ) {
closeModal('subModal')
$("#table").bootstrapTable('refresh');
}
else{
showAlert('d','保存失败');
}
},'json');
}
}
$("#subForm").bootstrapValidator({
live: 'disabled',//验证时机enabled是内容有变化就验证默认disabled和submitted是提交再验证
fields: {
name: {
validators: {
notEmpty: {
message: '流程模板名称不能为空'
}
}
},
processType: {
validators: {
notEmpty: {
message: '流程类型不能为空'
}
}
},
}
});
var companyid = "";
$(function() {
//简易公司combotree
$.post(ext.contextPath + '/user/getUnitForTree.do', { ng: '' }, function (data) {
if (data.length == 1 && !data[0].hasOwnProperty("nodes")) {
//当登陆者的pid以下没有子节点时显示单独一个span
$("#search_pidinner").val(data[0].id);
$("#companyselectinner").hide();
$("#companyNameinner").text("公司: " + data[0].text);
companyid = data[0].id;
} else if ((data.length == 1 && data.nodes != "") || data.length > 1) {
//第一次加载时赋值
// $("#search_pidinner").val(data[0].id);
// $("#cname_inputinner").val(data[0].text);
// companyid = data[0].id;
//$table.bootstrapTable('refresh');//异步加载重新刷新,待修改
$('#companytreeinner').treeview({
data: data,
showBorder: false,
levels: 3,
});
$('#companytreeinner').on('nodeSelected', function (event, data) {
$("#search_pidinner").val(data.id);
$("#cname_inputinner").val(data.text);
document.getElementById('ul_treeinner').style.display = "none";
companyid= data.id;
document.getElementById('companyid').value=data.id;
});
} else {
//待完善
};
}, 'json');
//防止点击树的+号收起下拉框
$("#ul_treeinner").on("click", function (e) {
event.stopPropagation();
});
//点击空白隐藏树
$(document).click(function (e) {
var divTree = $('#ul_treeinner'); // 设置目标区域
if (!divTree.is(e.target) && divTree.has(e.target).length === 0) {
divTree.hide()
}
})
/////
$.post(ext.contextPath + "/activiti/workflow/getProcessTypes4Combo.do", function(data) {
var selelct =$("#processType").select2({
data: data,
placeholder:'请选择',//默认文字提示
allowClear: false,//允许清空
escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入
language: "zh-CN",
minimumInputLength: 0,
minimumResultsForSearch: 10,//数据超过十个启用搜索框
formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果
formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择
});
selelct.on("change",function(e){
$("#table1").bootstrapTable("refresh")
var type= $(this).val();
   if('${ProcessType_Business_Maintenance}'==type){
$("#group_maintenanceType").show();
$("#maintenanceType").select2({minimumResultsForSearch: 10}).val("${maintenanceType}").trigger("change");
   }else{
$("#group_maintenanceType").hide();
   }
})
$("#processType").select2({minimumResultsForSearch: 10}).val("${processTypeId}").trigger("change");
},'json');
})
</script>
<div class="modal fade" id="subModal">
<div class="modal-dialog ">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span></button>
<h4 class="modal-title">编辑界面</h4>
</div>
<div class="modal-body">
<!-- 新增界面formid强制为subForm -->
<form class="form-horizontal" id="subForm">
<div id="alertDiv"></div>
<input id ="id" name="id" type="hidden" value="${model.id}"/>
<input class="form-control" type="hidden" id ="companyid" name ="companyid" value="${company.id }">
<!-- 界面提醒div强制id为alertdiv -->
<div class="form-group">
<label class="col-sm-3 control-label">公司</label>
<div class="col-sm-9">
<div class="form-group " style="margin-bottom:10px;">
<input id="search_pidinner" name="search_pidinner" type="hidden" />
<span id="companyNameinner" style="height:31px;color:#000000;border-top-left-radius: 4px;border-bottom-left-radius: 4px;font-weight:bold"></span>
</div>
<ul id="companyselectinner" style="list-style-type:none;padding-left:0px;width:300px;float: left;">
<li class="dropdown" style="width:300px;">
<!-- Menu toggle button -->
<a href="#" class="dropdown-toggle" data-toggle="dropdown"
style="width:300px;" onclick="document.getElementById('ul_treeinner').style.display = 'block';">
<div class="input-group">
<input class="form-control " id="cname_inputinner" name="cname_inputinner"
style="height:31px;width: 300px;border-top-right-radius: 4px;border-bottom-right-radius: 4px;"
readonly value="${company.name}"/>
</div><!-- /input-group -->
</a>
<ul id="ul_treeinner" class="dropdown-menu" data-stopPropagation="true">
<li class="header">
<div id="companytreeinner" style="width: 275px;overflow:auto;"></div>
</li>
</ul>
</li>
</ul>
<i style="float: left;padding-top: 10px;" class="fa fa-question-circle" aria-hidden="true" title="改变公司后先保存再进行其它操作"></i>
</div>
</div>
<div class="form-group">
<label class="col-sm-3 control-label">*流程模板名称</label>
<div class="col-sm-9">
<input type="text" class="form-control" name ="name" value="${model.name}" >
</div>
</div>
<div class="form-group">
<label class="col-sm-3 control-label">*流程类型</label>
<div class="col-sm-9">
<select class="form-control select2 " id="processType" name ="processType" style="width: 300px;"></select>
</div>
</div>
<div class="form-group" id="group_maintenanceType">
<label class="col-sm-3 control-label">运维类型</label>
<div class="col-sm-9">
<select class="form-control select2 " id="maintenanceType" name ="maintenanceType" style="width: 300px;" >
<option value="${MAINTENANCE_TYPE_OVERHAUL}" >检修</option>
<option value="${MAINTENANCE_TYPE_MAINTAIN}" >保养</option>
<option value="${MAINTENANCE_TYPE_REPAIR}" >维修</option>
<option value="${MAINTENANCE_TYPE_DEFECT}" >缺陷</option>
</select>
</div>
</div>
<div class="form-group">
<label class="col-sm-3 control-label">描述</label>
<div class="col-sm-9">
<textarea class="form-control" name="description" value="${description}">${description}</textarea>
</div>
</div>
<div class="form-group">
<label class="col-sm-3 control-label">审批流程</label>
<div class="col-sm-9">
<a class="btn btn-app hidden-xs" href="javascript:" onclick="editFlowFun('${model.id}')" data-toggle="tooltip">
<i class="fa fa-edit"></i> 流程编辑
</a>
<a class="btn btn-app" href="javascript:" onclick="deployFun('${model.id}')">
<i class="fa fa-play"></i> 流程部署
</a>
</div>
</div>
<table id="table1"></table>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default " data-dismiss="modal">关闭</button>
<button type="button" class="btn btn-primary" onclick="doupdate()">保存</button>
</div>
</div>
<!-- /.modal-content -->
</div>
<!-- /.modal-dialog -->
</div>