mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
add filtering in task list
This commit is contained in:
parent
691c5ffd21
commit
f4fb375fd1
@ -5,6 +5,8 @@ namespace Chill\TaskBundle\Controller;
|
|||||||
use Chill\MainBundle\Entity\Scope;
|
use Chill\MainBundle\Entity\Scope;
|
||||||
use Chill\MainBundle\Security\Resolver\CenterResolverDispatcher;
|
use Chill\MainBundle\Security\Resolver\CenterResolverDispatcher;
|
||||||
use Chill\MainBundle\Security\Resolver\CenterResolverInterface;
|
use Chill\MainBundle\Security\Resolver\CenterResolverInterface;
|
||||||
|
use Chill\MainBundle\Templating\Listing\FilterOrderHelper;
|
||||||
|
use Chill\MainBundle\Templating\Listing\FilterOrderHelperFactoryInterface;
|
||||||
use Chill\PersonBundle\Privacy\PrivacyEvent;
|
use Chill\PersonBundle\Privacy\PrivacyEvent;
|
||||||
use Chill\TaskBundle\Repository\SingleTaskAclAwareRepositoryInterface;
|
use Chill\TaskBundle\Repository\SingleTaskAclAwareRepositoryInterface;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
@ -54,6 +56,7 @@ final class SingleTaskController extends AbstractController
|
|||||||
private TranslatorInterface $translator;
|
private TranslatorInterface $translator;
|
||||||
private PaginatorFactory $paginatorFactory;
|
private PaginatorFactory $paginatorFactory;
|
||||||
private SingleTaskAclAwareRepositoryInterface $singleTaskAclAwareRepository;
|
private SingleTaskAclAwareRepositoryInterface $singleTaskAclAwareRepository;
|
||||||
|
private FilterOrderHelperFactoryInterface $filterOrderHelperFactory;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
CenterResolverDispatcher $centerResolverDispatcher,
|
CenterResolverDispatcher $centerResolverDispatcher,
|
||||||
@ -62,7 +65,8 @@ final class SingleTaskController extends AbstractController
|
|||||||
TranslatorInterface $translator,
|
TranslatorInterface $translator,
|
||||||
EventDispatcherInterface $eventDispatcher,
|
EventDispatcherInterface $eventDispatcher,
|
||||||
TimelineBuilder $timelineBuilder,
|
TimelineBuilder $timelineBuilder,
|
||||||
LoggerInterface $logger
|
LoggerInterface $logger,
|
||||||
|
FilterOrderHelperFactoryInterface $filterOrderHelperFactory
|
||||||
) {
|
) {
|
||||||
$this->eventDispatcher = $eventDispatcher;
|
$this->eventDispatcher = $eventDispatcher;
|
||||||
$this->timelineBuilder = $timelineBuilder;
|
$this->timelineBuilder = $timelineBuilder;
|
||||||
@ -71,6 +75,7 @@ final class SingleTaskController extends AbstractController
|
|||||||
$this->centerResolverDispatcher = $centerResolverDispatcher;
|
$this->centerResolverDispatcher = $centerResolverDispatcher;
|
||||||
$this->paginatorFactory = $paginatorFactory;
|
$this->paginatorFactory = $paginatorFactory;
|
||||||
$this->singleTaskAclAwareRepository = $singleTaskAclAwareRepository;
|
$this->singleTaskAclAwareRepository = $singleTaskAclAwareRepository;
|
||||||
|
$this->filterOrderHelperFactory = $filterOrderHelperFactory;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getEntityContext(Request $request)
|
private function getEntityContext(Request $request)
|
||||||
@ -526,19 +531,42 @@ final class SingleTaskController extends AbstractController
|
|||||||
{
|
{
|
||||||
$this->denyAccessUnlessGranted('ROLE_USER');
|
$this->denyAccessUnlessGranted('ROLE_USER');
|
||||||
|
|
||||||
$nb = $this->singleTaskAclAwareRepository->countByCurrentUsersTasks();
|
$filterOrder = $this->buildFilterOrder();
|
||||||
|
$nb = $this->singleTaskAclAwareRepository->countByCurrentUsersTasks(
|
||||||
|
$filterOrder->getQueryString(),
|
||||||
|
$filterOrder->getCheckbox('status')
|
||||||
|
);
|
||||||
$paginator = $this->paginatorFactory->create($nb);
|
$paginator = $this->paginatorFactory->create($nb);
|
||||||
$tasks = $this->singleTaskAclAwareRepository->findByCurrentUsersTasks(
|
$tasks = $this->singleTaskAclAwareRepository->findByCurrentUsersTasks(
|
||||||
null, [], $paginator->getCurrentPageFirstItemNumber(),
|
$filterOrder->getQueryString(),
|
||||||
|
$filterOrder->getCheckbox('status'),
|
||||||
|
$paginator->getCurrentPageFirstItemNumber(),
|
||||||
$paginator->getItemsPerPage()
|
$paginator->getItemsPerPage()
|
||||||
);
|
);
|
||||||
|
|
||||||
return $this->render('@ChillTask/SingleTask/List/index.html.twig', [
|
return $this->render('@ChillTask/SingleTask/List/index.html.twig', [
|
||||||
'tasks' => $tasks,
|
'tasks' => $tasks,
|
||||||
'paginator' => $paginator,
|
'paginator' => $paginator,
|
||||||
|
'filter_order' => $filterOrder,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function buildFilterOrder(): FilterOrderHelper
|
||||||
|
{
|
||||||
|
$statuses = ['no-alert', 'warning', 'alert'];
|
||||||
|
$statusTrans = [
|
||||||
|
'Tasks near deadline',
|
||||||
|
'Tasks over deadline',
|
||||||
|
'Tasks without alert',
|
||||||
|
];
|
||||||
|
return $this->filterOrderHelperFactory
|
||||||
|
->create(self::class)
|
||||||
|
->addSearchBox()
|
||||||
|
->addCheckbox('status', $statuses, $statuses, $statusTrans)
|
||||||
|
->build()
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* Arguments:
|
* Arguments:
|
||||||
|
@ -61,6 +61,66 @@ final class SingleTaskAclAwareRepository implements SingleTaskAclAwareRepository
|
|||||||
->setParameter('user', $this->security->getUser())
|
->setParameter('user', $this->security->getUser())
|
||||||
;
|
;
|
||||||
|
|
||||||
|
if (!empty($pattern)) {
|
||||||
|
$qb->andWhere($qb->expr()->like('LOWER(UNACCENT(t.title))', 'LOWER(UNACCENT(:pattern))'))
|
||||||
|
->setParameter('pattern', $pattern)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($flags) > 0) {
|
||||||
|
$orX = $qb->expr()->orX();
|
||||||
|
$now = new \DateTime();
|
||||||
|
|
||||||
|
if (\in_array('no-alert', $flags)) {
|
||||||
|
$orX
|
||||||
|
->add(
|
||||||
|
$qb->expr()->orX(
|
||||||
|
$qb->expr()->isNull('t.endDate'),
|
||||||
|
$qb->expr()->gte('t.endDate - COALESCE(t.warningInterval, :intervalBlank)', ':now')
|
||||||
|
)
|
||||||
|
);
|
||||||
|
$qb
|
||||||
|
->setParameter('intervalBlank', new \DateInterval('P0D'))
|
||||||
|
->setParameter('now', $now)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (\in_array('warning', $flags)) {
|
||||||
|
$orX
|
||||||
|
->add(
|
||||||
|
$qb->expr()->andX(
|
||||||
|
$qb->expr()->eq('t.closed', "'FALSE'"),
|
||||||
|
$qb->expr()->not($qb->expr()->isNull('t.endDate')),
|
||||||
|
$qb->expr()->not($qb->expr()->isNull('t.warningInterval')),
|
||||||
|
$qb->expr()->lte('t.endDate - t.warningInterval', ':now')
|
||||||
|
)
|
||||||
|
)
|
||||||
|
;
|
||||||
|
$qb
|
||||||
|
->setParameter('now', $now)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (\in_array('alert', $flags)) {
|
||||||
|
$orX
|
||||||
|
->add(
|
||||||
|
$qb->expr()->andX(
|
||||||
|
$qb->expr()->eq('t.closed', "'FALSE'"),
|
||||||
|
$qb->expr()->not($qb->expr()->isNull('t.endDate')),
|
||||||
|
$qb->expr()->lte('t.endDate', ':now')
|
||||||
|
)
|
||||||
|
)
|
||||||
|
;
|
||||||
|
$qb
|
||||||
|
->setParameter('now', $now)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
$qb->andWhere($orX);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return $qb;
|
return $qb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,8 @@
|
|||||||
|
|
||||||
<h1>{{ block('title') }}</h1>
|
<h1>{{ block('title') }}</h1>
|
||||||
|
|
||||||
|
{{ filter_order|chill_render_filter_order_helper }}
|
||||||
|
|
||||||
{% if tasks|length == 0 %}
|
{% if tasks|length == 0 %}
|
||||||
<p class="chill-no-data-statement">{{ 'Any tasks'|trans }}</p>
|
<p class="chill-no-data-statement">{{ 'Any tasks'|trans }}</p>
|
||||||
{% else %}
|
{% else %}
|
||||||
|
@ -97,6 +97,10 @@ Are you sure you want to start this task ?: Êtes-vous sûrs de vouloir démarre
|
|||||||
"%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ées"
|
"%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ées"
|
||||||
"%number% tasks near deadline": "{0} Aucune tâche en rappel|{1} Une tâche en rappel | ]1,Inf[ %count% tâches en rappel"
|
"%number% tasks near deadline": "{0} Aucune tâche en rappel|{1} Une tâche en rappel | ]1,Inf[ %count% tâches en rappel"
|
||||||
|
|
||||||
|
Tasks near deadline: Tâches à échéance proche
|
||||||
|
Tasks over deadline: Tâches à échéance dépassée
|
||||||
|
Tasks without alert: Tâches sans alerte
|
||||||
|
|
||||||
#title
|
#title
|
||||||
My tasks near deadline: Mes tâches à échéance proche
|
My tasks near deadline: Mes tâches à échéance proche
|
||||||
My tasks over deadline: Mes tâches à échéance dépassée
|
My tasks over deadline: Mes tâches à échéance dépassée
|
||||||
|
Loading…
x
Reference in New Issue
Block a user