Merge pull-request #1012
This commit is contained in:
@@ -340,10 +340,11 @@ class TaskFilter extends Base
|
||||
$this->query->beginOr();
|
||||
|
||||
foreach ($values as $assignee) {
|
||||
|
||||
$subtaskQuery = $this->buildSubtaskQuery();
|
||||
switch ($assignee) {
|
||||
case 'me':
|
||||
$this->query->eq(Task::TABLE.'.owner_id', $this->userSession->getId());
|
||||
$subtaskQuery->eq(Subtask::TABLE.'.user_id',$this->userSession->getId() );
|
||||
break;
|
||||
case 'nobody':
|
||||
$this->query->eq(Task::TABLE.'.owner_id', 0);
|
||||
@@ -351,6 +352,14 @@ class TaskFilter extends Base
|
||||
default:
|
||||
$this->query->ilike(User::TABLE.'.username', '%'.$assignee.'%');
|
||||
$this->query->ilike(User::TABLE.'.name', '%'.$assignee.'%');
|
||||
$subtaskQuery->beginOr();
|
||||
$subtaskQuery->ilike(User::TABLE.'.username', '%'.$assignee.'%');
|
||||
$subtaskQuery->ilike(User::TABLE.'.name', '%'.$assignee.'%');
|
||||
$subtaskQuery->closeOr();
|
||||
}
|
||||
if ($assignee != 'nobody'){
|
||||
$subtasks = $subtaskQuery->findAll();
|
||||
$this->addTasksWithFoundSubtask($subtasks);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -787,4 +796,23 @@ class TaskFilter extends Base
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
private function buildSubtaskQuery(){
|
||||
return $this->db->table(Subtask::TABLE)
|
||||
->columns(
|
||||
Subtask::TABLE.'.user_id',
|
||||
Subtask::TABLE.'.task_id',
|
||||
User::TABLE.'.name',
|
||||
User::TABLE.'.username')
|
||||
->join(User::TABLE, 'id', 'user_id', Subtask::TABLE)
|
||||
->neq(Subtask::TABLE.'.status', Subtask::STATUS_DONE);
|
||||
|
||||
}
|
||||
|
||||
private function addTasksWithFoundSubtask($subtasks) {
|
||||
foreach ($subtasks as $subtask) {
|
||||
$this->query->eq(Task::TABLE.'.id',$subtask['task_id']);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user