* @package report * @version $Id$ * @link http://www.zentao.net */ ?> app->getWebRoot() . 'fusioncharts/'; $swfFile = "fcf_$swf.swf"; return << EOT; } /** * Create the js code of chart. * * @param string $swf the swf type * @param string $dataURL the date url * @param int $width * @param int $height * @access public * @return string */ public function createJSChart($swf, $dataXML, $width = 'auto', $height = 500) { $jsRoot = $this->app->getWebRoot() . 'js/'; static $count = 0; $count ++; $chartRoot = $this->app->getWebRoot() . 'fusioncharts/'; $swfFile = "fcf_$swf.swf"; $divID = "chart{$count}div"; $chartID = "chart{$count}"; $js = ''; if($count == 1) $js = ""; return << EOT; } public function createJSChartFlot($projectName, $flotJSON, $count, $width = 'auto', $height = 500) { $this->app->loadLang('project'); $this->app->loadConfig('project'); $jsRoot = $this->app->getWebRoot() . 'js/'; $width = $width . 'px'; $height = $height . 'px'; $maxDays = $this->config->project->maxBurnDay; $dataJSON = $flotJSON['data']; $limitJSON = $flotJSON['limit']; $reflineJSON = $flotJSON['refline']; return <<

$projectName {$this->lang->project->burn}

