mirror of
https://github.com/YunoHost-Apps/kanboard_ynh.git
synced 2024-09-03 19:36:17 +02:00
175 lines
5.2 KiB
PHP
175 lines
5.2 KiB
PHP
<?php
|
|
|
|
namespace Kanboard\Controller;
|
|
|
|
use Kanboard\Model\Task as TaskModel;
|
|
|
|
/**
|
|
* Project Analytic controller
|
|
*
|
|
* @package controller
|
|
* @author Frederic Guillot
|
|
*/
|
|
class Analytic extends Base
|
|
{
|
|
/**
|
|
* Show average Lead and Cycle time
|
|
*
|
|
* @access public
|
|
*/
|
|
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->projectDailyStats->getRawMetrics($project['id'], $from, $to),
|
|
'date_format' => $this->config->get('application_date_format'),
|
|
'date_formats' => $this->dateParser->getAvailableFormats($this->dateParser->getDateFormats()),
|
|
'title' => t('Lead and Cycle time for "%s"', $project['name']),
|
|
)));
|
|
}
|
|
|
|
/**
|
|
* Show comparison between actual and estimated hours chart
|
|
*
|
|
* @access public
|
|
*/
|
|
public function compareHours()
|
|
{
|
|
$project = $this->getProject();
|
|
$query = $this->taskFilter->create()->filterByProject($project['id'])->getQuery();
|
|
|
|
$paginator = $this->paginator
|
|
->setUrl('analytic', 'compareHours', array('project_id' => $project['id']))
|
|
->setMax(30)
|
|
->setOrder(TaskModel::TABLE.'.id')
|
|
->setQuery($query)
|
|
->calculate();
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/compare_hours', array(
|
|
'project' => $project,
|
|
'paginator' => $paginator,
|
|
'metrics' => $this->estimatedTimeComparisonAnalytic->build($project['id']),
|
|
'title' => t('Compare hours for "%s"', $project['name']),
|
|
)));
|
|
}
|
|
|
|
/**
|
|
* Show average time spent by column
|
|
*
|
|
* @access public
|
|
*/
|
|
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 spent into each column for "%s"', $project['name']),
|
|
)));
|
|
}
|
|
|
|
/**
|
|
* Show tasks distribution graph
|
|
*
|
|
* @access public
|
|
*/
|
|
public function tasks()
|
|
{
|
|
$project = $this->getProject();
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/tasks', array(
|
|
'project' => $project,
|
|
'metrics' => $this->taskDistributionAnalytic->build($project['id']),
|
|
'title' => t('Task repartition for "%s"', $project['name']),
|
|
)));
|
|
}
|
|
|
|
/**
|
|
* Show users repartition
|
|
*
|
|
* @access public
|
|
*/
|
|
public function users()
|
|
{
|
|
$project = $this->getProject();
|
|
|
|
$this->response->html($this->helper->layout->analytic('analytic/users', array(
|
|
'project' => $project,
|
|
'metrics' => $this->userDistributionAnalytic->build($project['id']),
|
|
'title' => t('User repartition for "%s"', $project['name']),
|
|
)));
|
|
}
|
|
|
|
/**
|
|
* Show cumulative flow diagram
|
|
*
|
|
* @access public
|
|
*/
|
|
public function cfd()
|
|
{
|
|
$this->commonAggregateMetrics('analytic/cfd', 'total', 'Cumulative flow diagram for "%s"');
|
|
}
|
|
|
|
/**
|
|
* Show burndown chart
|
|
*
|
|
* @access public
|
|
*/
|
|
public function burndown()
|
|
{
|
|
$this->commonAggregateMetrics('analytic/burndown', 'score', 'Burndown chart for "%s"');
|
|
}
|
|
|
|
/**
|
|
* Common method for CFD and Burdown chart
|
|
*
|
|
* @access private
|
|
* @param string $template
|
|
* @param string $column
|
|
* @param string $title
|
|
*/
|
|
private function commonAggregateMetrics($template, $column, $title)
|
|
{
|
|
$project = $this->getProject();
|
|
list($from, $to) = $this->getDates();
|
|
|
|
$display_graph = $this->projectDailyColumnStats->countDays($project['id'], $from, $to) >= 2;
|
|
|
|
$this->response->html($this->helper->layout->analytic($template, array(
|
|
'values' => array(
|
|
'from' => $from,
|
|
'to' => $to,
|
|
),
|
|
'display_graph' => $display_graph,
|
|
'metrics' => $display_graph ? $this->projectDailyColumnStats->getAggregatedMetrics($project['id'], $from, $to, $column) : array(),
|
|
'project' => $project,
|
|
'date_format' => $this->config->get('application_date_format'),
|
|
'date_formats' => $this->dateParser->getAvailableFormats($this->dateParser->getDateFormats()),
|
|
'title' => t($title, $project['name']),
|
|
)));
|
|
}
|
|
|
|
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 = $values['from'];
|
|
$to = $values['to'];
|
|
}
|
|
|
|
return array($from, $to);
|
|
}
|
|
}
|