Task age and time spent in one column.
Details: https://github.com/fguillot/kanboard/issues/608
This commit is contained in:
parent
efbf679385
commit
59ee6f9fee
|
|
@ -62,6 +62,7 @@ class TaskCreation extends Base
|
|||
$values['swimlane_id'] = empty($values['swimlane_id']) ? 0 : $values['swimlane_id'];
|
||||
$values['date_creation'] = time();
|
||||
$values['date_modification'] = $values['date_creation'];
|
||||
$values['date_moved'] = $values['date_creation'];
|
||||
$values['position'] = $this->taskFinder->countByColumnAndSwimlaneId($values['project_id'], $values['column_id'], $values['swimlane_id']) + 1;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -102,6 +102,7 @@ class TaskFinder extends Base
|
|||
'tasks.is_active',
|
||||
'tasks.score',
|
||||
'tasks.category_id',
|
||||
'tasks.date_moved',
|
||||
'users.username AS assignee_username',
|
||||
'users.name AS assignee_name'
|
||||
)
|
||||
|
|
@ -242,6 +243,7 @@ class TaskFinder extends Base
|
|||
tasks.score,
|
||||
tasks.category_id,
|
||||
tasks.swimlane_id,
|
||||
tasks.date_moved,
|
||||
project_has_categories.name AS category_name,
|
||||
projects.name AS project_name,
|
||||
columns.title AS column_title,
|
||||
|
|
|
|||
|
|
@ -30,7 +30,10 @@ class TaskPosition extends Base
|
|||
$result = $this->calculateAndSave($project_id, $task_id, $column_id, $position, $swimlane_id);
|
||||
|
||||
if ($result) {
|
||||
|
||||
if ($original_task['column_id'] != $column_id) {
|
||||
$this->db->table(Task::TABLE)->eq('id', $task_id)->update(array('date_moved' => time(),
|
||||
));
|
||||
}
|
||||
if ($original_task['swimlane_id'] != $swimlane_id) {
|
||||
$this->calculateAndSave($project_id, 0, $column_id, 1, $original_task['swimlane_id']);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -5,7 +5,38 @@ namespace Schema;
|
|||
use PDO;
|
||||
use Core\Security;
|
||||
|
||||
const VERSION = 44;
|
||||
const VERSION = 45;
|
||||
|
||||
function version_45($pdo)
|
||||
{
|
||||
$pdo->exec('ALTER TABLE tasks ADD COLUMN date_moved INT DEFAULT 0');
|
||||
|
||||
/* Update tasks.date_moved from project_activities table if tasks.date_moved = null or 0.
|
||||
* We take max project_activities.date_creation where event_name in task.create','task.move.column
|
||||
* since creation date is always less than task moves
|
||||
*/
|
||||
$pdo->exec("UPDATE tasks
|
||||
SET date_moved = (
|
||||
SELECT md
|
||||
FROM (
|
||||
SELECT task_id, max(date_creation) md
|
||||
FROM project_activities
|
||||
WHERE event_name IN ('task.create', 'task.move.column')
|
||||
GROUP BY task_id
|
||||
) src
|
||||
WHERE id = src.task_id
|
||||
)
|
||||
WHERE (date_moved IS NULL OR date_moved = 0) AND id IN (
|
||||
SELECT task_id
|
||||
FROM (
|
||||
SELECT task_id, max(date_creation) md
|
||||
FROM project_activities
|
||||
WHERE event_name IN ('task.create', 'task.move.column')
|
||||
GROUP BY task_id
|
||||
) src
|
||||
)
|
||||
");
|
||||
}
|
||||
|
||||
function version_44($pdo)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -5,7 +5,38 @@ namespace Schema;
|
|||
use PDO;
|
||||
use Core\Security;
|
||||
|
||||
const VERSION = 25;
|
||||
const VERSION = 26;
|
||||
|
||||
function version_26($pdo)
|
||||
{
|
||||
$pdo->exec('ALTER TABLE tasks ADD COLUMN date_moved INT DEFAULT 0');
|
||||
|
||||
/* Update tasks.date_moved from project_activities table if tasks.date_moved = null or 0.
|
||||
* We take max project_activities.date_creation where event_name in task.create','task.move.column
|
||||
* since creation date is always less than task moves
|
||||
*/
|
||||
$pdo->exec("UPDATE tasks
|
||||
SET date_moved = (
|
||||
SELECT md
|
||||
FROM (
|
||||
SELECT task_id, max(date_creation) md
|
||||
FROM project_activities
|
||||
WHERE event_name IN ('task.create', 'task.move.column')
|
||||
GROUP BY task_id
|
||||
) src
|
||||
WHERE id = src.task_id
|
||||
)
|
||||
WHERE (date_moved IS NULL OR date_moved = 0) AND id IN (
|
||||
SELECT task_id
|
||||
FROM (
|
||||
SELECT task_id, max(date_creation) md
|
||||
FROM project_activities
|
||||
WHERE event_name IN ('task.create', 'task.move.column')
|
||||
GROUP BY task_id
|
||||
) src
|
||||
)
|
||||
");
|
||||
}
|
||||
|
||||
function version_25($pdo)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -5,7 +5,38 @@ namespace Schema;
|
|||
use Core\Security;
|
||||
use PDO;
|
||||
|
||||
const VERSION = 43;
|
||||
const VERSION = 44;
|
||||
|
||||
function version_44($pdo)
|
||||
{
|
||||
$pdo->exec('ALTER TABLE tasks ADD COLUMN date_moved INTEGER DEFAULT 0');
|
||||
|
||||
/* Update tasks.date_moved from project_activities table if tasks.date_moved = null or 0.
|
||||
* We take max project_activities.date_creation where event_name in task.create','task.move.column
|
||||
* since creation date is always less than task moves
|
||||
*/
|
||||
$pdo->exec("UPDATE tasks
|
||||
SET date_moved = (
|
||||
SELECT md
|
||||
FROM (
|
||||
SELECT task_id, max(date_creation) md
|
||||
FROM project_activities
|
||||
WHERE event_name IN ('task.create', 'task.move.column')
|
||||
GROUP BY task_id
|
||||
) src
|
||||
WHERE id = src.task_id
|
||||
)
|
||||
WHERE (date_moved IS NULL OR date_moved = 0) AND id IN (
|
||||
SELECT task_id
|
||||
FROM (
|
||||
SELECT task_id, max(date_creation) md
|
||||
FROM project_activities
|
||||
WHERE event_name IN ('task.create', 'task.move.column')
|
||||
GROUP BY task_id
|
||||
) src
|
||||
)
|
||||
");
|
||||
}
|
||||
|
||||
function version_43($pdo)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -68,7 +68,10 @@
|
|||
t('Change assignee')
|
||||
) ?>
|
||||
</span>
|
||||
|
||||
|
||||
<span title="<?= t('Task age in days')?>" class="task-days-age"><?= floor(time()/86400) - floor($task['date_creation']/86400)?>d</span>
|
||||
<span title="<?= t('Days in this column')?>" class="task-days-incolumn"><?= floor(time()/86400) - floor($task['date_moved']/86400)?>d</span>
|
||||
|
||||
<?php if ($task['score']): ?>
|
||||
<span class="task-score"><?= $this->e($task['score']) ?></span>
|
||||
<?php endif ?>
|
||||
|
|
|
|||
|
|
@ -1631,6 +1631,26 @@ a.task-board-nobody {
|
|||
margin-bottom: 25px;
|
||||
padding: 3px;
|
||||
}
|
||||
|
||||
.task-days-age {
|
||||
font-size: 0.8em;
|
||||
border: #888 1px solid;
|
||||
border-radius:2px;
|
||||
padding:1px 4px 1px 2px;
|
||||
border-top-left-radius: 3px;
|
||||
border-bottom-left-radius: 3px;
|
||||
}
|
||||
|
||||
.task-days-incolumn {
|
||||
font-size: 0.8em;
|
||||
border: #888 1px solid;
|
||||
border-left: none;
|
||||
margin-left: -5px;
|
||||
border-radius:2px;
|
||||
padding:1px 2px 1px 4px;
|
||||
border-top-right-radius: 3px;
|
||||
border-bottom-right-radius: 3px;
|
||||
}
|
||||
/* comments */
|
||||
.comment {
|
||||
margin-bottom: 20px;
|
||||
|
|
|
|||
|
|
@ -205,3 +205,23 @@ a.task-board-nobody {
|
|||
margin-bottom: 25px;
|
||||
padding: 3px;
|
||||
}
|
||||
|
||||
.task-days-age {
|
||||
font-size: 0.8em;
|
||||
border: #888 1px solid;
|
||||
border-radius:2px;
|
||||
padding:1px 4px 1px 2px;
|
||||
border-top-left-radius: 3px;
|
||||
border-bottom-left-radius: 3px;
|
||||
}
|
||||
|
||||
.task-days-incolumn {
|
||||
font-size: 0.8em;
|
||||
border: #888 1px solid;
|
||||
border-left: none;
|
||||
margin-left: -5px;
|
||||
border-radius:2px;
|
||||
padding:1px 2px 1px 4px;
|
||||
border-top-right-radius: 3px;
|
||||
border-bottom-right-radius: 3px;
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue