You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

411 lines
15 KiB
Plaintext

11 months ago
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
<title>共享任务</title>
<link href="Scripts/bootstrap/css/bootstrap.css" rel="stylesheet" type="text/css" />
<link href="Scripts/bootstrap/css/font-awesome.css" rel="stylesheet"/>
<link href="Style/skin/css/style.css" rel="stylesheet" type="text/css" />
<link href="Style/skin/css/animate.css" rel="stylesheet" type="text/css" />
<link href="Style/skin/font/iconfont.css" rel="stylesheet" type="text/css" />
</head>
<body class="gray-bg">
<div class="wrapper wrapper-content animated fadeInRight">
<div class="ibox-content">
<table class="table table-striped">
<thead>
<tr id="tablet">
</tr>
</thead>
<tbody id="Table1">
</tbody>
</table>
<div class="row">
<div class="col-sm-12">
<span id="Table2"></span>
</div>
</div>
</div>
</div>
<script type="text/javascript" src="./Scripts/bootstrap/js/jquery.min.js"></script>
<script type="text/javascript" src="./Scripts/bootstrap/js/bootstrap.min.js"></script>
<script src="./Scripts/QueryString.js" type="text/javascript"></script>
<script src="Scripts/config.js" type="text/javascript"></script>
<script src="Comm/Gener.js" type="text/javascript"></script>
<script src="Scripts/layui/layui/lay/modules/layer.js" type="text/javascript"></script>
<script type="text/javascript">
function SetImg(id) {
document.getElementById(id).src = './Img/Mail_Read.png';
}
function GroupBarClick(rowIdx) {
var alt = document.getElementById('Img' + rowIdx).alert;
var sta = 'block';
if (alt == 'Max') {
sta = 'block';
alt = 'Min';
classname = 'fa fa-minus-square';
} else {
sta = 'none';
alt = 'Max';
classname = 'fa fa-plus-square';
}
document.getElementById('Img' + rowIdx).className = classname;
document.getElementById('Img' + rowIdx).alert = alt;
var i = 0;
for (i = 0; i <= 1000; i++) {
var row = document.getElementById(rowIdx + i);
if (row == null || row == undefined || row.style == null)
continue;
if (sta == 'block') {
row.style.display = '';
} else {
row.style.display = sta;
}
}
}
function WinOpenIt(url) {
layer.open({
skin: 'layer-class',
type: 2,
title: '共享任务',
area: ['96%', '90%'],
content: url
});
}
</script>
<script language="javascript" type="text/javascript">
//页面启动函数.
$(function () {
InitPage();
});
//初始化数据.
function InitPage() {
//获取当前时间
var cdt = getNowFormatDate();
var timeKey = Math.random();
//初始化表格.
var handler = new HttpHandler("BP.WF.HttpHandler.WF");
handler.AddPara("FK_Node", GetQueryString("FK_Node"));
var data = handler.DoMethodReturnString("TaskPoolSharing_Init");
if (data.indexOf('err@') == 0) {
alert(data);
return;
}
data = cceval('(' + data + ')');
//设置表头.
var groupBy = GetQueryString("GroupBy");
if (groupBy == "" || groupBy == null)
groupBy = "ByFlow";
var nodeIDt = GetQueryString("FK_Node");
var tablet = "";
tablet += "<th>#</th>";
// title += "<th style='width:20px;'>优先级</th>";
tablet += "<th>标题</th>";
if (groupBy == "ByNode") {
tablet += "<th><a href='?FK_Node=" + nodeIDt + "&GroupBy=ByFlow' >流程</th>";
tablet += "<th><a href='?FK_Node=" + nodeIDt + "&GroupBy=ByStarter' >发起人</th>";
}
if (groupBy == "ByFlow") {
tablet += "<th><a href='?FK_Node=" + nodeIDt + "&GroupBy=ByNode' >节点</th>";
tablet += "<th><a href='?FK_Node=" + nodeIDt + "&GroupBy=ByStarter' >发起人</th>";
}
if (groupBy == "ByStarter") {
tablet += "<th><a href='?FK_Node=" + nodeIDt + "&GroupBy=ByFlow' >流程</th>";
tablet += "<th><a href='?FK_Node=" + nodeIDt + "&GroupBy=ByNode' >节点</th>";
}
tablet += "<th>发起日期</th>";
tablet += "<th>到达</th>";
tablet += "<th>期限</th>";
tablet += "<th>状态</th>";
tablet += "<th>类型</th>";
tablet += "<th>备注</th>";
$("#tablet").html(tablet);
//生成分组的字符串.
var str = "";
for (var i = 0; i < data.length; i++) {
if (groupBy == "ByNode") {
if (str.indexOf(data[i].NodeName) == -1)
str += "@" + data[i].NodeName;
}
if (groupBy == "ByFlow") {
if (str.indexOf(data[i].FlowName) == -1)
str += "@" + data[i].FlowName;
}
if (groupBy == "ByStarter") {
if (str.indexOf(data[i].StarterName) == -1)
str += "@" + data[i].StarterName;
}
}
var strs = str.split("@"); //生成数组.
var num = 0;
var is1 = false;
var listbox = '';
//循环数组.
for (var idx = 0; idx < strs.length; idx++) {
var groupName = strs[idx];
if (groupName == "" || groupName == null)
continue;
listbox += "<tr onclick=\"GroupBarClick('" + idx + "')\" > <th colspan=10 class='table-title'> <i class='fa fa-minus-square' alert='Min' id='Img" + idx + "'></i><span>" + groupName + "</span></th> </tr>";
//增加处理.
for (var i = 0; i < data.length; i++) {
var work = data[i];
if (groupBy == "ByNode") {
if (work.NodeName != groupName) {
continue;
}
} else if (groupBy == "ByFlow") {
if (work.FlowName != groupName) {
continue;
}
} else if (groupBy == "ByStarter") {
if (work.StarterName != groupName) {
continue;
}
} else {
continue;
}
var title = work.Title;
var isRead = work.IsRead;
var flowNo = work.FK_Flow;
var flowName = work.FlowName;
var nodeName = work.NodeName;
var starterName = work.StarterName;
var pri = work.PRI;
var nodeID = work.FK_Node;
var fid = work.FID;
var workID = work.WorkID;
var pWorkID = work.PWorkID;
var paras = work.AtPara;
if (paras != '') {
paras = paras.replace("'", "\\'");
paras = paras.replace('@', '&');
paras = paras.replace('@', '&');
paras = paras.replace('@', '&');
paras = paras.replace('@', '&');
paras = paras.replace('@', '&');
paras = "1" + paras;
}
num++;
if (is1 == true) {
listbox += "<tr " + "ID='" + idx + "_" + i + "'" + " >";
is1 = false;
}
else {
listbox += "<tr " + "ID='" + idx + "_" + i + "'" + " >";
is1 = true;
}
listbox += "<td>" + num + "</td>"; //序号.
//newRow += "<td><img class=Icon src='Img/PRI/" + pri + ".png' class=Icon /></td>"; //优先级
var url = "";
if (isRead == 0)
url = "<a href=\"javascript:WinOpenIt('MyFlow.htm?FK_Flow=" + flowNo + "&PWorkID=" + pWorkID + "&FK_Node=" + nodeID + "&FID=" + fid + "&WorkID=" + workID + "&IsRead=0&T=" + timeKey + "&Paras=" + paras + "','" + workID + "');\" ><img class=Icon align='middle' src='Img/Mail_UnRead.png' id='i" + idx + "_" + i + "' />" + title + "</a>";
else
url = "<a href=\"javascript:WinOpenIt('MyFlow.htm?FK_Flow=" + flowNo + "&PWorkID=" + pWorkID + "&FK_Node=" + nodeID + "&FID=" + fid + "&WorkID=" + workID + "&IsRead=0&T=" + timeKey + "&Paras=" + paras + "','" + workID + "');\" ><img class=Icon align='middle' src='Img/Mail_Read.png' />" + title + "</a>";
if (isRead == 0)
listbox += "<td SetImg('I" + idx + "_" + i + "')\" >" + url + "</td>";
else
listbox += "<td>" + url + "</td>"; //标题
if (groupBy == "ByNode") {
listbox += "<td>" + flowName + "</td>"; //流程类别
listbox += "<td>" + starterName + "</td>"; //发起人
} else if (groupBy == "ByFlow") {
listbox += "<td>" + nodeName + "</td>"; //节点名称
listbox += "<td>" + starterName + "</td>"; //发起人
} else if (groupBy == "ByStarter") {
listbox += "<td>" + flowName + "</td>"; //流程类别
listbox += "<td>" + nodeName + "</td>"; //节点名称
}
listbox += "<td>" + work.RDT + "</td>"; //发起时间
listbox += "<td>" + work.ADT + "</td>"; //接受时间
listbox += "<td>" + work.SDT + "</td>"; //应完成时间
//判断流程是否逾期
if (cdt > work.SDT && work.WFState == 2)
listbox += "<td><font color=red>逾期</font></td>";
else
listbox += "<td><font color=green>正常</font></td>";
listbox += "<td>" + GetState(work.WFState) + "</td>";
//备注
// listbox += "<td><div style='width:100px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;' title='" + work.FlowNote + "'>" + work.FlowNote + "</div></td>";
listbox += "</tr>";
}
}
$('#Table1').html(listbox);
$("#Table2").html("<div style='float:left;' >合计:" + data.length + "条</div> <div style='float:right;' ><a href=\"TaskPoolApply.htm\" >查看我申请下来的任务</a></div>");
}
function GetState(wfState) {
switch (wfState) {
case 1:
return "草稿";
case 2:
return "待办";
break;
case 3: //已完成.
break;
case 4:
return "挂起";
case 5:
return "<font color=red>退回</font>";
case 6:
return "转发";
case 7:
return "删除";
case 8:
return "加签";
case 11:
return "加签回复";
default:
return "其他";
}
}
//获取当前时间
function getNowFormatDate() {
var date = new Date();
var seperator1 = "-";
var seperator2 = ":";
var month = date.getMonth() + 1;
var strDate = date.getDate();
if (month >= 1 && month <= 9) {
month = "0" + month;
}
if (strDate >= 0 && strDate <= 9) {
strDate = "0" + strDate;
}
//当前时间=年份-月份-日 小时:分钟
var cdt = date.getFullYear() + seperator1 + month + seperator1 + strDate
+ " " + date.getHours() + seperator2 + date.getMinutes();
return cdt;
}
function WinOpenIt(url, workid) {
if (window.confirm('您确定要申请下来该任务吗?') == false) {
return;
}
//执行申请.
var handler = new HttpHandler("BP.WF.HttpHandler.WF");
handler.AddPara("WorkID", workid);
var data = handler.DoMethodReturnString("TaskPoolSharing_Apply");
if (data.indexOf('err@') == 0) {
alert(data);
return;
}
var newWindow = window.open(url, '_blank', 'height=600,width=850,top=50,left=50,toolbar=no,menubar=no,scrollbars=yes, resizable=yes,location=no, status=no');
newWindow.focus();
var doUrl = '../WF/Do.aspx?ActionType=DoAppTask&WorkID=' + workid;
return;
}
</script>
<script type="text/javascript">
var NS4 = (document.layers);
var IE4 = (document.all);
var win = window;
var n = 0;
function findInPage(str) {
alert(document.getElementById('string1'));
str = document.getElementById('string1').value;
// alert(str);
var txt, i, found;
if (str == "")
return false;
if (NS4) {
if (!win.find(str))
while (win.find(str, false, true))
n++;
else
n++;
if (n == 0)
alert("对不起!没有你要找的内容。");
}
if (IE4) {
txt = win.document.body.createTextRange();
for (i = 0; i <= n && (found = txt.findText(str)) != false; i++) {
txt.moveStart("character", 1);
txt.moveEnd("textedit");
}
if (found) {
txt.moveStart("character", -1);
txt.findText(str);
txt.select();
txt.scrollIntoView();
n++;
}
else {
if (n > 0) {
n = 0;
findInPage(str);
}
else
alert("对不起!没有你要找的内容。");
}
}
return false;
}
</script>
</body>
</html>