|
|
<?php |
|
|
|
|
|
namespace Kanboard\Controller; |
|
|
|
|
|
use Kanboard\Filter\TaskProjectFilter; |
|
|
use Kanboard\Model\TaskModel; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class AnalyticController extends BaseController |
|
|
{ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function leadAndCycleTime() |
|
|
{ |
|
|
$project = $this->getProject(); |
|
|
list($from, $to) = $this->getDates(); |
|
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/lead_cycle_time', array( |
|
|
'values' => array( |
|
|
'from' => $from, |
|
|
'to' => $to, |
|
|
), |
|
|
'project' => $project, |
|
|
'average' => $this->averageLeadCycleTimeAnalytic->build($project['id']), |
|
|
'metrics' => $this->projectDailyStatsModel->getRawMetrics($project['id'], $from, $to), |
|
|
'title' => t('Lead and cycle time'), |
|
|
))); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function timeComparison() |
|
|
{ |
|
|
$project = $this->getProject(); |
|
|
|
|
|
$paginator = $this->paginator |
|
|
->setUrl('AnalyticController', 'timeComparison', array('project_id' => $project['id'])) |
|
|
->setMax(30) |
|
|
->setOrder(TaskModel::TABLE.'.id') |
|
|
->setQuery($this->taskQuery |
|
|
->withFilter(new TaskProjectFilter($project['id'])) |
|
|
->getQuery() |
|
|
) |
|
|
->calculate(); |
|
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/time_comparison', array( |
|
|
'project' => $project, |
|
|
'paginator' => $paginator, |
|
|
'metrics' => $this->estimatedTimeComparisonAnalytic->build($project['id']), |
|
|
'title' => t('Estimated vs actual time'), |
|
|
))); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function averageTimeByColumn() |
|
|
{ |
|
|
$project = $this->getProject(); |
|
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/avg_time_columns', array( |
|
|
'project' => $project, |
|
|
'metrics' => $this->averageTimeSpentColumnAnalytic->build($project['id']), |
|
|
'title' => t('Average time into each column'), |
|
|
))); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function taskDistribution() |
|
|
{ |
|
|
$project = $this->getProject(); |
|
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/task_distribution', array( |
|
|
'project' => $project, |
|
|
'metrics' => $this->taskDistributionAnalytic->build($project['id']), |
|
|
'title' => t('Task distribution'), |
|
|
))); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function userDistribution() |
|
|
{ |
|
|
$project = $this->getProject(); |
|
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/user_distribution', array( |
|
|
'project' => $project, |
|
|
'metrics' => $this->userDistributionAnalytic->build($project['id']), |
|
|
'title' => t('User repartition'), |
|
|
))); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function cfd() |
|
|
{ |
|
|
$this->commonAggregateMetrics('analytic/cfd', 'total', t('Cumulative flow diagram')); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function burndown() |
|
|
{ |
|
|
$this->commonAggregateMetrics('analytic/burndown', 'score', t('Burndown chart')); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function estimatedVsActualByColumn() |
|
|
{ |
|
|
$project = $this->getProject(); |
|
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/estimated_actual_column', array( |
|
|
'project' => $project, |
|
|
'metrics' => $this->estimatedActualColumnAnalytic->build($project['id']), |
|
|
'title' => t('Estimated vs actual time per column'), |
|
|
))); |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private function commonAggregateMetrics($template, $column, $title) |
|
|
{ |
|
|
$project = $this->getProject(); |
|
|
list($from, $to) = $this->getDates(); |
|
|
|
|
|
$displayGraph = $this->projectDailyColumnStatsModel->countDays($project['id'], $from, $to) >= 2; |
|
|
$metrics = $displayGraph ? $this->projectDailyColumnStatsModel->getAggregatedMetrics($project['id'], $from, $to, $column) : array(); |
|
|
|
|
|
$this->response->html($this->helper->layout->analytic($template, array( |
|
|
'values' => array( |
|
|
'from' => $from, |
|
|
'to' => $to, |
|
|
), |
|
|
'display_graph' => $displayGraph, |
|
|
'metrics' => $metrics, |
|
|
'project' => $project, |
|
|
'title' => $title, |
|
|
))); |
|
|
} |
|
|
|
|
|
private function getDates() |
|
|
{ |
|
|
$values = $this->request->getValues(); |
|
|
|
|
|
$from = $this->request->getStringParam('from', date('Y-m-d', strtotime('-1week'))); |
|
|
$to = $this->request->getStringParam('to', date('Y-m-d')); |
|
|
|
|
|
if (! empty($values)) { |
|
|
$from = $this->dateParser->getIsoDate($values['from']); |
|
|
$to = $this->dateParser->getIsoDate($values['to']); |
|
|
} |
|
|
|
|
|
return array($from, $to); |
|
|
} |
|
|
} |
|
|
|