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(
|
$this->response->html($this->template->render('task_recurrence/info', array(
|
||||||
'task' => $task,
|
'task' => $task,
|
||||||
'recurrence_trigger_list' => $this->taskModel->getRecurrenceTriggerList(),
|
'recurrence_trigger_list' => $this->taskRecurrenceModel->getRecurrenceTriggerList(),
|
||||||
'recurrence_timeframe_list' => $this->taskModel->getRecurrenceTimeframeList(),
|
'recurrence_timeframe_list' => $this->taskRecurrenceModel->getRecurrenceTimeframeList(),
|
||||||
'recurrence_basedate_list' => $this->taskModel->getRecurrenceBasedateList(),
|
'recurrence_basedate_list' => $this->taskRecurrenceModel->getRecurrenceBasedateList(),
|
||||||
)));
|
)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -31,10 +31,10 @@ class TaskRecurrenceController extends BaseController
|
||||||
'values' => $values,
|
'values' => $values,
|
||||||
'errors' => $errors,
|
'errors' => $errors,
|
||||||
'task' => $task,
|
'task' => $task,
|
||||||
'recurrence_status_list' => $this->taskModel->getRecurrenceStatusList(),
|
'recurrence_status_list' => $this->taskRecurrenceModel->getRecurrenceStatusList(),
|
||||||
'recurrence_trigger_list' => $this->taskModel->getRecurrenceTriggerList(),
|
'recurrence_trigger_list' => $this->taskRecurrenceModel->getRecurrenceTriggerList(),
|
||||||
'recurrence_timeframe_list' => $this->taskModel->getRecurrenceTimeframeList(),
|
'recurrence_timeframe_list' => $this->taskRecurrenceModel->getRecurrenceTimeframeList(),
|
||||||
'recurrence_basedate_list' => $this->taskModel->getRecurrenceBasedateList(),
|
'recurrence_basedate_list' => $this->taskRecurrenceModel->getRecurrenceBasedateList(),
|
||||||
)));
|
)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -27,17 +27,17 @@ class TaskHelper extends Base
|
||||||
|
|
||||||
public function recurrenceTriggers()
|
public function recurrenceTriggers()
|
||||||
{
|
{
|
||||||
return $this->taskModel->getRecurrenceTriggerList();
|
return $this->taskRecurrenceModel->getRecurrenceTriggerList();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function recurrenceTimeframes()
|
public function recurrenceTimeframes()
|
||||||
{
|
{
|
||||||
return $this->taskModel->getRecurrenceTimeframeList();
|
return $this->taskRecurrenceModel->getRecurrenceTimeframeList();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function recurrenceBasedates()
|
public function recurrenceBasedates()
|
||||||
{
|
{
|
||||||
return $this->taskModel->getRecurrenceBasedateList();
|
return $this->taskRecurrenceModel->getRecurrenceBasedateList();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function selectTitle(array $values, array $errors)
|
public function selectTitle(array $values, array $errors)
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ namespace Kanboard\Model;
|
||||||
use Kanboard\Core\Base;
|
use Kanboard\Core\Base;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Task model
|
* Task Model
|
||||||
*
|
*
|
||||||
* @package Kanboard\Model
|
* @package Kanboard\Model
|
||||||
* @author Frederic Guillot
|
* @author Frederic Guillot
|
||||||
|
|
@ -117,64 +117,6 @@ class TaskModel extends Base
|
||||||
return 0;
|
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
|
* Get task progress based on the column position
|
||||||
*
|
*
|
||||||
|
|
|
||||||
|
|
@ -13,6 +13,64 @@ use DateTime;
|
||||||
*/
|
*/
|
||||||
class TaskRecurrenceModel extends TaskDuplicationModel
|
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
|
* Duplicate recurring task
|
||||||
*
|
*
|
||||||
|
|
@ -31,7 +89,9 @@ class TaskRecurrenceModel extends TaskDuplicationModel
|
||||||
|
|
||||||
$recurring_task_id = $this->save($task_id, $values);
|
$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
|
$parent_update = $this->db
|
||||||
->table(TaskModel::TABLE)
|
->table(TaskModel::TABLE)
|
||||||
->eq('id', $task_id)
|
->eq('id', $task_id)
|
||||||
|
|
|
||||||
|
|
@ -10,7 +10,7 @@ use Kanboard\Model\ProjectModel;
|
||||||
use Kanboard\Model\CategoryModel;
|
use Kanboard\Model\CategoryModel;
|
||||||
use Kanboard\Model\TaskTagModel;
|
use Kanboard\Model\TaskTagModel;
|
||||||
|
|
||||||
class TaskDuplicationTest extends Base
|
class TaskDuplicationModelTest extends Base
|
||||||
{
|
{
|
||||||
public function testThatDuplicateDefineCreator()
|
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\TaskFinderModel;
|
||||||
use Kanboard\Model\TaskModel;
|
use Kanboard\Model\TaskModel;
|
||||||
use Kanboard\Model\TaskRecurrenceModel;
|
use Kanboard\Model\TaskRecurrenceModel;
|
||||||
|
use Kanboard\Model\TaskTagModel;
|
||||||
|
|
||||||
class TaskRecurrenceModelTest extends Base
|
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()
|
public function testCalculateRecurringTaskDueDate()
|
||||||
{
|
{
|
||||||
$taskRecurrenceModel = new TaskRecurrenceModel($this->container);
|
$taskRecurrenceModel = new TaskRecurrenceModel($this->container);
|
||||||
|
|
@ -55,6 +84,7 @@ class TaskRecurrenceModelTest extends Base
|
||||||
$taskFinderModel = new TaskFinderModel($this->container);
|
$taskFinderModel = new TaskFinderModel($this->container);
|
||||||
$projectModel = new ProjectModel($this->container);
|
$projectModel = new ProjectModel($this->container);
|
||||||
$dateParser = new DateParser($this->container);
|
$dateParser = new DateParser($this->container);
|
||||||
|
$taskTagModel = new TaskTagModel($this->container);
|
||||||
|
|
||||||
$this->assertEquals(1, $projectModel->create(array('name' => 'test1')));
|
$this->assertEquals(1, $projectModel->create(array('name' => 'test1')));
|
||||||
|
|
||||||
|
|
@ -67,6 +97,7 @@ class TaskRecurrenceModelTest extends Base
|
||||||
'recurrence_factor' => 2,
|
'recurrence_factor' => 2,
|
||||||
'recurrence_timeframe' => TaskModel::RECURRING_TIMEFRAME_DAYS,
|
'recurrence_timeframe' => TaskModel::RECURRING_TIMEFRAME_DAYS,
|
||||||
'recurrence_basedate' => TaskModel::RECURRING_BASEDATE_TRIGGERDATE,
|
'recurrence_basedate' => TaskModel::RECURRING_BASEDATE_TRIGGERDATE,
|
||||||
|
'tags' => array('T1', 'T2'),
|
||||||
)));
|
)));
|
||||||
|
|
||||||
$this->assertEquals(2, $taskRecurrenceModel->duplicateRecurringTask(1));
|
$this->assertEquals(2, $taskRecurrenceModel->duplicateRecurringTask(1));
|
||||||
|
|
@ -86,5 +117,10 @@ class TaskRecurrenceModelTest extends Base
|
||||||
$this->assertEquals(1, $task['recurrence_parent']);
|
$this->assertEquals(1, $task['recurrence_parent']);
|
||||||
$this->assertEquals(2, $task['recurrence_factor']);
|
$this->assertEquals(2, $task['recurrence_factor']);
|
||||||
$this->assertEquals($dateParser->removeTimeFromTimestamp(strtotime('+2 days')), $task['date_due'], '', 2);
|
$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