kb / app /Action /TaskAssignColorOnDueDate.php
Xv Zan
ULFS
e4f4821
<?php
namespace Kanboard\Action;
use Kanboard\Model\TaskModel;
/**
* Assign a color to a priority
*
* @package Kanboard\Action
* @author Julien Buratto
*/
class TaskAssignColorOnDueDate extends Base
{
/**
* Get action description
*
* @access public
* @return string
*/
public function getDescription()
{
return t('Assign automatically a color when due date is expired');
}
/**
* Get the list of compatible events
*
* @access public
* @return array
*/
public function getCompatibleEvents()
{
return array(
TaskModel::EVENT_DAILY_CRONJOB,
);
}
/**
* Get the required parameter for the action
*
* @access public
* @return array
*/
public function getActionRequiredParameters()
{
return array(
'color_id' => t('Color'),
);
}
/**
* Get all tasks
*
* @access public
* @return array
*/
public function getEventRequiredParameters()
{
return array('tasks');
}
/**
* Execute the action (change the task color)
*
* @access public
* @param array $data Event data dictionary
* @return bool True if the action was executed or false when not executed
*/
public function doAction(array $data)
{
$results = array();
foreach ($data['tasks'] as $task) {
if ($task['date_due'] <= time() && $task['date_due'] > 0 && $task['color_id'] != $this->getParam('color_id')) {
$values = array(
'id' => $task['id'],
'color_id' => $this->getParam('color_id'),
);
$results[] = $this->taskModificationModel->update($values, false);
}
}
return in_array(true, $results, true);
}
/**
* Check if the event data meet the action condition
*
* @access public
* @param array $data Event data dictionary
* @return bool
*/
public function hasRequiredCondition(array $data)
{
return count($data['tasks']) > 0;
}
}