mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-12 13:24:25 +00:00
back to the list keep the query parameters required by the list
This commit is contained in:
parent
066efdc042
commit
39e166eb5b
@ -194,9 +194,10 @@ class SingleTaskController extends Controller
|
|||||||
$this->addFlash('success', $translator
|
$this->addFlash('success', $translator
|
||||||
->trans("The task has been updated"));
|
->trans("The task has been updated"));
|
||||||
|
|
||||||
return $this->redirectToRoute('chill_task_singletask_list', [
|
return $this->redirectToRoute(
|
||||||
'person_id' => $task->getPerson()->getId()
|
'chill_task_singletask_list',
|
||||||
]);
|
$request->query->get('list_params', [])
|
||||||
|
);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$this->addFlash('error', $translator->trans("This form contains errors"));
|
$this->addFlash('error', $translator->trans("This form contains errors"));
|
||||||
@ -277,9 +278,10 @@ class SingleTaskController extends Controller
|
|||||||
->trans("The task has been successfully removed."));
|
->trans("The task has been successfully removed."));
|
||||||
|
|
||||||
return $this->redirect($this->generateUrl(
|
return $this->redirect($this->generateUrl(
|
||||||
'chill_task_singletask_list', array(
|
'chill_task_singletask_list',
|
||||||
'person_id' => $personId
|
$request->query->get('list_params', [
|
||||||
)));
|
'person_id' => $person->getId()
|
||||||
|
])));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@ use Chill\TaskBundle\Templating\UI\CountNotificationTask;
|
|||||||
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
|
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
|
||||||
use Chill\TaskBundle\Repository\SingleTaskRepository;
|
use Chill\TaskBundle\Repository\SingleTaskRepository;
|
||||||
use Symfony\Component\Translation\TranslatorInterface;
|
use Symfony\Component\Translation\TranslatorInterface;
|
||||||
|
use Chill\MainBundle\Entity\User;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@ -66,19 +67,28 @@ class UserMenuBuilder implements LocalMenuBuilderInterface
|
|||||||
|
|
||||||
public function buildMenu($menuId, MenuItem $menu, array $parameters)
|
public function buildMenu($menuId, MenuItem $menu, array $parameters)
|
||||||
{
|
{
|
||||||
$number = $this->counter->countNotification($this->tokenStorage->getToken()
|
$user = $this->tokenStorage->getToken()->getUser();
|
||||||
->getUser());
|
$ended = $this->counter->countNotificationEnded($user);
|
||||||
|
$warning = $this->counter->countNotificationWarning($user);
|
||||||
|
|
||||||
|
if ($ended > 0) {
|
||||||
|
$this->addItemInMenu($menu, $user, '%number% tasks over deadline', $ended, -15);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($warning > 0) {
|
||||||
|
$this->addItemInMenu($menu, $user, '%number% tasks near deadline', $warning, -14);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function addItemInMenu(MenuItem $menu, User $u, $message, $number, $order)
|
||||||
|
{
|
||||||
if ($number > 0) {
|
if ($number > 0) {
|
||||||
$menu->addChild(
|
$menu->addChild(
|
||||||
$this->translator->transChoice('%number% tasks near deadline', $number),
|
$this->translator->transChoice($message, $number),
|
||||||
[
|
[
|
||||||
'route' => 'chill_task_singletask_list',
|
'route' => 'chill_task_singletask_list',
|
||||||
'routeParameters' => [
|
'routeParameters' => [
|
||||||
'user_id' => $this->tokenStorage
|
'user_id' => $u->getId(),
|
||||||
->getToken()
|
|
||||||
->getUser()
|
|
||||||
->getId(),
|
|
||||||
'status' => [
|
'status' => [
|
||||||
SingleTaskRepository::DATE_STATUS_WARNING,
|
SingleTaskRepository::DATE_STATUS_WARNING,
|
||||||
SingleTaskRepository::DATE_STATUS_ENDED
|
SingleTaskRepository::DATE_STATUS_ENDED
|
||||||
@ -87,7 +97,7 @@ class UserMenuBuilder implements LocalMenuBuilderInterface
|
|||||||
]
|
]
|
||||||
])
|
])
|
||||||
->setExtras([
|
->setExtras([
|
||||||
'order'=> -15,
|
'order'=> $order,
|
||||||
'icon' => 'exclamation-triangle',
|
'icon' => 'exclamation-triangle',
|
||||||
'entryclass' => 'user_menu__entry--warning-entry'
|
'entryclass' => 'user_menu__entry--warning-entry'
|
||||||
]);
|
]);
|
||||||
|
@ -81,4 +81,5 @@ cancel: annuler
|
|||||||
'The task has been updated': 'La tâche a été mise à jour'
|
'The task has been updated': 'La tâche a été mise à jour'
|
||||||
'The transition is successfully applied': 'La transition a bien été effectuée'
|
'The transition is successfully applied': 'La transition a bien été effectuée'
|
||||||
'The transition could not be applied': "La transition n'a pas pu être appliquée"
|
'The transition could not be applied': "La transition n'a pas pu être appliquée"
|
||||||
'%number% tasks near deadline': '{0} Aucune tâche à échance|{1} Une tâche à échéance | ]1,Inf[ %count% tâches à échéance'
|
'%number% tasks over deadline': '{0} Aucune tâche dépassée|{1} Une tâche dépassée | ]1,Inf[ %count% tâches dépassée'
|
||||||
|
'%number% tasks near deadline': '{0} Aucune tâche en rappel|{1} Une tâche en rappel | ]1,Inf[ %count% tâches en rappel'
|
||||||
|
@ -65,16 +65,16 @@
|
|||||||
</li>
|
</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<li>
|
<li>
|
||||||
<a href="{{ path('chill_task_single_task_show', { 'id': task.id }) }}" class="sc-button bt-show "></a>
|
<a href="{{ path('chill_task_single_task_show', { 'id': task.id, 'list_params': app.request.query.all }) }}" class="sc-button bt-show "></a>
|
||||||
</li>
|
</li>
|
||||||
{% if is_granted('CHILL_TASK_TASK_UPDATE', task) %}
|
{% if is_granted('CHILL_TASK_TASK_UPDATE', task) %}
|
||||||
<li>
|
<li>
|
||||||
<a href="{{ path('chill_task_single_task_edit', { 'id': task.id }) }}" class="sc-button bt-update "></a>
|
<a href="{{ path('chill_task_single_task_edit', { 'id': task.id, 'list_params': app.request.query.all }) }}" class="sc-button bt-update "></a>
|
||||||
</li>
|
</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if is_granted('CHILL_TASK_TASK_DELETE', task) %}
|
{% if is_granted('CHILL_TASK_TASK_DELETE', task) %}
|
||||||
<li>
|
<li>
|
||||||
<a href="{{ path('chill_task_single_task_delete', { 'id': task.id } ) }}" class="sc-button bt-delete "></a>
|
<a href="{{ path('chill_task_single_task_delete', { 'id': task.id, 'list_params': app.request.query.all } ) }}" class="sc-button bt-delete "></a>
|
||||||
</li>
|
</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
'title' : 'Remove task'|trans,
|
'title' : 'Remove task'|trans,
|
||||||
'confirm_question' : 'Are you sure you want to remove the task about "%name%" ?'|trans({ '%name%' : person.firstname ~ ' ' ~ person.lastname } ),
|
'confirm_question' : 'Are you sure you want to remove the task about "%name%" ?'|trans({ '%name%' : person.firstname ~ ' ' ~ person.lastname } ),
|
||||||
'cancel_route' : 'chill_task_singletask_list',
|
'cancel_route' : 'chill_task_singletask_list',
|
||||||
'cancel_parameters' : { 'person_id' : task.person.id, 'id' : task.id },
|
'cancel_parameters' : app.request.query.get('list_params', { } ),
|
||||||
'form' : delete_form
|
'form' : delete_form
|
||||||
} ) }}
|
} ) }}
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="cancel">
|
<li class="cancel">
|
||||||
<a href="{{ path('chill_task_single_task_show', { 'id': task.id } ) }}" class="sc-button">
|
<a href="{{ path('chill_task_single_task_show', { 'id': task.id, 'list_params': app.request.query.get('list_params', { } )} ) }}" class="sc-button">
|
||||||
{{ 'Cancel'|trans }}
|
{{ 'Cancel'|trans }}
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
@ -90,7 +90,7 @@
|
|||||||
|
|
||||||
<ul class="record_actions">
|
<ul class="record_actions">
|
||||||
<li class="cancel">
|
<li class="cancel">
|
||||||
<a class="sc-button bt-cancel" href="{{ path('chill_task_singletask_list', { 'person_id': person.id } ) }}">
|
<a class="sc-button bt-cancel" href="{{ path('chill_task_singletask_list', app.request.query.get('list_params', {}) ) }}">
|
||||||
{{ 'Back to the list'|trans }}
|
{{ 'Back to the list'|trans }}
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
@ -43,7 +43,7 @@ class CountNotificationTask implements NotificationCounterInterface
|
|||||||
*/
|
*/
|
||||||
protected $cachePool;
|
protected $cachePool;
|
||||||
|
|
||||||
const CACHE_KEY = 'chill_task.count_notifications.user.%d';
|
const CACHE_KEY = 'chill_task.count_notifications.user.%d.%s';
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
SingleTaskRepository $singleTaskRepository,
|
SingleTaskRepository $singleTaskRepository,
|
||||||
@ -54,12 +54,29 @@ class CountNotificationTask implements NotificationCounterInterface
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function countNotification(UserInterface $u): int
|
public function countNotification(UserInterface $u): int
|
||||||
|
{
|
||||||
|
return
|
||||||
|
$this->countNotificationEnded($u)
|
||||||
|
+ $this->countNotificationWarning($u);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function countNotificationEnded(UserInterface $u): int
|
||||||
|
{
|
||||||
|
return $this->_countNotification($u, SingleTaskRepository::DATE_STATUS_ENDED);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function countNotificationWarning(UserInterface $u): int
|
||||||
|
{
|
||||||
|
return $this->_countNotification($u, SingleTaskRepository::DATE_STATUS_WARNING);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _countNotification(UserInterface $u, $status)
|
||||||
{
|
{
|
||||||
if (!$u instanceof User) {
|
if (!$u instanceof User) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
$sumCache = $this->cachePool->getItem($this->getCacheKey($u));
|
$sumCache = $this->cachePool->getItem($this->getCacheKey($u, $status));
|
||||||
|
|
||||||
if ($sumCache->isHit()) {
|
if ($sumCache->isHit()) {
|
||||||
return $sumCache->get();
|
return $sumCache->get();
|
||||||
@ -70,16 +87,9 @@ class CountNotificationTask implements NotificationCounterInterface
|
|||||||
'is_closed' => false
|
'is_closed' => false
|
||||||
];
|
];
|
||||||
|
|
||||||
$sum = 0;
|
$sum = $this->singleTaskRepository->countByParameters(
|
||||||
|
|
||||||
foreach ([
|
|
||||||
SingleTaskRepository::DATE_STATUS_ENDED,
|
|
||||||
SingleTaskRepository::DATE_STATUS_WARNING] as $status) {
|
|
||||||
|
|
||||||
$sum += $this->singleTaskRepository->countByParameters(
|
|
||||||
\array_merge($params, [ 'date_status' => $status ])
|
\array_merge($params, [ 'date_status' => $status ])
|
||||||
);
|
);
|
||||||
}
|
|
||||||
|
|
||||||
$sumCache->set($sum);
|
$sumCache->set($sum);
|
||||||
$this->cachePool->save($sumCache);
|
$this->cachePool->save($sumCache);
|
||||||
@ -106,8 +116,8 @@ class CountNotificationTask implements NotificationCounterInterface
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getCacheKey(User $u)
|
private function getCacheKey(User $u, $status)
|
||||||
{
|
{
|
||||||
return sprintf(self::CACHE_KEY, $u->getId());
|
return sprintf(self::CACHE_KEY, $u->getId(), $status);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user