RequestHandlerWorkflow.jsp
4.17 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
<%@ page import="weaver.general.Util" %>
<%@ page import="java.util.*" %>
<%@ page language="java" contentType="text/html; charset=UTF-8" %> <%@ include file="/systeminfo/init_wev8.jsp" %>
<jsp:useBean id="RecordSet" class="weaver.conn.RecordSet" scope="page" />
<jsp:useBean id="RequestDefaultComInfo" class="weaver.system.RequestDefaultComInfo" scope="page" />
<%
int userid=user.getUID();
String worktypeid=request.getParameter("worktypeid");
String workflowid=request.getParameter("workflowid");
String url=request.getParameter("url");
String needall=request.getParameter("needall");//1:添加自定义;0:删除自定义
String style="insert";
//获取自定义流程信息
String sql="select selectedworkflow , isuserdefault from workflow_RequestUserDefault where userid="+userid;
//System.out.println(sql);
String selectedworkflow="";
String isuserdefault="0";//自定义流程是否启动
RecordSet.executeSql(sql);
while(RecordSet.next()){
style="update";
selectedworkflow=RecordSet.getString("selectedworkflow");
isuserdefault=RecordSet.getString("isuserdefault");
}
if(needall.equals("1")){
String[] swfs=selectedworkflow.split("\\|");
boolean b=true;
for(String swf:swfs){
if(swf.equalsIgnoreCase(worktypeid)){
b=false;
break;
}
}
if(b){
selectedworkflow=selectedworkflow+"|"+worktypeid;
}
//添加自定义
// if(selectedworkflow.indexOf(worktypeid)==-1){
// selectedworkflow=selectedworkflow+"|"+worktypeid;
// }
b=true;
for(String swf:swfs){
if(swf.equalsIgnoreCase(workflowid)){
b=false;
break;
}
}
if(b){
selectedworkflow=selectedworkflow+"|"+workflowid;
}
//if(selectedworkflow.indexOf(workflowid)==-1){
// selectedworkflow=selectedworkflow+"|"+workflowid;
//}
if(isuserdefault.equals("0")){
isuserdefault="1";
}
if(style.equals("insert")){
sql="insert into workflow_RequestUserDefault(userid,selectedworkflow,isuserdefault) values(?,?,1)";
RecordSet.executeUpdate(sql,userid,worktypeid+"|"+workflowid);
}else if(style.equals("update")){
sql="update workflow_RequestUserDefault set isuserdefault=1,selectedworkflow=? where userid=?";
RecordSet.executeUpdate(sql,selectedworkflow,userid);
}
}else if(needall.equals("0")){
//删除自定义
if(selectedworkflow.indexOf(workflowid)!=-1){
//工作流程删除
//selectedworkflow=selectedworkflow.replace("|"+workflowid,"");
//selectedworkflow=selectedworkflow.replace(workflowid+"|","");
String[] workflowids=selectedworkflow.split("\\|");
selectedworkflow="";
for(String wfid:workflowids){
//System.out.println(wfid);
if(!wfid.equalsIgnoreCase(workflowid)){
selectedworkflow=selectedworkflow+wfid+"|";
}
}
if(selectedworkflow.length()>0){
selectedworkflow=selectedworkflow.substring(0,(selectedworkflow.length()-1));
}
}
if(selectedworkflow.indexOf(worktypeid)!=-1){
//工作流程类型删除
String tid=worktypeid.substring(worktypeid.indexOf("T")+1);
// System.out.println(tid);
sql="select id from workflow_base where workflowtype="+tid;
RecordSet.executeSql(sql);
boolean b=true;
String[] swfs=selectedworkflow.split("\\|");
while(RecordSet.next()){
// if(selectedworkflow.indexOf("W"+RecordSet.getString("id"))!=-1){
// b=false;
// break;
// }
for(String swf:swfs){
if(swf.equalsIgnoreCase("W"+RecordSet.getString("id"))){
b=false;
break;
}
}
if(!b){
break;
}
}
if(b){
//selectedworkflow=selectedworkflow.replace("|"+worktypeid,"");
//selectedworkflow=selectedworkflow.replace(worktypeid+"|","");
selectedworkflow="";
for(String swf:swfs){
if(!swf.equalsIgnoreCase(worktypeid)){
selectedworkflow=selectedworkflow+swf+"|";
}
}
if(selectedworkflow.length()>0){
selectedworkflow=selectedworkflow.substring(0,(selectedworkflow.length()-1));
}
}
}
// System.out.println(selectedworkflow);
if(selectedworkflow.length()==0){
sql="delete from workflow_RequestUserDefault where userid="+userid;
RecordSet.execute(sql);
}else{
sql="update workflow_RequestUserDefault set isuserdefault=1,selectedworkflow=? where userid=?";
RecordSet.executeUpdate(sql,selectedworkflow,userid);
}
}
//System.out.println(url);
if(!"".equals(Util.null2String(url))){
response.sendRedirect(url);
}
%>