mirror of
https://git.code.sf.net/p/seeddms/code
synced 2025-02-06 23:24:57 +00:00
rework countDocuments()
check if user is actually set, 'WorkflowByMe' now uses a single sql statement
This commit is contained in:
parent
8ae40fbc9e
commit
84aa83d1d9
|
@ -904,7 +904,7 @@ class SeedDMS_Core_DMS {
|
||||||
foreach($tmp as $group)
|
foreach($tmp as $group)
|
||||||
$groups[] = $group->getID();
|
$groups[] = $group->getID();
|
||||||
}
|
}
|
||||||
$selectStr = "SELECT count(*) c ";
|
$selectStr = "count(distinct ttcontentid.document) c ";
|
||||||
$queryStr =
|
$queryStr =
|
||||||
"FROM `ttcontentid` ".
|
"FROM `ttcontentid` ".
|
||||||
"LEFT JOIN `tblDocumentStatus` ON `tblDocumentStatus`.`documentID`=`ttcontentid`.`document` AND `tblDocumentStatus`.`version`=`ttcontentid`.`maxVersion` ".
|
"LEFT JOIN `tblDocumentStatus` ON `tblDocumentStatus`.`documentID`=`ttcontentid`.`document` AND `tblDocumentStatus`.`version`=`ttcontentid`.`maxVersion` ".
|
||||||
|
@ -936,10 +936,12 @@ class SeedDMS_Core_DMS {
|
||||||
"LEFT JOIN `ttapproveid` ON `ttapproveid`.`approveID` = `tblDocumentApprovers`.`approveID` ".
|
"LEFT JOIN `ttapproveid` ON `ttapproveid`.`approveID` = `tblDocumentApprovers`.`approveID` ".
|
||||||
"LEFT JOIN `tblDocumentApproveLog` ON `tblDocumentApproveLog`.`approveLogID`=`ttapproveid`.`maxLogID` ";
|
"LEFT JOIN `tblDocumentApproveLog` ON `tblDocumentApproveLog`.`approveLogID`=`ttapproveid`.`maxLogID` ";
|
||||||
|
|
||||||
$queryStr .= "WHERE (`tblDocumentApprovers`.`type` = 0 AND `tblDocumentApprovers`.`required` = ".$user->getID()." ";
|
if($user) {
|
||||||
if($groups)
|
$queryStr .= "WHERE (`tblDocumentApprovers`.`type` = 0 AND `tblDocumentApprovers`.`required` = ".$user->getID()." ";
|
||||||
$queryStr .= "OR `tblDocumentApprovers`.`type` = 1 AND `tblDocumentApprovers`.`required` IN (".implode(',', $groups).") ";
|
if($groups)
|
||||||
$queryStr .= ") ";
|
$queryStr .= "OR `tblDocumentApprovers`.`type` = 1 AND `tblDocumentApprovers`.`required` IN (".implode(',', $groups).") ";
|
||||||
|
$queryStr .= ") ";
|
||||||
|
}
|
||||||
$queryStr .= "AND `tblDocumentApproveLog`.`status` = 0 ";
|
$queryStr .= "AND `tblDocumentApproveLog`.`status` = 0 ";
|
||||||
$queryStr .= "AND `tblDocumentStatusLog`.`status` IN (".S_DRAFT_APP.", ".S_EXPIRED.") ";
|
$queryStr .= "AND `tblDocumentStatusLog`.`status` IN (".S_DRAFT_APP.", ".S_EXPIRED.") ";
|
||||||
break; /* }}} */
|
break; /* }}} */
|
||||||
|
@ -952,10 +954,12 @@ class SeedDMS_Core_DMS {
|
||||||
"LEFT JOIN `ttreceiptid` ON `ttreceiptid`.`receiptID` = `tblDocumentRecipients`.`receiptID` ".
|
"LEFT JOIN `ttreceiptid` ON `ttreceiptid`.`receiptID` = `tblDocumentRecipients`.`receiptID` ".
|
||||||
"LEFT JOIN `tblDocumentReceiptLog` ON `tblDocumentReceiptLog`.`receiptLogID`=`ttreceiptid`.`maxLogID` ";
|
"LEFT JOIN `tblDocumentReceiptLog` ON `tblDocumentReceiptLog`.`receiptLogID`=`ttreceiptid`.`maxLogID` ";
|
||||||
|
|
||||||
$queryStr .= "WHERE (`tblDocumentRecipients`.`type` = 0 AND `tblDocumentRecipients`.`required` = ".$user->getID()." ";
|
if($user) {
|
||||||
if($groups)
|
$queryStr .= "WHERE (`tblDocumentRecipients`.`type` = 0 AND `tblDocumentRecipients`.`required` = ".$user->getID()." ";
|
||||||
$queryStr .= "OR `tblDocumentRecipients`.`type` = 1 AND `tblDocumentRecipients`.`required` IN (".implode(',', $groups).") ";
|
if($groups)
|
||||||
$queryStr .= ") ";
|
$queryStr .= "OR `tblDocumentRecipients`.`type` = 1 AND `tblDocumentRecipients`.`required` IN (".implode(',', $groups).") ";
|
||||||
|
$queryStr .= ") ";
|
||||||
|
}
|
||||||
$queryStr .= "AND `tblDocumentReceiptLog`.`status` = 0 ";
|
$queryStr .= "AND `tblDocumentReceiptLog`.`status` = 0 ";
|
||||||
$queryStr .= "AND `tblDocumentStatusLog`.`status` IN (".S_RELEASED.") ";
|
$queryStr .= "AND `tblDocumentStatusLog`.`status` IN (".S_RELEASED.") ";
|
||||||
break; /* }}} */
|
break; /* }}} */
|
||||||
|
@ -968,51 +972,40 @@ class SeedDMS_Core_DMS {
|
||||||
"LEFT JOIN `ttrevisionid` ON `ttrevisionid`.`revisionID` = `tblDocumentRevisors`.`revisionID` ".
|
"LEFT JOIN `ttrevisionid` ON `ttrevisionid`.`revisionID` = `tblDocumentRevisors`.`revisionID` ".
|
||||||
"LEFT JOIN `tblDocumentRevisionLog` ON `tblDocumentRevisionLog`.`revisionLogID`=`ttrevisionid`.`maxLogID` ";
|
"LEFT JOIN `tblDocumentRevisionLog` ON `tblDocumentRevisionLog`.`revisionLogID`=`ttrevisionid`.`maxLogID` ";
|
||||||
|
|
||||||
$queryStr .= "WHERE (`tblDocumentRevisors`.`type` = 0 AND `tblDocumentRevisors`.`required` = ".$user->getID()." ";
|
if($user) {
|
||||||
if($groups)
|
$queryStr .= "WHERE (`tblDocumentRevisors`.`type` = 0 AND `tblDocumentRevisors`.`required` = ".$user->getID()." ";
|
||||||
$queryStr .= "OR `tblDocumentRevisors`.`type` = 1 AND `tblDocumentRevisors`.`required` IN (".implode(',', $groups).") ";
|
if($groups)
|
||||||
$queryStr .= ") ";
|
$queryStr .= "OR `tblDocumentRevisors`.`type` = 1 AND `tblDocumentRevisors`.`required` IN (".implode(',', $groups).") ";
|
||||||
|
$queryStr .= ") ";
|
||||||
|
}
|
||||||
$queryStr .= "AND `tblDocumentRevisionLog`.`status` = 0 ";
|
$queryStr .= "AND `tblDocumentRevisionLog`.`status` = 0 ";
|
||||||
$queryStr .= "AND `tblDocumentStatusLog`.`status` IN (".S_IN_REVISION.") ";
|
$queryStr .= "AND `tblDocumentStatusLog`.`status` IN (".S_IN_REVISION.") ";
|
||||||
break; /* }}} */
|
break; /* }}} */
|
||||||
case 'NeedsCorrectionOwner':
|
case 'NeedsCorrectionOwner': // Documents that need to be corrected {{{
|
||||||
$queryStr .=
|
$queryStr .=
|
||||||
"LEFT JOIN `tblDocuments` ON `tblDocuments`.`id` = `ttcontentid`.`document` ";
|
"LEFT JOIN `tblDocuments` ON `tblDocuments`.`id` = `ttcontentid`.`document` ";
|
||||||
$queryStr .= "WHERE `tblDocuments`.`owner` = '".$user->getID()."' ".
|
$queryStr .= "WHERE `tblDocuments`.`owner` = '".$user->getID()."' ".
|
||||||
"AND `tblDocumentStatusLog`.`status` IN (".S_NEEDS_CORRECTION.") ";
|
"AND `tblDocumentStatusLog`.`status` IN (".S_NEEDS_CORRECTION.") ";
|
||||||
break; /* }}} */
|
break; /* }}} */
|
||||||
case 'WorkflowByMe':
|
case 'WorkflowByMe': // Documents which need my workflow action {{{
|
||||||
// Get document list for the current user.
|
|
||||||
$workflowStatus = $user->getWorkflowStatus();
|
|
||||||
|
|
||||||
// Create a comma separated list of all the documentIDs whose information is
|
$queryStr .=
|
||||||
// required.
|
"LEFT JOIN `tblWorkflowDocumentContent` on `ttcontentid`.`document`=`tblWorkflowDocumentContent`.`document` AND `ttcontentid`.`maxVersion`=`tblWorkflowDocumentContent`.`version` ".
|
||||||
$dList = array();
|
"LEFT JOIN `tblWorkflowTransitions` on `tblWorkflowDocumentContent`.`workflow`=`tblWorkflowTransitions`.`workflow` AND `tblWorkflowDocumentContent`.`state`=`tblWorkflowTransitions`.`state` ".
|
||||||
foreach ($workflowStatus["u"] as $st) {
|
"LEFT JOIN `tblWorkflowTransitionUsers` on `tblWorkflowTransitionUsers`.`transition` = `tblWorkflowTransitions`.`id` ".
|
||||||
if (!in_array($st["document"], $dList)) {
|
"LEFT JOIN `tblWorkflowTransitionGroups` on `tblWorkflowTransitionGroups`.`transition` = `tblWorkflowTransitions`.`id` ";
|
||||||
$dList[] = $st["document"];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
foreach ($workflowStatus["g"] as $st) {
|
|
||||||
if (!in_array($st["document"], $dList)) {
|
|
||||||
$dList[] = $st["document"];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$docCSV = "";
|
|
||||||
foreach ($dList as $d) {
|
|
||||||
$docCSV .= (strlen($docCSV)==0 ? "" : ", ")."'".$d."'";
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($dList) {
|
if($user) {
|
||||||
$queryStr .=
|
$queryStr .= "WHERE (`tblWorkflowTransitionUsers`.`userid` = ".$user->getID()." ";
|
||||||
"WHERE `ttcontentid`.`document` IN (" . implode(',', $dList) . ")";
|
if($groups)
|
||||||
} else {
|
$queryStr .= "OR `tblWorkflowTransitionGroups`.`groupid` IN (".implode(',', $groups).")";
|
||||||
$queryStr = '';
|
$queryStr .= ") ";
|
||||||
}
|
}
|
||||||
break;
|
$queryStr .= "AND `tblDocumentStatusLog`.`status` = ".S_IN_WORKFLOW." ";
|
||||||
|
break; // }}}
|
||||||
}
|
}
|
||||||
if($queryStr) {
|
if($queryStr) {
|
||||||
$resArr = $this->db->getResultArray($selectStr.$queryStr);
|
$resArr = $this->db->getResultArray('SELECT '.$selectStr.$queryStr);
|
||||||
if (is_bool($resArr) && !$resArr) {
|
if (is_bool($resArr) && !$resArr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1518,6 +1511,7 @@ class SeedDMS_Core_DMS {
|
||||||
$queryStr .= "OR `tblWorkflowTransitionGroups`.`groupid` IN (".implode(',', $groups).")";
|
$queryStr .= "OR `tblWorkflowTransitionGroups`.`groupid` IN (".implode(',', $groups).")";
|
||||||
$queryStr .= ") ";
|
$queryStr .= ") ";
|
||||||
}
|
}
|
||||||
|
$queryStr .= "AND `tblDocumentStatusLog`.`status` = ".S_IN_WORKFLOW." ";
|
||||||
// echo 'SELECT '.$selectStr." ".$queryStr;
|
// echo 'SELECT '.$selectStr." ".$queryStr;
|
||||||
if ($orderby=='e') $queryStr .= "ORDER BY `expires`";
|
if ($orderby=='e') $queryStr .= "ORDER BY `expires`";
|
||||||
else if ($orderby=='u') $queryStr .= "ORDER BY `statusDate`";
|
else if ($orderby=='u') $queryStr .= "ORDER BY `statusDate`";
|
||||||
|
|
Loading…
Reference in New Issue
Block a user