Files
luos/workflow/engine/src/ProcessMaker/BusinessModel/Cases/Participated.php

310 lines
13 KiB
PHP
Raw Normal View History

<?php
namespace ProcessMaker\BusinessModel\Cases;
2020-12-09 23:21:32 +00:00
use ProcessMaker\Model\Application;
2020-12-16 17:47:42 -04:00
use ProcessMaker\Model\AppNotes;
2020-10-21 16:56:11 -04:00
use ProcessMaker\Model\Delegation;
2020-11-25 18:11:22 -04:00
use ProcessMaker\Model\Task;
2021-01-13 12:41:53 -04:00
use ProcessMaker\Model\User;
2020-10-21 16:56:11 -04:00
class Participated extends AbstractCases
{
2020-11-11 10:38:08 -04:00
// Columns to see in the cases list
public $columnsView = [
// Columns view in the cases list
'APP_DELEGATION.APP_NUMBER', // Case #
2020-12-09 19:04:05 -04:00
'APP_DELEGATION.DEL_TITLE', // Case Title
2020-11-11 10:38:08 -04:00
'PROCESS.PRO_TITLE', // Process Name
'TASK.TAS_TITLE', // Pending Task
'APPLICATION.APP_STATUS', // Status
2020-11-25 18:11:22 -04:00
'APPLICATION.APP_CREATE_DATE', // Start Date
'APPLICATION.APP_FINISH_DATE', // Finish Date
'APP_DELEGATION.DEL_TASK_DUE_DATE', // Due Date related to the colors
2021-01-12 14:48:38 -04:00
'USERS.USR_ID', // Current UserId
2020-11-11 10:38:08 -04:00
// Additional column for other functionalities
2020-11-25 18:11:22 -04:00
'APP_DELEGATION.APP_UID', // Case Uid for Open case
'APP_DELEGATION.DEL_INDEX', // Del Index for Open case
2020-12-07 17:07:26 -04:00
'APP_DELEGATION.PRO_UID', // Process Uid for Case notes
'APP_DELEGATION.TAS_UID', // Task Uid for Case notes
2020-11-11 10:38:08 -04:00
];
/**
* Get the columns related to the cases list
* @return array
*/
public function getColumnsView()
{
return $this->columnsView;
}
2020-11-25 18:11:22 -04:00
/**
* Scope filters
*
* @param \Illuminate\Database\Eloquent\Builder $query
*
* @return \Illuminate\Database\Eloquent\Builder
*/
public function filters($query)
{
// Specific case
if ($this->getCaseNumber()) {
$query->case($this->getCaseNumber());
}
// Specific case title
if (!empty($this->getCaseTitle())) {
2020-12-09 19:04:05 -04:00
$query->title($this->getCaseTitle());
2020-11-25 18:11:22 -04:00
}
// Scope to search for an specific process
if ($this->getProcessId()) {
$query->processId($this->getProcessId());
}
// Specific task
if ($this->getTaskId()) {
$query->task($this->getTaskId());
}
// Specific status
if ($this->getCaseStatus()) {
$query->status($this->getCaseStatus());
}
// Specific start case date from
if (!empty($this->getStartCaseFrom())) {
$query->startDateFrom($this->getStartCaseFrom());
}
// Specific by start case date to
if (!empty($this->getStartCaseTo())) {
$query->startDateTo($this->getStartCaseTo());
}
// Specific finish case date from
if (!empty($this->getFinishCaseFrom())) {
$query->finishCaseFrom($this->getFinishCaseFrom());
}
// Filter by finish case date to
if (!empty($this->getFinishCaseTo())) {
$query->finishCaseTo($this->getFinishCaseTo());
}
// Specific case uid PMFCaseLink
if (!empty($this->getCaseUid())) {
$query->appUid($this->getCaseUid());
}
return $query;
}
2020-10-21 16:56:11 -04:00
/**
* Get the data corresponding to Participated
*
* @return array
*/
public function getData()
{
// Start the query for get the cases related to the user
2020-11-25 18:11:22 -04:00
$query = Delegation::query()->select($this->getColumnsView());
2020-11-11 10:38:08 -04:00
// Join with process
$query->joinProcess();
// Join with task
$query->joinTask();
// Join with users
$query->joinUser();
2020-11-25 18:11:22 -04:00
// Join with application
$query->joinApplication();
2020-10-21 16:56:11 -04:00
// Scope to Participated
$query->participated($this->getUserId());
// Add filter
$filter = $this->getParticipatedStatus();
2020-12-07 17:07:26 -04:00
switch ($filter) {
case 'STARTED':
// Scope that search for the STARTED by user
$query->caseStarted();
break;
case 'IN_PROGRESS':
// Scope that search for the TO_DO
$query->selectRaw(
'CONCAT(
2020-11-25 18:11:22 -04:00
\'[\',
GROUP_CONCAT(
CONCAT(
\'{"tas_id":\',
APP_DELEGATION.TAS_ID,
\', "user_id":\',
APP_DELEGATION.USR_ID,
\', "due_date":"\',
APP_DELEGATION.DEL_TASK_DUE_DATE,
\'"}\'
)
),
\']\'
) AS PENDING'
2020-12-07 17:07:26 -04:00
);
// Only cases in progress
$query->caseInProgress();
// Group by AppNumber
$query->groupBy('APP_NUMBER');
break;
case 'COMPLETED':
// Scope that search for the COMPLETED
$query->caseCompleted();
// Scope to set the last thread
$query->lastThread();
break;
2020-10-21 16:56:11 -04:00
}
2020-11-25 18:11:22 -04:00
/** Apply filters */
$this->filters($query);
/** Apply order and pagination */
2020-10-21 16:56:11 -04:00
// The order by clause
$query->orderBy($this->getOrderByColumn(), $this->getOrderDirection());
// The limit by clause
$query->offset($this->getOffset())->limit($this->getLimit());
//Execute the query
2020-11-11 10:38:08 -04:00
$results = $query->get();
// Prepare the result
2020-11-25 18:11:22 -04:00
$results->transform(function ($item, $key) use ($filter) {
2020-11-11 10:38:08 -04:00
// Apply the date format defined in environment
2020-11-25 18:11:22 -04:00
$item['APP_CREATE_DATE_LABEL'] = !empty($item['APP_CREATE_DATE']) ? applyMaskDateEnvironment($item['APP_CREATE_DATE']): null;
$item['APP_FINISH_DATE_LABEL'] = !empty($item['APP_FINISH_DATE']) ? applyMaskDateEnvironment($item['APP_FINISH_DATE']): null;
2020-11-11 10:38:08 -04:00
// Calculate duration
2020-11-25 18:11:22 -04:00
$startDate = (string)$item['APP_CREATE_DATE'];
$endDate = !empty($item['APP_FINISH_DATE']) ? $item['APP_FINISH_DATE'] : date("Y-m-d H:i:s");
2020-11-11 10:38:08 -04:00
$item['DURATION'] = getDiffBetweenDates($startDate, $endDate);
2020-12-16 17:47:42 -04:00
// Get total case notes
$item['CASE_NOTES_COUNT'] = AppNotes::total($item['APP_NUMBER']);
2020-12-15 11:37:58 -04:00
// Define data according to the filters
2020-11-25 18:11:22 -04:00
switch ($filter) {
case 'STARTED':
$result = [];
$i = 0;
if ($item['APP_STATUS'] === 'TO_DO') {
$taskPending = Delegation::getPendingThreads($item['APP_NUMBER']);
foreach ($taskPending as $thread) {
// todo this need to review
$result[$i]['tas_title'] = $thread['TAS_TITLE'];
$result[$i]['user_id'] = $thread['USR_ID'];
$result[$i]['due_date'] = $thread['DEL_TASK_DUE_DATE'];
2021-01-12 15:53:54 -04:00
$result[$i]['delay'] = getDiffBetweenDates($thread['DEL_TASK_DUE_DATE'], date("Y-m-d H:i:s"));
2020-12-16 17:47:42 -04:00
$result[$i]['tas_color'] = (!empty($thread['DEL_TASK_DUE_DATE'])) ? $this->getTaskColor($thread['DEL_TASK_DUE_DATE']) : '';
$result[$i]['tas_color_label'] = (!empty($result[$i]['tas_color'])) ? self::TASK_COLORS[$result[$i]['tas_color']] : '';
2021-01-19 09:39:18 -04:00
$result[$i]['tas_status'] = self::TASK_STATUS[$result[$i]['tas_color']];
2021-01-13 12:41:53 -04:00
// Get the user tooltip information
2021-01-14 09:53:58 -04:00
$result[$i]['user_tooltip'] = User::getInformation($thread['USR_ID']);
2020-11-25 18:11:22 -04:00
$i++;
}
$item['PENDING'] = $result;
} else {
$result[$i]['tas_title'] = $item['TAS_TITLE'];
$result[$i]['user_id'] = $item['USR_ID'];
$result[$i]['due_date'] = $item['DEL_TASK_DUE_DATE'];
2021-01-12 15:53:54 -04:00
$result[$i]['delay'] = getDiffBetweenDates($item['DEL_TASK_DUE_DATE'], date("Y-m-d H:i:s"));
2020-12-18 12:27:28 -04:00
$result[$i]['tas_color'] = (!empty($item['DEL_TASK_DUE_DATE'])) ? $this->getTaskColor($item['DEL_TASK_DUE_DATE']) : '';
2020-12-16 17:47:42 -04:00
$result[$i]['tas_color_label'] = (!empty($result[$i]['tas_color'])) ? self::TASK_COLORS[$result[$i]['tas_color']] : '';
2021-01-19 09:39:18 -04:00
$result[$i]['tas_status'] = self::TASK_STATUS[$result[$i]['tas_color']];
2021-01-13 12:41:53 -04:00
// Get the user tooltip information
2021-01-14 09:53:58 -04:00
$result[$i]['user_tooltip'] = User::getInformation($item['USR_ID']);
2020-11-25 18:11:22 -04:00
$item['PENDING'] = $result;
}
break;
case 'IN_PROGRESS':
2020-12-09 19:04:05 -04:00
// Get the detail related to the open thread
if (!empty($item['PENDING'])) {
2020-12-15 11:37:58 -04:00
$result = $this->prepareTaskPending($item['PENDING']);
$item['PENDING'] = !empty($result['THREAD_TASKS']) ? $result['THREAD_TASKS'] : [];
2020-12-09 19:04:05 -04:00
}
2020-11-25 18:11:22 -04:00
break;
case 'COMPLETED':
$result = [];
$i = 0;
$result[$i]['tas_title'] = $item['TAS_TITLE'];
$result[$i]['user_id'] = $item['USR_ID'];
$result[$i]['due_date'] = $item['DEL_TASK_DUE_DATE'];
2021-01-12 15:53:54 -04:00
$result[$i]['delay'] = getDiffBetweenDates($item['DEL_TASK_DUE_DATE'], date("Y-m-d H:i:s"));
2020-12-18 12:27:28 -04:00
$result[$i]['tas_color'] = (!empty($item['DEL_TASK_DUE_DATE'])) ? $this->getTaskColor($item['DEL_TASK_DUE_DATE']) : '';
2020-12-16 17:47:42 -04:00
$result[$i]['tas_color_label'] = (!empty($result[$i]['tas_color'])) ? self::TASK_COLORS[$result[$i]['tas_color']] : '';
2021-01-19 09:39:18 -04:00
$result[$i]['tas_status'] = self::TASK_STATUS[$result[$i]['tas_color']];
2021-01-13 12:41:53 -04:00
// Get the user tooltip information
2021-01-14 09:53:58 -04:00
$result[$i]['user_tooltip'] = User::getInformation($item['USR_ID']);
2020-11-25 18:11:22 -04:00
$item['PENDING'] = $result;
break;
}
2020-11-11 10:38:08 -04:00
return $item;
});
return $results->values()->toArray();
2020-10-21 16:56:11 -04:00
}
2020-11-11 10:38:08 -04:00
2020-10-21 16:56:11 -04:00
/**
2020-12-14 15:24:08 -04:00
* Get the number of rows corresponding has Participation, does not apply filters
2020-10-21 16:56:11 -04:00
*
* @return int
*/
public function getCounter()
{
2020-12-09 23:21:32 +00:00
// Get base query
2020-10-21 16:56:11 -04:00
$query = Delegation::query()->select();
2020-12-09 23:21:32 +00:00
// Join with application
$query->joinApplication();
2020-10-21 16:56:11 -04:00
// Scope that sets the queries for Participated
$query->participated($this->getUserId());
2020-12-09 23:21:32 +00:00
// Get filter
$filter = $this->getParticipatedStatus();
switch ($filter) {
case 'STARTED':
// Scope that search for the STARTED by user
$query->caseStarted();
break;
case 'IN_PROGRESS':
// Only distinct APP_NUMBER
$query->distinct();
// Scope for in progress cases
2020-12-09 19:04:05 -04:00
$query->statusIds([self::STATUS_DRAFT, self::STATUS_TODO]);
2020-12-09 23:21:32 +00:00
break;
case 'COMPLETED':
// Scope that search for the COMPLETED
$query->caseCompleted();
// Scope to set the last thread
$query->lastThread();
break;
}
2020-10-21 16:56:11 -04:00
// Return the number of rows
2020-12-09 23:21:32 +00:00
return $query->count(['APP_DELEGATION.APP_NUMBER']);
2020-10-21 16:56:11 -04:00
}
2020-12-14 15:24:08 -04:00
/**
* Count how many cases the user has Participation, needs to apply filters
*
* @return int
*/
public function getPagingCounters()
{
// Get base query
$query = Delegation::query()->select();
// Join with application
$query->joinApplication();
// Scope that sets the queries for Participated
$query->participated($this->getUserId());
// Get filter
$filter = $this->getParticipatedStatus();
switch ($filter) {
case 'STARTED':
// Scope that search for the STARTED by user
$query->caseStarted();
break;
case 'IN_PROGRESS':
// Only distinct APP_NUMBER
$query->distinct();
// Scope for in progress cases
$query->statusIds([self::STATUS_DRAFT, self::STATUS_TODO]);
break;
case 'COMPLETED':
// Scope that search for the COMPLETED
$query->caseCompleted();
// Scope to set the last thread
$query->lastThread();
break;
}
// Apply filters
$this->filters($query);
// Return the number of rows
return $query->count(['APP_DELEGATION.APP_NUMBER']);
}
}