Make sure that tags are duplicated for recurring tasks
This commit is contained in:
parent
b7ac354e83
commit
8e56148a6d
|
|
@ -107,9 +107,9 @@ class BoardTooltipController extends BaseController
|
|||
|
||||
$this->response->html($this->template->render('task_recurrence/info', array(
|
||||
'task' => $task,
|
||||
'recurrence_trigger_list' => $this->taskModel->getRecurrenceTriggerList(),
|
||||
'recurrence_timeframe_list' => $this->taskModel->getRecurrenceTimeframeList(),
|
||||
'recurrence_basedate_list' => $this->taskModel->getRecurrenceBasedateList(),
|
||||
'recurrence_trigger_list' => $this->taskRecurrenceModel->getRecurrenceTriggerList(),
|
||||
'recurrence_timeframe_list' => $this->taskRecurrenceModel->getRecurrenceTimeframeList(),
|
||||
'recurrence_basedate_list' => $this->taskRecurrenceModel->getRecurrenceBasedateList(),
|
||||
)));
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -31,10 +31,10 @@ class TaskRecurrenceController extends BaseController
|
|||
'values' => $values,
|
||||
'errors' => $errors,
|
||||
'task' => $task,
|
||||
'recurrence_status_list' => $this->taskModel->getRecurrenceStatusList(),
|
||||
'recurrence_trigger_list' => $this->taskModel->getRecurrenceTriggerList(),
|
||||
'recurrence_timeframe_list' => $this->taskModel->getRecurrenceTimeframeList(),
|
||||
'recurrence_basedate_list' => $this->taskModel->getRecurrenceBasedateList(),
|
||||
'recurrence_status_list' => $this->taskRecurrenceModel->getRecurrenceStatusList(),
|
||||
'recurrence_trigger_list' => $this->taskRecurrenceModel->getRecurrenceTriggerList(),
|
||||
'recurrence_timeframe_list' => $this->taskRecurrenceModel->getRecurrenceTimeframeList(),
|
||||
'recurrence_basedate_list' => $this->taskRecurrenceModel->getRecurrenceBasedateList(),
|
||||
)));
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -27,17 +27,17 @@ class TaskHelper extends Base
|
|||
|
||||
public function recurrenceTriggers()
|
||||
{
|
||||
return $this->taskModel->getRecurrenceTriggerList();
|
||||
return $this->taskRecurrenceModel->getRecurrenceTriggerList();
|
||||
}
|
||||
|
||||
public function recurrenceTimeframes()
|
||||
{
|
||||
return $this->taskModel->getRecurrenceTimeframeList();
|
||||
return $this->taskRecurrenceModel->getRecurrenceTimeframeList();
|
||||
}
|
||||
|
||||
public function recurrenceBasedates()
|
||||
{
|
||||
return $this->taskModel->getRecurrenceBasedateList();
|
||||
return $this->taskRecurrenceModel->getRecurrenceBasedateList();
|
||||
}
|
||||
|
||||
public function selectTitle(array $values, array $errors)
|
||||
|
|
|
|||
|
|
@ -5,7 +5,7 @@ namespace Kanboard\Model;
|
|||
use Kanboard\Core\Base;
|
||||
|
||||
/**
|
||||
* Task model
|
||||
* Task Model
|
||||
*
|
||||
* @package Kanboard\Model
|
||||
* @author Frederic Guillot
|
||||
|
|
@ -117,64 +117,6 @@ class TaskModel extends Base
|
|||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the list user selectable recurrence status
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceStatusList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_STATUS_NONE => t('No'),
|
||||
TaskModel::RECURRING_STATUS_PENDING => t('Yes'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the list recurrence triggers
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceTriggerList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_TRIGGER_FIRST_COLUMN => t('When task is moved from first column'),
|
||||
TaskModel::RECURRING_TRIGGER_LAST_COLUMN => t('When task is moved to last column'),
|
||||
TaskModel::RECURRING_TRIGGER_CLOSE => t('When task is closed'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the list options to calculate recurrence due date
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceBasedateList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_BASEDATE_DUEDATE => t('Existing due date'),
|
||||
TaskModel::RECURRING_BASEDATE_TRIGGERDATE => t('Action date'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the list recurrence timeframes
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceTimeframeList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_TIMEFRAME_DAYS => t('Day(s)'),
|
||||
TaskModel::RECURRING_TIMEFRAME_MONTHS => t('Month(s)'),
|
||||
TaskModel::RECURRING_TIMEFRAME_YEARS => t('Year(s)'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get task progress based on the column position
|
||||
*
|
||||
|
|
|
|||
|
|
@ -13,6 +13,64 @@ use DateTime;
|
|||
*/
|
||||
class TaskRecurrenceModel extends TaskDuplicationModel
|
||||
{
|
||||
/**
|
||||
* Return the list user selectable recurrence status
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceStatusList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_STATUS_NONE => t('No'),
|
||||
TaskModel::RECURRING_STATUS_PENDING => t('Yes'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the list recurrence triggers
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceTriggerList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_TRIGGER_FIRST_COLUMN => t('When task is moved from first column'),
|
||||
TaskModel::RECURRING_TRIGGER_LAST_COLUMN => t('When task is moved to last column'),
|
||||
TaskModel::RECURRING_TRIGGER_CLOSE => t('When task is closed'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the list options to calculate recurrence due date
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceBasedateList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_BASEDATE_DUEDATE => t('Existing due date'),
|
||||
TaskModel::RECURRING_BASEDATE_TRIGGERDATE => t('Action date'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the list recurrence timeframes
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getRecurrenceTimeframeList()
|
||||
{
|
||||
return array(
|
||||
TaskModel::RECURRING_TIMEFRAME_DAYS => t('Day(s)'),
|
||||
TaskModel::RECURRING_TIMEFRAME_MONTHS => t('Month(s)'),
|
||||
TaskModel::RECURRING_TIMEFRAME_YEARS => t('Year(s)'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Duplicate recurring task
|
||||
*
|
||||
|
|
@ -31,7 +89,9 @@ class TaskRecurrenceModel extends TaskDuplicationModel
|
|||
|
||||
$recurring_task_id = $this->save($task_id, $values);
|
||||
|
||||
if ($recurring_task_id > 0) {
|
||||
if ($recurring_task_id !== false) {
|
||||
$this->tagDuplicationModel->duplicateTaskTags($task_id, $recurring_task_id);
|
||||
|
||||
$parent_update = $this->db
|
||||
->table(TaskModel::TABLE)
|
||||
->eq('id', $task_id)
|
||||
|
|
|
|||
|
|
@ -10,7 +10,7 @@ use Kanboard\Model\ProjectModel;
|
|||
use Kanboard\Model\CategoryModel;
|
||||
use Kanboard\Model\TaskTagModel;
|
||||
|
||||
class TaskDuplicationTest extends Base
|
||||
class TaskDuplicationModelTest extends Base
|
||||
{
|
||||
public function testThatDuplicateDefineCreator()
|
||||
{
|
||||
|
|
@ -0,0 +1,30 @@
|
|||
<?php
|
||||
|
||||
require_once __DIR__.'/../Base.php';
|
||||
|
||||
use Kanboard\Model\TaskModel;
|
||||
use Kanboard\Model\TaskCreationModel;
|
||||
use Kanboard\Model\ProjectModel;
|
||||
|
||||
class TaskModelTest extends Base
|
||||
{
|
||||
public function testRemove()
|
||||
{
|
||||
$taskModel = new TaskModel($this->container);
|
||||
$taskCreationModel = new TaskCreationModel($this->container);
|
||||
$projectModel = new ProjectModel($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'UnitTest')));
|
||||
$this->assertEquals(1, $taskCreationModel->create(array('title' => 'Task #1', 'project_id' => 1)));
|
||||
|
||||
$this->assertTrue($taskModel->remove(1));
|
||||
$this->assertFalse($taskModel->remove(1234));
|
||||
}
|
||||
|
||||
public function testGetTaskIdFromText()
|
||||
{
|
||||
$taskModel = new TaskModel($this->container);
|
||||
$this->assertEquals(123, $taskModel->getTaskIdFromText('My task #123'));
|
||||
$this->assertEquals(0, $taskModel->getTaskIdFromText('My task 123'));
|
||||
}
|
||||
}
|
||||
|
|
@ -8,9 +8,38 @@ use Kanboard\Model\TaskCreationModel;
|
|||
use Kanboard\Model\TaskFinderModel;
|
||||
use Kanboard\Model\TaskModel;
|
||||
use Kanboard\Model\TaskRecurrenceModel;
|
||||
use Kanboard\Model\TaskTagModel;
|
||||
|
||||
class TaskRecurrenceModelTest extends Base
|
||||
{
|
||||
public function testRecurrenceSettings()
|
||||
{
|
||||
$taskRecurrenceModel = new TaskRecurrenceModel($this->container);
|
||||
|
||||
$statuses = $taskRecurrenceModel->getRecurrenceStatusList();
|
||||
$this->assertCount(2, $statuses);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_STATUS_NONE, $statuses);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_STATUS_PENDING, $statuses);
|
||||
$this->assertArrayNotHasKey(TaskModel::RECURRING_STATUS_PROCESSED, $statuses);
|
||||
|
||||
$triggers = $taskRecurrenceModel->getRecurrenceTriggerList();
|
||||
$this->assertCount(3, $triggers);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TRIGGER_FIRST_COLUMN, $triggers);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TRIGGER_LAST_COLUMN, $triggers);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TRIGGER_CLOSE, $triggers);
|
||||
|
||||
$dates = $taskRecurrenceModel->getRecurrenceBasedateList();
|
||||
$this->assertCount(2, $dates);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_BASEDATE_DUEDATE, $dates);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_BASEDATE_TRIGGERDATE, $dates);
|
||||
|
||||
$timeframes = $taskRecurrenceModel->getRecurrenceTimeframeList();
|
||||
$this->assertCount(3, $timeframes);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TIMEFRAME_DAYS, $timeframes);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TIMEFRAME_MONTHS, $timeframes);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TIMEFRAME_YEARS, $timeframes);
|
||||
}
|
||||
|
||||
public function testCalculateRecurringTaskDueDate()
|
||||
{
|
||||
$taskRecurrenceModel = new TaskRecurrenceModel($this->container);
|
||||
|
|
@ -55,6 +84,7 @@ class TaskRecurrenceModelTest extends Base
|
|||
$taskFinderModel = new TaskFinderModel($this->container);
|
||||
$projectModel = new ProjectModel($this->container);
|
||||
$dateParser = new DateParser($this->container);
|
||||
$taskTagModel = new TaskTagModel($this->container);
|
||||
|
||||
$this->assertEquals(1, $projectModel->create(array('name' => 'test1')));
|
||||
|
||||
|
|
@ -67,6 +97,7 @@ class TaskRecurrenceModelTest extends Base
|
|||
'recurrence_factor' => 2,
|
||||
'recurrence_timeframe' => TaskModel::RECURRING_TIMEFRAME_DAYS,
|
||||
'recurrence_basedate' => TaskModel::RECURRING_BASEDATE_TRIGGERDATE,
|
||||
'tags' => array('T1', 'T2'),
|
||||
)));
|
||||
|
||||
$this->assertEquals(2, $taskRecurrenceModel->duplicateRecurringTask(1));
|
||||
|
|
@ -86,5 +117,10 @@ class TaskRecurrenceModelTest extends Base
|
|||
$this->assertEquals(1, $task['recurrence_parent']);
|
||||
$this->assertEquals(2, $task['recurrence_factor']);
|
||||
$this->assertEquals($dateParser->removeTimeFromTimestamp(strtotime('+2 days')), $task['date_due'], '', 2);
|
||||
|
||||
$tags = $taskTagModel->getList(2);
|
||||
$this->assertCount(2, $tags);
|
||||
$this->assertArrayHasKey(1, $tags);
|
||||
$this->assertArrayHasKey(2, $tags);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,58 +0,0 @@
|
|||
<?php
|
||||
|
||||
require_once __DIR__.'/../Base.php';
|
||||
|
||||
use Kanboard\Model\TaskModel;
|
||||
use Kanboard\Model\TaskCreationModel;
|
||||
use Kanboard\Model\ProjectModel;
|
||||
|
||||
class TaskTest extends Base
|
||||
{
|
||||
public function testRemove()
|
||||
{
|
||||
$t = new TaskModel($this->container);
|
||||
$tc = new TaskCreationModel($this->container);
|
||||
$p = new ProjectModel($this->container);
|
||||
|
||||
$this->assertEquals(1, $p->create(array('name' => 'UnitTest')));
|
||||
$this->assertEquals(1, $tc->create(array('title' => 'Task #1', 'project_id' => 1)));
|
||||
|
||||
$this->assertTrue($t->remove(1));
|
||||
$this->assertFalse($t->remove(1234));
|
||||
}
|
||||
|
||||
public function testGetTaskIdFromText()
|
||||
{
|
||||
$t = new TaskModel($this->container);
|
||||
$this->assertEquals(123, $t->getTaskIdFromText('My task #123'));
|
||||
$this->assertEquals(0, $t->getTaskIdFromText('My task 123'));
|
||||
}
|
||||
|
||||
public function testRecurrenceSettings()
|
||||
{
|
||||
$t = new TaskModel($this->container);
|
||||
|
||||
$statuses = $t->getRecurrenceStatusList();
|
||||
$this->assertCount(2, $statuses);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_STATUS_NONE, $statuses);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_STATUS_PENDING, $statuses);
|
||||
$this->assertArrayNotHasKey(TaskModel::RECURRING_STATUS_PROCESSED, $statuses);
|
||||
|
||||
$triggers = $t->getRecurrenceTriggerList();
|
||||
$this->assertCount(3, $triggers);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TRIGGER_FIRST_COLUMN, $triggers);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TRIGGER_LAST_COLUMN, $triggers);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TRIGGER_CLOSE, $triggers);
|
||||
|
||||
$dates = $t->getRecurrenceBasedateList();
|
||||
$this->assertCount(2, $dates);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_BASEDATE_DUEDATE, $dates);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_BASEDATE_TRIGGERDATE, $dates);
|
||||
|
||||
$timeframes = $t->getRecurrenceTimeframeList();
|
||||
$this->assertCount(3, $timeframes);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TIMEFRAME_DAYS, $timeframes);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TIMEFRAME_MONTHS, $timeframes);
|
||||
$this->assertArrayHasKey(TaskModel::RECURRING_TIMEFRAME_YEARS, $timeframes);
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue