📄 flow_view.php
字号:
<?php
function outstr( $n )
{
switch ( $n )
{
case 1 :
$str = "(未接受)";
break;
case 2 :
$str = "(办理中)";
break;
case 3 :
$str = "(已转交)";
break;
case 4 :
$str = "(办理中)";
}
return $str;
}
include_once( "inc/auth.php" );
include_once( "inc/utility_all.php" );
include_once( "prcs_role.php" );
if ( !run_role( $RUN_ID, 0 ) )
{
exit( );
}
$query = "SELECT * from FLOW_TYPE where FLOW_ID={$FLOW_ID}";
$cursor = exequery( $connection, $query );
if ( $ROW = mysql_fetch_array( $cursor ) )
{
$FLOW_NAME = $ROW['FLOW_NAME'];
$FLOW_TYPE = $ROW['FLOW_TYPE'];
}
if ( $FLOW_TYPE == 2 )
{
header( "location:free_flow_view.php?RUN_ID=".$_REQUEST['RUN_ID']."&FLOW_ID=".$_REQUEST['FLOW_ID'] );
}
$query = "SELECT * from FLOW_RUN WHERE RUN_ID={$RUN_ID}";
$cursor = exequery( $connection, $query );
if ( $ROW = mysql_fetch_array( $cursor ) )
{
$RUN_NAME = $ROW['RUN_NAME'];
}
$TITLE = "流程图 - ".$FLOW_NAME." - ".$RUN_NAME;
if ( $PRINT_FLAG != 1 )
{
include_once( "inc/img_flow.inc.php" );
include_once( "inc/img_patten.inc.php" );
$connection = openconnection( );
$sql = "\r\n SELECT FLOW_PRCS FROM flow_run_prcs \r\n\t\t WHERE RUN_ID=".$_REQUEST['RUN_ID']." \r\n\t\t GROUP BY PRCS_ID ASC \r\n ";
$res = exequery( $connection, $sql );
while ( $row = mysql_fetch_array( $res ) )
{
$exportv[] = $row['FLOW_PRCS'];
}
$sql = " \r\n SELECT ID,FLOW_ID,PRCS_ID,PRCS_NAME,PRCS_USER,PRCS_ITEM,PRCS_DEPT,PRCS_PRIV,PRCS_TO \r\n\t FROM flow_process \r\n\t\t WHERE FLOW_ID=".$_REQUEST['FLOW_ID']." \r\n\t\t\t ORDER BY PRCS_ID\r\n\t\t\t\t ";
$res = exequery( $connection, $sql );
while ( $row = mysql_fetch_array( $res ) )
{
$export[$row['PRCS_ID']] = $row['PRCS_TO'];
}
$NowImg = new imgflow( );
$ImgPatten = new formatex( );
$export = $ImgPatten->makeupex( $export );
$export = $ImgPatten->replaceflag( $export );
$screenxy = $ImgPatten->countsize( $export );
$exportv = $ImgPatten->replaceflagrun( $export, $exportv );
$current = $ImgPatten->getcurrentsetp( $exportv );
$width = $screenxy['x'] - 49;
$height = $screenxy['y'];
$NowImg->definepic( "jpeg", $width, $height );
$w = $NowImg->layer_w;
$h = $NowImg->layer_h;
$NowImg->defineexport( $export );
$NowImg->destroyimg( );
$coordinate = $NowImg->coordinate;
echo "\r\n<html>\r\n<head>\r\n<title>";
echo $TITLE;
echo "</title>\r\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">\r\n";
echo "<s";
echo "cript>\r\nfocus();\r\nwindow.resizeTo(";
echo $screenxy['x'];
echo ",";
echo $screenxy['y'] + 300;
echo ");\r\n\r\n</script>\r\n</head>\r\n<body class=\"bodycolor\" topmargin=\"5\">\r\n<table border=\"0\" width=\"100%\" cellspacing=\"1\" cellpadding=\"5\">\r\n <tr class=\"tablehead1\">\r\n <td >流程图\r\n </td>\r\n </tr>\r\n\t";
if ( !$PRINT_FLAG )
{
echo " <tr class=\"tablehead2\"><td>\r\n\t\r\n <input type=\"image\" src=\"/images/button/shut.gif\" border=\"0\" onClick=\"parent.close();\" title=\"关闭\">\r\n </td></tr>\r\n\t";
}
echo "\t\r\n</table>\r\n";
}
if ( $PRINT_FLAG )
{
$WIDTH = "60%";
}
else
{
$WIDTH = "100%";
}
echo "<table width=\"100%\" border=\"0\" cellpadding=\"5\" cellspacing=\"1\" bgcolor=\"EBEBEB\">\r\n <tr>\r\n <td>";
$rootpath = str_replace( "\\", "/", get_cfg_var( "doc_root" )."/" );
$file = $rootpath."/general/system/workflow/flow_type/flow.ini";
$handle = fopen( $file, "r" );
$isview = fread( $handle, 1024 );
if ( $isview == 1 )
{
$dis = "";
$viewsrc = "/images/arrow_up.gif";
$viewmes = "隐藏流程图";
}
else
{
$dis = "none";
$viewsrc = "/images/arrow_down.gif";
$viewmes = "显示流程图";
}
echo " <img id='imgarrow' src='";
echo $viewsrc;
echo "' border=\"0\" onClick=\"DisplayFlowimg()\" style=\"cursor:hand \"> ";
echo "<s";
echo "pan style=\"color:#666666;cursor:hand \" id=\"imgtext\" onClick=\"DisplayFlowimg()\">\r\n ";
echo $viewmes;
echo " </span></td>\r\n </tr>\r\n</table>\r\n<div id=\"flowdiv\" style=\"display:";
echo $dis;
echo " \">\r\n<table width=\"100%\" border=\"0\" cellpadding=\"0\" cellspacing=\"1\" bgcolor=\"EBEBEB\">\r\n <tr>\r\n <td>\r\n\t\r\n\r\n\r\n<DIV id=overDiv style=\"Z-INDEX: 3; LEFT: 0px; VISIBILITY: hidden; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; POSITION: absolute; TOP: 0px; BORDER-BOTTOM-STYLE: none\"></DIV>\r\n";
echo "<S";
echo "CRIPT src=\"/inc/viewlayer.js\"></SCRIPT>\r\n";
$flowinfo = $coordinate;
$query = "SELECT * from FLOW_PROCESS WHERE FLOW_ID=".$_REQUEST['FLOW_ID']." ORDER BY PRCS_ID";
$cursor = exequery( $connection, $query );
$PRCS_COUNT = 0;
while ( $ROW = mysql_fetch_array( $cursor ) )
{
++$PRCS_COUNT;
$flowinfo[$PRCS_COUNT]['prcsname'] = $ROW['PRCS_NAME'];
$flowinfo[$PRCS_COUNT]['id'] = $ROW['ID'];
$flowinfo[$PRCS_COUNT]['prcsid'] = $ROW['PRCS_ID'];
}
echo "\r\n\r\n<table width=\"100%\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\r\n <tr>\r\n <td><div id=\"parentLayer\" style=\"position:absolute; width:1px; height:1px; z-index:0\">\r\n";
reset( $flowinfo );
unset( $k );
while ( list( $key, $flowdetail ) = each( $flowinfo ) )
{
++$k;
$x = $flowdetail['TL']['0'];
$y = $flowdetail['TL']['1'];
$prcsname = $flowdetail['prcsname'];
$prcsid = $flowdetail['prcsid'];
echo "<div id=\"";
echo "layer".$k;
echo "\" style=\"position:absolute; left:";
echo $x;
echo "px; top:";
echo $y;
echo "px; width:";
echo $w;
echo "px; height:";
echo $h;
echo "px; z-index:0; background-color: #E2E4E3; layer-background-color: #E2E4E3; border: 1px none #000000;\">\r\n ";
$sqll = "\r\n SELECT MAX(frp.PRCS_ID) AS maxpid FROM flow_run_prcs frp,user u \r\n\t\t WHERE u.USER_ID=frp.USER_ID \r\n\t\t\t AND frp.RUN_ID=".$_REQUEST['RUN_ID']." AND frp.FLOW_PRCS=".$prcsid."\r\n ";
$resl = exequery( $connection, $sqll );
$rowl = mysql_fetch_array( $resl );
$tmp_prcsid = $rowl['maxpid'];
if ( 0 < $tmp_prcsid )
{
$tmpsqlp = "AND frp.PRCS_ID=".$tmp_prcsid;
}
$sqlp = "\r\n SELECT u.USER_NAME,frp.* FROM flow_run_prcs frp,user u \r\n\t\t WHERE u.USER_ID=frp.USER_ID \r\n\t\t\t AND frp.RUN_ID=".$_REQUEST['RUN_ID']." AND frp.FLOW_PRCS=".$prcsid." ".$tmpsqlp."";
$resp = exequery( $connection, $sqlp );
$mostly_man = array( );
$subordination_man = array( );
$mk = 0;
while ( $rowp = mysql_fetch_array( $resp ) )
{
if ( $rowp['OP_FLAG'] == 1 )
{
$mostly_man[]['name'] = $rowp['USER_NAME'];
$mostly_man[]['flag'] = $rowp['PRCS_FLAG'];
}
else
{
$subordination_man[$mk]['name'] = $rowp['USER_NAME'];
$subordination_man[$mk]['flag'] = $rowp['PRCS_FLAG'];
}
++$mk;
}
unset( $strSubd );
if ( 0 < count( $subordination_man ) )
{
while ( list( $key, $var ) = each( $subordination_man ) )
{
$strSubd .= "<tr><td>".$var['name'];
$strSubd .= $strM."</td></tr>";
}
}
if ( $strSubd == "" )
{
$strSubd = "<tr><td> </td></tr>";
}
$drc2HTML = "<table width=190 border=0 cellspacing=0 cellpadding=2><tr><td width=40% height=50 align=right valign=top>经办人:</td><td align=left valign=top><table width=100% border=0 cellspacing=0 cellpadding=0>{$strSubd}</table></td></tr></table>";
$mostlyHTML = $mostly_man[0][name];
unset( $drcHTML );
if ( $mostlyHTML != "" )
{
$drcHTML = "\t\t\tonmouseover=\"drc('<b><font color=FFFFFF>主办人:{$mostlyHTML}</font></b>', '{$drc2HTML}'); high(popup)\" \r\n\t\t\t\t\t\t\t\t\t\t\tstyle=\"CURSOR: hand\" onfocus=this.blur() \r\n\t\t\t\t\t\t\t\t\t\t\tonmouseout=low(popup); ";
}
echo " \r\n \r\n <table width=\"100%\" height=\"";
echo $h;
echo "\" border=\"1\" cellpadding=\"0\" cellspacing=\"1\" bordercolor=\"#666666\" ";
echo $drcHTML;
echo " >\r\n <tr align=\"center\">\r\n\t<td height=\"20\" bgcolor=\"#0099CC\">";
echo "<s";
echo "pan style=\"color:#FFFFFF;font-weight:bolder \">\r\n\t序号:";
echo $prcsid;
echo "</span>\r\n\t</td>\r\n\t</tr>\r\n <tr >\r\n <td align=\"center\" valign=\"middle\">\r\n\t\t<table width=\"100%\" height=\"";
echo $h - 28;
echo "\" ";
if ( $k == $current )
{
echo "border='1'";
}
echo " cellpadding=\"0\" cellspacing=\"0\" bordercolor=\"#FF0000\">\r\n\t\t <tr>\r\n\t\t\t<td align=\"center\" valign=\"middle\">";
echo $prcsname;
echo "</td>\r\n\t\t </tr>\r\n\t\t</table>\t \r\n\t </td>\r\n </tr>\r\n </table>\r\n</div>\r\n";
}
echo "\t\r\n\t\r\n\t</div> \r\n\t\r\n\t <img src='runimgflow.php?FLOW_ID=";
echo $_REQUEST['FLOW_ID'];
echo "&RUN_ID=";
echo $_REQUEST['RUN_ID'];
echo "'></td>\r\n </tr>\r\n</table>\r\n\r\n\r\n\r\n\r\n\t\r\n\t\r\n\t\r\n\t</td>\r\n </tr>\r\n</table>\r\n</div>\r\n<table border=\"0\" cellspacing=\"1\" align=\"center\" width=\"";
echo $WIDTH;
echo "\" class=\"small\" cellpadding=\"5\">\r\n\r\n";
$query = "SELECT MAX(PRCS_ID) from FLOW_RUN_PRCS where RUN_ID={$RUN_ID}";
$cursor = exequery( $connection, $query );
if ( $ROW = mysql_fetch_array( $cursor ) )
{
$PRCS_ID = $ROW[0];
}
$PRCS_ID_I = 1;
for ( ; $PRCS_ID_I <= $PRCS_ID; ++$PRCS_ID_I )
{
$query = "SELECT * from FLOW_RUN_PRCS where RUN_ID={$RUN_ID} and PRCS_ID={$PRCS_ID_I}";
$cursor = exequery( $connection, $query );
$PRCS_FLAG_DESC = "";
$PRCS_FLAG_ALL = 4;
while ( $ROW = mysql_fetch_array( $cursor ) )
{
$PRCS_USER = $ROW['USER_ID'];
$PRCS_TIME = $ROW['PRCS_TIME'];
$DELIVER_TIME = $ROW['DELIVER_TIME'];
$PRCS_FLAG = $ROW['PRCS_FLAG'];
$FLOW_PRCS = $ROW['FLOW_PRCS'];
$OP_FLAG = $ROW['OP_FLAG'];
if ( $PRCS_FLAG != 4 )
{
$PRCS_FLAG_ALL = 0;
}
$PRCS_USER_NAME = "";
$query1 = "SELECT * from USER where USER_ID='{$PRCS_USER}'";
$cursor1 = exequery( $connection, $query1 );
if ( $ROW = mysql_fetch_array( $cursor1 ) )
{
$PRCS_USER_NAME = $ROW['USER_NAME'];
$DEPT_ID = $ROW['DEPT_ID'];
$DEPT_NAME = dept_long_name( $DEPT_ID );
}
else
{
$PRCS_USER_NAME = $PRCS_USER;
}
if ( $OP_FLAG == 1 )
{
$PRCS_USER_NAME = "<span class='big4'><u title='主办人,部门:{$DEPT_NAME}' style='cursor:hand'>{$PRCS_USER_NAME}</u></span>";
}
else
{
$PRCS_USER_NAME = "<u title='部门:{$DEPT_NAME}' style='cursor:hand'>{$PRCS_USER_NAME}</u>";
}
if ( $PRCS_FLAG == 1 )
{
$TIME_USED = 0;
}
else if ( $PRCS_FLAG == 2 )
{
$TIME_USED = time( ) - strtotime( $PRCS_TIME );
}
else
{
$TIME_USED = strtotime( $DELIVER_TIME ) - strtotime( $PRCS_TIME );
if ( $DELIVER_TIME == "" )
{
$TIME_USED = 0;
}
}
if ( $PRCS_TIME == "" )
{
$TIME_USED = 0;
}
$DAY = floor( $TIME_USED / 86400 );
$HOUR = floor( $TIME_USED % 86400 / 3600 );
$MIN = floor( $TIME_USED % 3600 / 60 );
$SEC = floor( $TIME_USED % 60 );
$TIME_STR = "";
if ( 0 < $DAY )
{
$TIME_STR .= $DAY."天";
}
if ( 0 < $HOUR )
{
$TIME_STR .= $HOUR."时";
}
if ( 0 < $MIN )
{
$TIME_STR .= $MIN."分";
}
if ( 0 < $SEC )
{
$TIME_STR .= $SEC."秒";
}
if ( $PRCS_FLAG == 1 )
{
$PRCS_FLAG_DESC .= "<img src='/images/email_close.gif' alt='未接收' align='absmiddle'> ".$PRCS_USER_NAME." [<font color=green>未接收办理</font>]";
}
else if ( $PRCS_FLAG == 2 )
{
$PRCS_FLAG_DESC .= "<img src='/images/email_open.gif' alt='已接收' align='absmiddle'> ".$PRCS_USER_NAME." [<font color=green>办理中 已用时:";
$PRCS_FLAG_DESC .= $TIME_STR."</font>]";
$PRCS_FLAG_DESC .= "<br>     开始于:{$PRCS_TIME}";
}
else if ( $PRCS_FLAG == 3 )
{
$PRCS_FLAG_DESC .= "<img src='/images/flow_next.gif' alt='已办结' align='absmiddle'> ".$PRCS_USER_NAME." [<font color=green>已转交下步 用时:";
$PRCS_FLAG_DESC .= $TIME_STR."</font>]";
$PRCS_FLAG_DESC .= "<br>     开始于:{$PRCS_TIME}";
}
else if ( $PRCS_FLAG == 4 )
{
$PRCS_FLAG_DESC .= "<img src='/images/flow_next.gif' alt='已办结' align='absmiddle'> ".$PRCS_USER_NAME." [<font color=green>已办结 用时:";
$PRCS_FLAG_DESC .= $TIME_STR."</font>]";
$PRCS_FLAG_DESC .= "<br>     开始于:{$PRCS_TIME}";
}
$PRCS_FLAG_DESC .= "<br>";
}
if ( 2 < $PRCS_FLAG )
{
$PRCS_FLAG_DESC .= "<br>     本步骤结束于:{$DELIVER_TIME}";
}
if ( $PRCS_ID_I == 1 )
{
echo " <tr class=\"TableLine2\">\r\n <td nowrap colspan=\"3\">\r\n <b>流程开始</b><br>\r\n </td>\r\n </tr>\r\n";
}
if ( $PRCS_FLAG_DESC == "" )
{
$PRCS_FLAG_DESC = " ";
}
echo " <tr class=\"TableLine1\">\r\n <td nowrap align=\"center\">第<b>";
echo "<s";
echo "pan class=\"Big4\">";
echo $PRCS_ID_I;
echo "</span></b>步</td>\r\n";
if ( $FLOW_TYPE == 1 )
{
$query1 = "SELECT * from FLOW_PROCESS WHERE FLOW_ID={$FLOW_ID} AND PRCS_ID={$FLOW_PRCS}";
$cursor1 = exequery( $connection, $query1 );
if ( $ROW = mysql_fetch_array( $cursor1 ) )
{
$PRCS_NAME = $ROW['PRCS_NAME'];
}
echo " <td><img border=0 src=\"/images/arrow_down.gif\" width=\"11\" height=\"13\"> 序号";
echo $FLOW_PRCS;
echo ":";
echo $PRCS_NAME;
echo "</td>\r\n";
}
echo " <td>";
echo $PRCS_FLAG_DESC;
echo "</td>\r\n </tr>\r\n";
}
if ( $PRCS_FLAG == 4 )
{
echo " <tr class=\"TableLine2\">\r\n <td nowrap align=\"center\" colspan=\"3\"><b>结束</b></td>\r\n </tr>\r\n";
}
echo "</table>\r\n<br>\r\n\r\n\r\n\r\n\r\n</body>\r\n</html>\r\n";
echo "<s";
echo "cript>\r\nfunction DisplayFlowimg(){\r\n if (flowdiv.style.display == 'none'){\r\n\t flowdiv.style.display = '';\r\n\t\timgarrow.src = '/images/arrow_up.gif';\r\n\t\timgtext.innerHTML = '隐藏流程图';\r\n\t}\r\n else {\r\n\t flowdiv.style.display = 'none';\r\n\t\timgarrow.src = '/images/arrow_down.gif';\r\n\t\timgtext.innerHTML = '显示流程图';\r\n\t}\t\r\n\r\n}\r\n</script>\r\n";
?>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -