add filtering in task list

This commit is contained in:
Julien Fastré 2021-10-27 13:32:52 +02:00
parent 691c5ffd21
commit f4fb375fd1
4 changed files with 97 additions and 3 deletions

View File

@ -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:

View File

@ -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;
} }

View File

@ -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 %}

View File

@ -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