EOT; } /** * Create xml data of single charts. * * @param array $sets * @param array $chartOptions * @param array $colors * @access public * @return string the xml data. */ public function createSingleXML($sets, $chartOptions = array(), $colors = array()) { $data = pack("CCC", 0xef, 0xbb, 0xbf); // utf-8 bom. $data .=""; $data .= ' $value) $data .= " $key='$value'"; $data .= ">"; if(empty($colors)) $colors = $this->lang->report->colors; $colorCount = count($colors); $i = 0; foreach($sets as $set) { if($i == $colorCount) $i = 0; $color = $colors[$i]; $i ++; $data .= ""; } $data .= ""; return $data; } public function createSingleJSON($sets) { $data = '['; foreach($sets as $set) { $data .= "[$set->name, $set->value],"; } $data = rtrim($data, ','); $data .= ']'; return $data; } /** * Create the js code to render chart. * * @param int $chartCount * @access public * @return string */ public function renderJsCharts($chartCount) { $js = ''; return $js; } /** * Compute percent of every item. * * @param array $datas * @access public * @return array */ public function computePercent($datas) { $sum = 0; foreach($datas as $data) $sum += $data->value; foreach($datas as $data) $data->percent = round($data->value / $sum, 2); return $datas; } /** * Get projects. * * @access public * @return void */ public function getProjects() { $projects = array(); $tasks = $this->dao->select('t1.*') ->from(TABLE_TASK)->alias('t1') ->leftJoin(TABLE_PROJECT)->alias('t2') ->on('t1.project = t2.id') ->where('t1.status')->ne('cancel') ->andWhere('t1.deleted')->eq(0) ->andWhere('t2.deleted')->eq(0) ->fetchAll(); foreach($tasks as $task) { if(!isset($projects[$task->project])) $projects[$task->project] = new stdclass(); $projects[$task->project]->estimate = isset($projects[$task->project]->estimate) ? $projects[$task->project]->estimate + $task->estimate : $task->estimate; $projects[$task->project]->consumed = isset($projects[$task->project]->consumed) ? $projects[$task->project]->consumed + $task->consumed : $task->consumed; $projects[$task->project]->tasks = isset($projects[$task->project]->tasks) ? $projects[$task->project]->tasks + 1 : 1; if($task->type == 'devel') $projects[$task->project]->devConsumed = isset($projects[$task->project]->devConsumed) ? $projects[$task->project]->devConsumed + $task->consumed : $task->consumed; if($task->type == 'test') $projects[$task->project]->testConsumed = isset($projects[$task->project]->testConsumed) ? $projects[$task->project]->testConsumed + $task->consumed : $task->consumed; } $bugs = $this->dao->select('t1.project') ->from(TABLE_BUG)->alias('t1') ->leftJoin(TABLE_PROJECT)->alias('t2') ->on('t1.project = t2.id') ->where('t1.deleted')->eq(0) ->andWhere('t2.deleted')->eq(0) ->fetchAll(); foreach($bugs as $bug) { if($bug->project) { $projects[$bug->project]->bugs = isset($projects[$bug->project]->bugs) ? $projects[$bug->project]->bugs + 1 : 1; } } $stories = $this->dao->select('t1.project') ->from(TABLE_PROJECTSTORY)->alias('t1') ->leftJoin(TABLE_PROJECT)->alias('t2') ->on('t1.project = t2.id') ->leftJoin(TABLE_STORY)->alias('t3') ->on('t1.story = t3.id') ->where('t2.deleted')->eq(0) ->andWhere('t3.deleted')->eq(0) ->fetchAll(); foreach($stories as $story) { if(!isset($projects[$story->project])) $projects[$story->project] = new stdclass(); $projects[$story->project]->stories = isset($projects[$story->project]->stories) ? $projects[$story->project]->stories + 1 : 1; } $projectList = $this->dao->select('id, name, status')->from(TABLE_PROJECT)->fetchAll(); $projectPairs = array(); foreach($projectList as $project) { $projectPairs[$project->id] = $project->name; if($project->status != 'done') unset($projects[$project->id]); } foreach($projects as $id => $project) { if(!isset($projectPairs[$id])) { unset($projects[$id]); continue; } if(!isset($project->stories)) $projects[$id]->stories = 0; if(!isset($project->bugs)) $projects[$id]->bugs = 0; if(!isset($project->devConsumed)) $projects[$id]->devConsumed = 0; if(!isset($project->testConsumed)) $projects[$id]->testConsumed = 0; if(!isset($project->consumed)) $projects[$id]->consumed = 0; if(!isset($project->estimate)) $projects[$id]->estimate = 0; $projects[$id]->name = $projectPairs[$id]; } return $projects; } /** * Get products. * * @access public * @return array */ public function getProducts() { $products = $this->dao->select('id, code, name, PO')->from(TABLE_PRODUCT)->where('deleted')->eq(0)->fetchAll('id'); $plans = $this->dao->select('*')->from(TABLE_PRODUCTPLAN)->where('deleted')->eq(0)->andWhere('product')->in(array_keys($products))->fetchAll('id'); if(!$plans) return array(); foreach($plans as $plan) $products[$plan->product]->plans[$plan->id] = $plan; $planStories = $this->dao->select('plan, id, status')->from(TABLE_STORY)->where('deleted')->eq(0)->andWhere('plan')->in(array_keys($plans))->fetchGroup('plan', 'id'); foreach($planStories as $planID => $stories) { foreach($stories as $story) { $plan = $plans[$story->plan]; $products[$plan->product]->plans[$story->plan]->status[$story->status] = isset($products[$plan->product]->plans[$story->plan]->status[$story->status]) ? $products[$plan->product]->plans[$story->plan]->status[$story->status] + 1 : 1; } } return $products; } /** * Get bugs * * @param int $begin * @param int $end * @access public * @return array */ public function getBugs($begin, $end) { $end = date('Ymd', strtotime("$end +1 day")); $bugs = $this->dao->select('id, resolution, openedBy')->from(TABLE_BUG) ->where('deleted')->eq(0) ->andWhere('openedDate')->ge($begin) ->andWhere('openedDate')->le($end) ->fetchAll(); $bugSummary = array(); foreach($bugs as $bug) { $bugSummary[$bug->openedBy][$bug->resolution] = empty($bugSummary[$bug->openedBy][$bug->resolution]) ? 1 : $bugSummary[$bug->openedBy][$bug->resolution] + 1; $bugSummary[$bug->openedBy]['all'] = empty($bugSummary[$bug->openedBy]['all']) ? 1 : $bugSummary[$bug->openedBy]['all'] + 1; } return $bugSummary; } /** * Get workload. * * @access public * @return array */ public function getWorkload() { $tasks = $this->dao->select('t1.*, t2.name as projectName') ->from(TABLE_TASK)->alias('t1') ->leftJoin(TABLE_PROJECT)->alias('t2') ->on('t1.project = t2.id') ->where('t1.deleted')->eq(0) ->andWhere('t1.status')->notin('cancel, closed, done') ->andWhere('t2.deleted')->eq(0) ->fetchGroup('assignedTo'); $workload = array(); foreach($tasks as $user => $userTasks) { if($user) { foreach($userTasks as $task) { $workload[$user]['task'][$task->projectName]['count'] = isset($workload[$user]['task'][$task->projectName]['count']) ? $workload[$user]['task'][$task->projectName]['count'] + 1 : 1; $workload[$user]['task'][$task->projectName]['manhour'] = isset($workload[$user]['task'][$task->projectName]['manhour']) ? $workload[$user]['task'][$task->projectName]['manhour'] + $task->left : $task->left; $workload[$user]['total']['count'] = isset($workload[$user]['total']['count']) ? $workload[$user]['total']['count'] + 1 : 1; $workload[$user]['total']['manhour'] = isset($workload[$user]['total']['manhour']) ? $workload[$user]['total']['manhour'] + $task->left : $task->left; } } } unset($workload['closed']); return $workload; } /** * Get bug assign. * * @access public * @return array */ public function getBugAssign() { $bugs = $this->dao->select('t1.*, t2.name as productName') ->from(TABLE_BUG)->alias('t1') ->leftJoin(TABLE_PRODUCT)->alias('t2') ->on('t1.product = t2.id') ->where('t1.deleted')->eq(0) ->andWhere('t1.status')->eq('active') ->andWhere('t2.deleted')->eq(0) ->fetchGroup('assignedTo'); $assign = array(); foreach($bugs as $user => $userBugs) { if($user) { foreach($userBugs as $bug) { $assign[$user]['bug'][$bug->productName]['count'] = isset($assign[$user]['bug'][$bug->productName]['count']) ? $assign[$user]['bug'][$bug->productName]['count'] + 1 : 1; $assign[$user]['total']['count'] = isset($assign[$user]['total']['count']) ? $assign[$user]['total']['count'] + 1 : 1; } } } unset($assign['closed']); return $assign; } }