868 lines
33 KiB
PHP
868 lines
33 KiB
PHP
<?php
|
|
/**
|
|
* The control file of task module of ZenTaoPMS.
|
|
*
|
|
* @copyright Copyright 2009-2011 青岛易软天创网络科技有限公司 (QingDao Nature Easy Soft Network Technology Co,LTD www.cnezsoft.com)
|
|
* @license LGPL (http://www.gnu.org/licenses/lgpl.html)
|
|
* @author Chunsheng Wang <chunsheng@cnezsoft.com>
|
|
* @package task
|
|
* @version $Id$
|
|
* @link http://www.zentao.net
|
|
*/
|
|
class task extends control
|
|
{
|
|
/**
|
|
* Construct function, load model of project and story modules.
|
|
*
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->loadModel('project');
|
|
$this->loadModel('story');
|
|
}
|
|
|
|
/**
|
|
* Create a task.
|
|
*
|
|
* @param int $projectID
|
|
* @param int $storyID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function create($projectID = 0, $storyID = 0)
|
|
{
|
|
$project = $this->project->getById($projectID);
|
|
$taskLink = $this->createLink('project', 'browse', "projectID=$projectID&tab=task");
|
|
$storyLink = $this->session->storyList ? $this->session->storyList : $this->createLink('project', 'story', "projectID=$projectID");
|
|
$this->view->users = $this->loadModel('user')->getPairs('noletter');
|
|
|
|
/* Set menu. */
|
|
$this->project->setMenu($this->project->getPairs(), $project->id);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$tasksID = $this->task->create($projectID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
/* Create actions. */
|
|
$this->loadModel('action');
|
|
foreach($tasksID as $taskID)
|
|
{
|
|
$actionID = $this->action->create('task', $taskID, 'Opened', '');
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
|
|
/* Locate the browser. */
|
|
if($this->post->after == 'continueAdding')
|
|
{
|
|
echo js::alert($this->lang->task->successSaved . $this->lang->task->afterChoices['continueAdding']);
|
|
die(js::locate($this->createLink('task', 'create', "projectID=$projectID&storyID={$this->post->story}"), 'parent'));
|
|
}
|
|
elseif($this->post->after == 'toTastList')
|
|
{
|
|
die(js::locate($taskLink, 'parent'));
|
|
}
|
|
elseif($this->post->after == 'toStoryList')
|
|
{
|
|
die(js::locate($storyLink, 'parent'));
|
|
}
|
|
}
|
|
|
|
$stories = $this->story->getProjectStoryPairs($projectID);
|
|
$members = $this->project->getTeamMemberPairs($projectID, 'nodeleted');
|
|
$header['title'] = $project->name . $this->lang->colon . $this->lang->task->create;
|
|
$position[] = html::a($taskLink, $project->name);
|
|
$position[] = $this->lang->task->create;
|
|
|
|
$this->view->header = $header;
|
|
$this->view->position = $position;
|
|
$this->view->project = $project;
|
|
$this->view->stories = $stories;
|
|
$this->view->storyID = $storyID;
|
|
$this->view->members = $members;
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Create a task.
|
|
*
|
|
* @param int $projectID
|
|
* @param int $storyID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function batchCreate($projectID = 0, $storyID = 0)
|
|
{
|
|
$project = $this->project->getById($projectID);
|
|
$taskLink = $this->createLink('project', 'browse', "projectID=$projectID&tab=task");
|
|
$storyLink = $this->session->storyList ? $this->session->storyList : $this->createLink('project', 'story', "projectID=$projectID");
|
|
$this->view->users = $this->loadModel('user')->getPairs('noletter');
|
|
|
|
/* Set menu. */
|
|
$this->project->setMenu($this->project->getPairs(), $project->id);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$mails = $this->task->batchCreate($projectID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
foreach($mails as $mail)
|
|
{
|
|
$this->sendmail($mail->taskID, $mail->actionID);
|
|
}
|
|
|
|
/* Locate the browser. */
|
|
die(js::locate($taskLink, 'parent'));
|
|
}
|
|
|
|
$stories = $this->story->getProjectStoryPairs($projectID);
|
|
$stories['same'] = $this->lang->task->same;
|
|
$members = $this->project->getTeamMemberPairs($projectID, 'nodeleted');
|
|
$header['title'] = $project->name . $this->lang->colon . $this->lang->task->create;
|
|
$position[] = html::a($taskLink, $project->name);
|
|
$position[] = $this->lang->task->create;
|
|
|
|
$this->view->header = $header;
|
|
$this->view->position = $position;
|
|
$this->view->project = $project;
|
|
$this->view->stories = $stories;
|
|
$this->view->storyID = $storyID;
|
|
$this->view->members = $members;
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Common actions of task module.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function commonAction($taskID)
|
|
{
|
|
$this->view->task = $this->task->getByID($taskID);
|
|
$this->view->project = $this->project->getById($this->view->task->project);
|
|
$this->view->members = $this->project->getTeamMemberPairs($this->view->project->id ,'nodeleted');
|
|
$this->view->users = $this->loadModel('user')->getPairs('noletter');
|
|
$this->view->actions = $this->loadModel('action')->getList('task', $taskID);
|
|
|
|
/* Set menu. */
|
|
$this->project->setMenu($this->project->getPairs(), $this->view->project->id);
|
|
$this->view->position[] = html::a($this->createLink('project', 'browse', "project={$this->view->task->project}"), $this->view->project->name);
|
|
|
|
}
|
|
|
|
/**
|
|
* Edit a task.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function edit($taskID)
|
|
{
|
|
$this->commonAction($taskID);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$this->loadModel('action');
|
|
$changes = $this->task->update($taskID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
$files = $this->loadModel('file')->saveUpload('task', $taskID);
|
|
|
|
if($this->post->comment != '' or !empty($changes) or !empty($files))
|
|
{
|
|
$action = !empty($changes) ? 'Edited' : 'Commented';
|
|
$fileAction = '';
|
|
if(!empty($files)) $fileAction = $this->lang->addFiles . join(',', $files) . "\n" ;
|
|
$actionID = $this->action->create('task', $taskID, $action, $fileAction . $this->post->comment);
|
|
$this->action->logHistory($actionID, $changes);
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
die(js::locate($this->createLink('task', 'view', "taskID=$taskID"), 'parent'));
|
|
}
|
|
|
|
$this->view->header->title = $this->lang->task->edit;
|
|
$this->view->position[] = $this->lang->task->edit;
|
|
$this->view->stories = $this->story->getProjectStoryPairs($this->view->project->id);
|
|
$this->view->members = $this->loadModel('user')->appendDeleted($this->view->members, $this->view->task->assignedTo);
|
|
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* View a task.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function view($taskID)
|
|
{
|
|
$task = $this->task->getById($taskID);
|
|
if(!$task) die(js::error($this->lang->notFound) . js::locate('back'));
|
|
|
|
/* Set menu. */
|
|
$project = $this->project->getById($task->project);
|
|
$this->project->setMenu($this->project->getPairs(), $project->id);
|
|
|
|
$header['title'] = $project->name . $this->lang->colon . $this->lang->task->view;
|
|
$position[] = html::a($this->createLink('project', 'browse', "projectID=$task->project"), $project->name);
|
|
$position[] = $this->lang->task->view;
|
|
|
|
$this->view->header = $header;
|
|
$this->view->position = $position;
|
|
$this->view->project = $project;
|
|
$this->view->task = $task;
|
|
$this->view->actions = $this->loadModel('action')->getList('task', $taskID);
|
|
$this->view->users = $this->loadModel('user')->getPairs('noletter');
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Confirm story change
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function confirmStoryChange($taskID)
|
|
{
|
|
$task = $this->task->getById($taskID);
|
|
$this->dao->update(TABLE_TASK)->set('storyVersion')->eq($task->latestStoryVersion)->where('id')->eq($taskID)->exec();
|
|
$this->loadModel('action')->create('task', $taskID, 'confirmed', '', $task->latestStoryVersion);
|
|
die(js::reload('parent'));
|
|
}
|
|
|
|
/**
|
|
* Start a task.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function start($taskID)
|
|
{
|
|
$this->commonAction($taskID);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$this->loadModel('action');
|
|
$changes = $this->task->start($taskID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
if($this->post->comment != '' or !empty($changes))
|
|
{
|
|
$actionID = $this->action->create('task', $taskID, 'Started', $this->post->comment);
|
|
$this->action->logHistory($actionID, $changes);
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
die(js::locate($this->createLink('task', 'view', "taskID=$taskID"), 'parent'));
|
|
}
|
|
|
|
$this->view->header->title = $this->view->project->name . $this->lang->colon .$this->lang->task->start;
|
|
$this->view->position[] = $this->lang->task->start;
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Finish a task.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function finish($taskID)
|
|
{
|
|
$this->commonAction($taskID);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$this->loadModel('action');
|
|
$changes = $this->task->finish($taskID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
if($this->post->comment != '' or !empty($changes))
|
|
{
|
|
$actionID = $this->action->create('task', $taskID, 'Finished', $this->post->comment);
|
|
$this->action->logHistory($actionID, $changes);
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
die(js::locate($this->createLink('task', 'view', "taskID=$taskID"), 'parent'));
|
|
}
|
|
|
|
$this->view->header->title = $this->view->project->name . $this->lang->colon .$this->lang->task->finish;
|
|
$this->view->position[] = $this->lang->task->finish;
|
|
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Close a task.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function close($taskID)
|
|
{
|
|
$this->commonAction($taskID);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$this->loadModel('action');
|
|
$changes = $this->task->close($taskID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
if($this->post->comment != '' or !empty($changes))
|
|
{
|
|
$actionID = $this->action->create('task', $taskID, 'Closed', $this->post->comment);
|
|
$this->action->logHistory($actionID, $changes);
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
die(js::locate($this->createLink('task', 'view', "taskID=$taskID"), 'parent'));
|
|
}
|
|
|
|
$this->view->header->title = $this->view->project->name . $this->lang->colon .$this->lang->task->finish;
|
|
$this->view->position[] = $this->lang->task->finish;
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
/**
|
|
* Batch close tasks.
|
|
*
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function batchClose()
|
|
{
|
|
if($this->post->tasks)
|
|
{
|
|
$tasks = $this->post->tasks;
|
|
unset($_POST['tasks']);
|
|
$this->loadModel('action');
|
|
|
|
foreach($tasks as $taskID)
|
|
{
|
|
$this->commonAction($taskID);
|
|
$task = $this->task->getById($taskID);
|
|
if($task->status == 'wait' or $task->status == 'doing') continue;
|
|
|
|
$changes = $this->task->close($taskID);
|
|
|
|
if($changes)
|
|
{
|
|
$actionID = $this->action->create('task', $taskID, 'Closed', '');
|
|
$this->action->logHistory($actionID, $changes);
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
}
|
|
}
|
|
die(js::reload('parent'));
|
|
}
|
|
|
|
/**
|
|
* Cancel a task.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function cancel($taskID)
|
|
{
|
|
$this->commonAction($taskID);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$this->loadModel('action');
|
|
$changes = $this->task->cancel($taskID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
if($this->post->comment != '' or !empty($changes))
|
|
{
|
|
$actionID = $this->action->create('task', $taskID, 'Canceled', $this->post->comment);
|
|
$this->action->logHistory($actionID, $changes);
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
die(js::locate($this->createLink('task', 'view', "taskID=$taskID"), 'parent'));
|
|
}
|
|
|
|
$this->view->header->title = $this->view->project->name . $this->lang->colon .$this->lang->task->cancel;
|
|
$this->view->position[] = $this->lang->task->cancel;
|
|
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Activate a task.
|
|
*
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function activate($taskID)
|
|
{
|
|
$this->commonAction($taskID);
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
$this->loadModel('action');
|
|
$changes = $this->task->activate($taskID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
if($this->post->comment != '' or !empty($changes))
|
|
{
|
|
$actionID = $this->action->create('task', $taskID, 'Activated', $this->post->comment);
|
|
$this->action->logHistory($actionID, $changes);
|
|
$this->sendmail($taskID, $actionID);
|
|
}
|
|
die(js::locate($this->createLink('task', 'view', "taskID=$taskID"), 'parent'));
|
|
}
|
|
|
|
$this->view->header->title = $this->view->project->name . $this->lang->colon .$this->lang->task->activate;
|
|
$this->view->position[] = $this->lang->task->activate;
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Delete a task.
|
|
*
|
|
* @param int $projectID
|
|
* @param int $taskID
|
|
* @param string $confirm yes|no
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function delete($projectID, $taskID, $confirm = 'no')
|
|
{
|
|
if($confirm == 'no')
|
|
{
|
|
die(js::confirm($this->lang->task->confirmDelete, inlink('delete', "projectID=$projectID&taskID=$taskID&confirm=yes")));
|
|
}
|
|
else
|
|
{
|
|
$story = $this->dao->select('story')->from(TABLE_TASK)->where('id')->eq($taskID)->fetch('story');
|
|
$this->task->delete(TABLE_TASK, $taskID);
|
|
if($story) $this->loadModel('story')->setStage($story);
|
|
die(js::locate($this->session->taskList, 'parent'));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Send email.
|
|
*
|
|
* @param int $taskID
|
|
* @param int $actionID
|
|
* @access private
|
|
* @return void
|
|
*/
|
|
private function sendmail($taskID, $actionID)
|
|
{
|
|
/* Set toList and ccList. */
|
|
$task = $this->task->getById($taskID);
|
|
$projectName = $this->project->getById($task->project)->name;
|
|
$toList = $task->assignedTo;
|
|
$ccList = trim($task->mailto, ',');
|
|
|
|
if($toList == '')
|
|
{
|
|
if($ccList == '') return;
|
|
if(strpos($ccList, ',') === false)
|
|
{
|
|
$toList = $ccList;
|
|
$ccList = '';
|
|
}
|
|
else
|
|
{
|
|
$commaPos = strpos($ccList, ',');
|
|
$toList = substr($ccList, 0, $commaPos);
|
|
$ccList = substr($ccList, $commaPos + 1);
|
|
}
|
|
}
|
|
elseif(strtolower($toList) == 'closed')
|
|
{
|
|
$toList = $task->finishedBy;
|
|
}
|
|
|
|
/* Get action info. */
|
|
$action = $this->loadModel('action')->getById($actionID);
|
|
$history = $this->action->getHistory($actionID);
|
|
$action->history = isset($history[$actionID]) ? $history[$actionID] : array();
|
|
|
|
/* Create the email content. */
|
|
$this->view->task = $task;
|
|
$this->view->action = $action;
|
|
$this->clear();
|
|
$mailContent = $this->parse($this->moduleName, 'sendmail');
|
|
|
|
/* Send emails. */
|
|
$this->loadModel('mail')->send($toList, $projectName . ':' . 'TASK#' . $task->id . $this->lang->colon . $task->name, $mailContent, $ccList);
|
|
if($this->mail->isError()) echo js::error($this->mail->getError());
|
|
}
|
|
|
|
/**
|
|
* AJAX: return tasks of a user in html select.
|
|
*
|
|
* @param string $account
|
|
* @param string $status
|
|
* @access public
|
|
* @return string
|
|
*/
|
|
public function ajaxGetUserTasks($account = '', $status = 'wait,doing')
|
|
{
|
|
if($account == '') $account = $this->app->user->account;
|
|
$tasks = $this->task->getUserTaskPairs($account, $status);
|
|
die(html::select('task', $tasks, '', 'class=select-1'));
|
|
}
|
|
|
|
/**
|
|
* AJAX: return project tasks in html select.
|
|
*
|
|
* @param int $projectID
|
|
* @param int $taskID
|
|
* @access public
|
|
* @return string
|
|
*/
|
|
public function ajaxGetProjectTasks($projectID, $taskID = 0)
|
|
{
|
|
$tasks = $this->task->getProjectTaskPairs((int)$projectID);
|
|
die(html::select('task', $tasks, $taskID));
|
|
}
|
|
|
|
/**
|
|
* The report page.
|
|
*
|
|
* @param int $projectID
|
|
* @param string $browseType
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function report($projectID, $browseType = 'all')
|
|
{
|
|
|
|
$this->loadModel('report');
|
|
$this->view->charts = array();
|
|
$this->view->renderJS = '';
|
|
|
|
if(!empty($_POST))
|
|
{
|
|
foreach($this->post->charts as $chart)
|
|
{
|
|
$chartFunc = 'getDataOf' . $chart;
|
|
$chartData = $this->task->$chartFunc();
|
|
$chartOption = $this->lang->task->report->$chart;
|
|
$this->task->mergeChartOption($chart);
|
|
|
|
$chartXML = $this->report->createSingleXML($chartData, $chartOption->graph);
|
|
$this->view->charts[$chart] = $this->report->createJSChart($chartOption->swf, $chartXML, $chartOption->width, $chartOption->height);
|
|
$this->view->datas[$chart] = $this->report->computePercent($chartData);
|
|
}
|
|
$this->view->renderJS = $this->report->renderJsCharts(count($this->view->charts));
|
|
}
|
|
|
|
$this->project->setMenu($this->project->getPairs(), $projectID);
|
|
$this->projects = $this->project->getPairs();
|
|
$this->view->header->title = $this->projects[$projectID] . $this->lang->colon . $this->lang->task->report->common;
|
|
$this->view->projectID = $projectID;
|
|
$this->view->browseType = $browseType;
|
|
$this->view->checkedCharts = $this->post->charts ? join(',', $this->post->charts) : '';
|
|
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* get data to export
|
|
*
|
|
* @param int $projectID
|
|
* @param string $orderBy
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function export($projectID, $orderBy)
|
|
{
|
|
if($_POST)
|
|
{
|
|
$taskLang = $this->lang->task;
|
|
$taskConfig = $this->config->task;
|
|
|
|
/* Create field lists. */
|
|
$fields = explode(',', $taskConfig->exportFields);
|
|
foreach($fields as $key => $fieldName)
|
|
{
|
|
$fieldName = trim($fieldName);
|
|
$fields[$fieldName] = isset($taskLang->$fieldName) ? $taskLang->$fieldName : $fieldName;
|
|
unset($fields[$key]);
|
|
}
|
|
|
|
/* Get tasks. */
|
|
$tasks = $this->dao->select('*')->from(TABLE_TASK)->alias('t1')->where($this->session->taskReportCondition)->orderBy($orderBy)->fetchAll('id');
|
|
|
|
/* Get users and projects. */
|
|
$users = $this->loadModel('user')->getPairs('noletter');
|
|
$projects = $this->loadModel('project')->getPairs('all');
|
|
|
|
/* Get related objects id lists. */
|
|
$relatedStoryIdList = array();
|
|
foreach($tasks as $task) $relatedStoryIdList[$task->story] = $task->story;
|
|
|
|
/* Get related objects title or names. */
|
|
$relatedStories = $this->dao->select('id,title')->from(TABLE_STORY) ->where('id')->in($relatedStoryIdList)->fetchPairs();
|
|
$relatedFiles = $this->dao->select('id, objectID, pathname, title')->from(TABLE_FILE)->where('objectType')->eq('task')->andWhere('objectID')->in(@array_keys($tasks))->fetchGroup('objectID');
|
|
|
|
foreach($tasks as $task)
|
|
{
|
|
if($this->post->fileType == 'csv')
|
|
{
|
|
$task->desc = htmlspecialchars_decode($task->desc);
|
|
$task->desc = str_replace("<br />", "\n", $task->desc);
|
|
$task->desc = str_replace('"', '""', $task->desc);
|
|
}
|
|
|
|
/* fill some field with useful value. */
|
|
$task->story = isset($relatedStories[$task->story]) ? $relatedStories[$task->story] : '';
|
|
|
|
if(isset($projects[$task->project])) $task->project = $projects[$task->project];
|
|
if(isset($taskLang->typeList[$task->type])) $task->type = $taskLang->typeList[$task->type];
|
|
if(isset($taskLang->priList[$task->pri])) $task->pri = $taskLang->priList[$task->pri];
|
|
if(isset($taskLang->statusList[$task->status])) $task->status = $taskLang->statusList[$task->status];
|
|
if(isset($taskLang->reasonList[$task->closedReason])) $task->closedReason = $taskLang->reasonList[$task->closedReason];
|
|
|
|
if(isset($users[$task->openedBy])) $task->openedBy = $users[$task->openedBy];
|
|
if(isset($users[$task->assignedTo])) $task->assignedTo = $users[$task->assignedTo];
|
|
if(isset($users[$task->finishedBy])) $task->finishedBy = $users[$task->finishedBy];
|
|
if(isset($users[$task->canceledBy])) $task->canceledBy = $users[$task->canceledBy];
|
|
if(isset($users[$task->closedBy])) $task->closedBy = $users[$task->closedBy];
|
|
if(isset($users[$task->lastEditedBy])) $task->lastEditedBy = $users[$task->lastEditedBy];
|
|
|
|
$task->openedDate = substr($task->openedDate, 0, 10);
|
|
$task->assignedDate = substr($task->assignedDate, 0, 10);
|
|
$task->finishedDate = substr($task->finishedDate, 0, 10);
|
|
$task->canceledDate = substr($task->canceledDate, 0, 10);
|
|
$task->closedDate = substr($task->closedDate, 0, 10);
|
|
$task->lastEditedDate = substr($task->lastEditedDate, 0, 10);
|
|
|
|
/* Set related files. */
|
|
if(isset($relatedFiles[$task->id]))
|
|
{
|
|
foreach($relatedFiles[$task->id] as $file)
|
|
{
|
|
$fileURL = 'http://' . $this->server->http_host . $this->config->webRoot . "data/upload/$task->company/" . $file->pathname;
|
|
$task->files .= html::a($fileURL, $file->title, '_blank') . '<br />';
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->post->set('fields', $fields);
|
|
$this->post->set('rows', $tasks);
|
|
$this->fetch('file', 'export2' . $this->post->fileType, $_POST);
|
|
}
|
|
|
|
$this->display();
|
|
}
|
|
|
|
/**
|
|
* Import from Bug.
|
|
*
|
|
* @param int $projectID
|
|
* @param string $orderBy
|
|
* @param int $recTotal
|
|
* @param int $recPerPage
|
|
* @param int $pageID
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public function importFromBug($projectID = 0, $pager = '', $recTotal = 0, $recPerPage = 30, $pageID = 1)
|
|
{
|
|
if(!empty($_POST))
|
|
{
|
|
$mails = $this->task->importFromBug($projectID);
|
|
if(dao::isError()) die(js::error(dao::getError()));
|
|
|
|
foreach($mails as $mail)
|
|
{
|
|
$this->sendmail($mail->taskID, $mail->actionID);
|
|
}
|
|
|
|
/* Locate the browser. */
|
|
die(js::locate($this->createLink('project', 'task', "projectID=$projectID"), 'parent'));
|
|
}
|
|
$this->loadModel('bug');
|
|
|
|
$projects = $this->project->getPairs();
|
|
$users = $this->project->getTeamMemberPairs($projectID, 'nodeleted');
|
|
|
|
/* Load pager and get tasks. */
|
|
$this->app->loadClass('pager', $static = true);
|
|
$pager = new pager($recTotal, $recPerPage, $pageID);
|
|
|
|
$this->project->setMenu($projects, $projectID);
|
|
$header['title'] = $projects[$projectID] . $this->lang->colon . $this->lang->task->importFromBug;
|
|
$position[] = html::a($this->createLink('project', 'task', "projectID=$projectID"), $projects[$projectID]);
|
|
$position[] = $this->lang->task->importFromBug;
|
|
|
|
$bugs = $this->bug->getActiveBugs($pager);
|
|
$this->view->header = $header;
|
|
$this->view->pager = $pager;
|
|
$this->view->bugs = $bugs;
|
|
$this->view->users = $users;
|
|
$this->view->projectID = $projectID;
|
|
$this->display();
|
|
}
|
|
|
|
|
|
/* task#536.
|
|
public function importFromBug($projectID = 0, $browseType = 'noclosed', $param = 0, $orderBy = '', $recTotal = 0, $recPerPage = 20, $pageID = 1)
|
|
{
|
|
$this->products = $this->loadModel('product')->getPairs();
|
|
if(empty($this->products))
|
|
{
|
|
//echo js::alert($this->lang->product->errorNoProduct);
|
|
//die(js::locate($this->createLink('product', 'create')));
|
|
}
|
|
$this->view->products = $this->products;
|
|
$projects = $this->project->getPairs('all');
|
|
|
|
/* Set browseType and queryID. /
|
|
$browseType = strtolower($browseType);
|
|
$queryID = ($browseType == 'bysearch') ? (int)$param : 0;
|
|
|
|
/* Set menu and save session. /
|
|
$this->project->setMenu($this->project->getPairs(), $projectID);
|
|
$this->session->set('bugList', $this->app->getURI(true));
|
|
|
|
/* Process the order by field. /
|
|
if(!$orderBy) $orderBy = $this->cookie->qaBugOrder ? $this->cookie->qaBugOrder : 'id_desc';
|
|
setcookie('qaBugOrder', $orderBy, $this->config->cookieLife, $this->config->webRoot);
|
|
|
|
/* Load pager. /
|
|
$this->app->loadClass('pager', $static = true);
|
|
$pager = pager::init($recTotal, $recPerPage, $pageID);
|
|
|
|
$bugs = array();
|
|
if($browseType == 'all')
|
|
{
|
|
$bugs = $this->dao->select('*')->from(TABLE_BUG)->where('product')->eq($productID)
|
|
->andWhere('deleted')->eq(0)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'assigntome')
|
|
{
|
|
$bugs = $this->dao->findByAssignedTo($this->app->user->account)->from(TABLE_BUG)->andWhere('product')->eq($productID)
|
|
->andWhere('deleted')->eq(0)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'openedbyme')
|
|
{
|
|
$bugs = $this->dao->findByOpenedBy($this->app->user->account)->from(TABLE_BUG)->andWhere('product')->eq($productID)
|
|
->andWhere('deleted')->eq(0)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'resolvedbyme')
|
|
{
|
|
$bugs = $this->dao->findByResolvedBy($this->app->user->account)->from(TABLE_BUG)->andWhere('product')->eq($productID)
|
|
->andWhere('deleted')->eq(0)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'assigntonull')
|
|
{
|
|
$bugs = $this->dao->findByAssignedTo('')->from(TABLE_BUG)->andWhere('product')->eq($productID)
|
|
->andWhere('deleted')->eq(0)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'unresolved')
|
|
{
|
|
$bugs = $this->dao->findByStatus('active')->from(TABLE_BUG)->andWhere('product')->eq($productID)
|
|
->andWhere('deleted')->eq(0)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'longlifebugs')
|
|
{
|
|
$bugs = $this->dao->findByLastEditedDate("<", date(DT_DATE1, strtotime('-7 days')))->from(TABLE_BUG)->andWhere('product')->eq($productID)
|
|
->andWhere('openedDate')->lt(date(DT_DATE1,strtotime('-7 days')))
|
|
->andWhere('deleted')->eq(0)
|
|
->andWhere('status')->ne('closed')->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'postponedbugs')
|
|
{
|
|
$bugs = $this->dao->findByResolution('postponed')->from(TABLE_BUG)->andWhere('product')->eq($productID)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
elseif($browseType == 'needconfirm')
|
|
{
|
|
$bugs = $this->dao->select('t1.*, t2.title AS storyTitle')->from(TABLE_BUG)->alias('t1')->leftJoin(TABLE_STORY)->alias('t2')->on('t1.story = t2.id')
|
|
->where("t2.status = 'active'")
|
|
->andWhere('t1.deleted')->eq(0)
|
|
->andWhere('t2.version > t1.storyVersion')
|
|
->orderBy($orderBy)
|
|
->fetchAll();
|
|
}
|
|
elseif($browseType == 'bysearch')
|
|
{
|
|
if($queryID)
|
|
{
|
|
$query = $this->loadModel('search')->getQuery($queryID);
|
|
if($query)
|
|
{
|
|
$this->session->set('bugQuery', $query->sql);
|
|
$this->session->set('bugForm', $query->form);
|
|
}
|
|
else
|
|
{
|
|
$this->session->set('bugQuery', ' 1 = 1');
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if($this->session->bugQuery == false) $this->session->set('bugQuery', ' 1 = 1');
|
|
}
|
|
$bugQuery = str_replace("`product` = 'all'", '1', $this->session->bugQuery); // Search all product.
|
|
$bugs = $this->dao->select('*')->from(TABLE_BUG)->where($bugQuery)
|
|
->andWhere('deleted')->eq(0)
|
|
->orderBy($orderBy)->page($pager)->fetchAll();
|
|
}
|
|
|
|
/ Process the sql, get the conditon partion, save it to session. Thus the report page can use the same condition. /
|
|
if($browseType != 'needconfirm')
|
|
{
|
|
$sql = explode('WHERE', $this->dao->get());
|
|
$sql = explode('ORDER', $sql[1]);
|
|
$this->session->set('bugReportCondition', $sql[0]);
|
|
}
|
|
|
|
/ Build the search form. /
|
|
$this->config->bug->search['actionURL'] = $this->createLink('bug', 'browse', "productID=$productID&browseType=bySearch&queryID=myQueryID");
|
|
$this->config->bug->search['queryID'] = $queryID;
|
|
$this->config->bug->search['params']['product']['values'] = array($productID => $this->products[$productID], 'all' => $this->lang->bug->allProduct);
|
|
$this->config->bug->search['params']['module']['values'] = $this->tree->getOptionMenu($productID, $viewType = 'bug', $startModuleID = 0);
|
|
$this->config->bug->search['params']['project']['values'] = $this->product->getProjectPairs($productID);
|
|
$this->config->bug->search['params']['openedBuild']['values'] = $this->loadModel('build')->getProductBuildPairs($productID);
|
|
$this->config->bug->search['params']['resolvedBuild']['values'] = $this->build->getProductBuildPairs($productID);
|
|
$this->view->searchForm = $this->fetch('search', 'buildForm', $this->config->bug->search);
|
|
|
|
$users = $this->loadModel('user')->getPairs('noletter');
|
|
|
|
$header['title'] = $projects[$projectID] . $this->lang->colon . $this->lang->task->common;
|
|
$position[] = html::a($this->createLink('project', 'task', "projectID=$projectID"), $projects[$projectID]);
|
|
$position[] = $this->lang->task->common;
|
|
|
|
$this->view->header = $header;
|
|
$this->view->position = $position;
|
|
$this->view->projectID = $projectID;
|
|
$this->view->projectName = $projects[$projectID];
|
|
$this->view->browseType = $browseType;
|
|
$this->view->bugs = $bugs;
|
|
$this->view->users = $users;
|
|
$this->view->pager = $pager;
|
|
$this->view->param = $param;
|
|
$this->view->orderBy = $orderBy;
|
|
|
|
$this->display();
|
|
}
|
|
*/
|
|
}
|