Merge branch 'tasks_mission_type_filter' into 'master'

Add filter to tasks based on mission type (AMLI)

See merge request Chill-Projet/chill-bundles!588
This commit is contained in:
LenaertsJ 2023-09-14 14:08:33 +00:00
commit 6a554c1c8c
5 changed files with 76 additions and 40 deletions

View File

@ -0,0 +1,6 @@
kind: Fixed
body: Reimplement the mission type filter on tasks, only for instances that have a
config parameter indicating true for this.
time: 2023-08-21T11:57:38.273630026+02:00
custom:
Issue: ""

View File

@ -26,6 +26,7 @@ use Chill\TaskBundle\Event\TaskEvent;
use Chill\TaskBundle\Event\UI\UIEvent; use Chill\TaskBundle\Event\UI\UIEvent;
use Chill\TaskBundle\Form\SingleTaskType; use Chill\TaskBundle\Form\SingleTaskType;
use Chill\TaskBundle\Repository\SingleTaskAclAwareRepositoryInterface; use Chill\TaskBundle\Repository\SingleTaskAclAwareRepositoryInterface;
use Chill\TaskBundle\Repository\SingleTaskRepository;
use Chill\TaskBundle\Repository\SingleTaskStateRepository; use Chill\TaskBundle\Repository\SingleTaskStateRepository;
use Chill\TaskBundle\Security\Authorization\TaskVoter; use Chill\TaskBundle\Security\Authorization\TaskVoter;
use LogicException; use LogicException;
@ -48,42 +49,18 @@ use function array_merge;
final class SingleTaskController extends AbstractController final class SingleTaskController extends AbstractController
{ {
private CenterResolverDispatcherInterface $centerResolverDispatcher;
private EventDispatcherInterface $eventDispatcher;
private FilterOrderHelperFactoryInterface $filterOrderHelperFactory;
private LoggerInterface $logger;
private PaginatorFactory $paginatorFactory;
private SingleTaskAclAwareRepositoryInterface $singleTaskAclAwareRepository;
private TimelineBuilder $timelineBuilder;
private TranslatorInterface $translator;
public function __construct( public function __construct(
CenterResolverDispatcherInterface $centerResolverDispatcher, private CenterResolverDispatcherInterface $centerResolverDispatcher,
PaginatorFactory $paginatorFactory, private PaginatorFactory $paginatorFactory,
SingleTaskAclAwareRepositoryInterface $singleTaskAclAwareRepository, private SingleTaskAclAwareRepositoryInterface $singleTaskAclAwareRepository,
TranslatorInterface $translator, private TranslatorInterface $translator,
EventDispatcherInterface $eventDispatcher, private EventDispatcherInterface $eventDispatcher,
TimelineBuilder $timelineBuilder, private TimelineBuilder $timelineBuilder,
LoggerInterface $logger, private LoggerInterface $logger,
FilterOrderHelperFactoryInterface $filterOrderHelperFactory, private FilterOrderHelperFactoryInterface $filterOrderHelperFactory,
private SingleTaskStateRepository $singleTaskStateRepository private SingleTaskStateRepository $singleTaskStateRepository,
) { private SingleTaskRepository $singleTaskRepository
$this->eventDispatcher = $eventDispatcher; ) {}
$this->timelineBuilder = $timelineBuilder;
$this->logger = $logger;
$this->translator = $translator;
$this->centerResolverDispatcher = $centerResolverDispatcher;
$this->paginatorFactory = $paginatorFactory;
$this->singleTaskAclAwareRepository = $singleTaskAclAwareRepository;
$this->filterOrderHelperFactory = $filterOrderHelperFactory;
}
/** /**
* @Route( * @Route(
@ -300,7 +277,9 @@ final class SingleTaskController extends AbstractController
) { ) {
$this->denyAccessUnlessGranted(TaskVoter::SHOW, null); $this->denyAccessUnlessGranted(TaskVoter::SHOW, null);
$filterOrder = $this->buildFilterOrder(); $showMissionTypeFilter = $this->singleTaskRepository->countByDistinctTypes() > 1;
$filterOrder = $this->buildFilterOrder(true, $showMissionTypeFilter);
$filteredUsers = $filterOrder->getUserPickerData('userPicker'); $filteredUsers = $filterOrder->getUserPickerData('userPicker');
@ -308,9 +287,15 @@ final class SingleTaskController extends AbstractController
$filterOrder->getCheckboxData('status'), $filterOrder->getCheckboxData('status'),
array_map(static fn ($i) => 'state_' . $i, $filterOrder->hasCheckboxData('states') ? $filterOrder->getCheckboxData('states') : []) array_map(static fn ($i) => 'state_' . $i, $filterOrder->hasCheckboxData('states') ? $filterOrder->getCheckboxData('states') : [])
); );
if ($showMissionTypeFilter) {
$types = $filterOrder->getCheckboxData('missionTypePicker');
}
$nb = $this->singleTaskAclAwareRepository->countByAllViewable( $nb = $this->singleTaskAclAwareRepository->countByAllViewable(
$filterOrder->getQueryString(), $filterOrder->getQueryString(),
$flags, $flags,
$types ?? [],
$filteredUsers $filteredUsers
); );
$paginator = $this->paginatorFactory->create($nb); $paginator = $this->paginatorFactory->create($nb);
@ -319,6 +304,7 @@ final class SingleTaskController extends AbstractController
$tasks = $this->singleTaskAclAwareRepository->findByAllViewable( $tasks = $this->singleTaskAclAwareRepository->findByAllViewable(
$filterOrder->getQueryString(), $filterOrder->getQueryString(),
$flags, $flags,
$types ?? [],
$filteredUsers, $filteredUsers,
$paginator->getCurrentPageFirstItemNumber(), $paginator->getCurrentPageFirstItemNumber(),
$paginator->getItemsPerPage(), $paginator->getItemsPerPage(),
@ -669,7 +655,7 @@ final class SingleTaskController extends AbstractController
return $form; return $form;
} }
private function buildFilterOrder($includeFilterByUser = true): FilterOrderHelper private function buildFilterOrder($includeFilterByUser = true, $includeMissionType = false): FilterOrderHelper
{ {
$statuses = ['no-alert', 'warning', 'alert']; $statuses = ['no-alert', 'warning', 'alert'];
$statusTrans = [ $statusTrans = [
@ -677,6 +663,7 @@ final class SingleTaskController extends AbstractController
'Tasks near deadline', 'Tasks near deadline',
'Tasks over deadline', 'Tasks over deadline',
]; ];
$arrayOfTypes = [];
$filterBuilder = $this->filterOrderHelperFactory $filterBuilder = $this->filterOrderHelperFactory
->create(self::class) ->create(self::class)
@ -696,6 +683,16 @@ final class SingleTaskController extends AbstractController
->addUserPicker('userPicker', 'Filter by user', ['multiple' => true, 'required' => false]); ->addUserPicker('userPicker', 'Filter by user', ['multiple' => true, 'required' => false]);
} }
if ($includeMissionType) {
$filterBuilder->addCheckbox(
'missionTypePicker',
array_map(
fn ($row) => $row['type'],
$this->singleTaskRepository->findAllTaskDistinctTypes()
)
);
}
return $filterBuilder->build(); return $filterBuilder->build();
} }

View File

@ -52,6 +52,7 @@ final class SingleTaskAclAwareRepository implements SingleTaskAclAwareRepository
public function buildBaseQuery( public function buildBaseQuery(
?string $pattern = null, ?string $pattern = null,
?array $flags = [], ?array $flags = [],
?array $types = [],
?array $users = [] ?array $users = []
): QueryBuilder { ): QueryBuilder {
$qb = $this->em->createQueryBuilder(); $qb = $this->em->createQueryBuilder();
@ -77,8 +78,12 @@ final class SingleTaskAclAwareRepository implements SingleTaskAclAwareRepository
if ($orXUser->count() > 0) { if ($orXUser->count() > 0) {
$qb->andWhere($orXUser); $qb->andWhere($orXUser);
} }
}
return $qb; if (null !== $types && count($types) > 0) {
$qb->andWhere($qb->expr()->in('t.type', ':types'));
$qb->setParameter('types', $types);
} }
if (null !== $flags && count($flags) > 0) { if (null !== $flags && count($flags) > 0) {
@ -203,9 +208,10 @@ final class SingleTaskAclAwareRepository implements SingleTaskAclAwareRepository
public function countByAllViewable( public function countByAllViewable(
?string $pattern = null, ?string $pattern = null,
?array $flags = [], ?array $flags = [],
?array $types = [],
?array $users = [] ?array $users = []
): int { ): int {
$qb = $this->buildBaseQuery($pattern, $flags, $users); $qb = $this->buildBaseQuery($pattern, $flags, $types, $users);
return $this return $this
->addACLGlobal($qb) ->addACLGlobal($qb)
@ -251,12 +257,13 @@ final class SingleTaskAclAwareRepository implements SingleTaskAclAwareRepository
public function findByAllViewable( public function findByAllViewable(
?string $pattern = null, ?string $pattern = null,
?array $flags = [], ?array $flags = [],
?array $types = [],
?array $users = [], ?array $users = [],
?int $start = 0, ?int $start = 0,
?int $limit = 50, ?int $limit = 50,
?array $orderBy = [] ?array $orderBy = []
): array { ): array {
$qb = $this->buildBaseQuery($pattern, $flags, $users); $qb = $this->buildBaseQuery($pattern, $flags, $types, $users);
$qb = $this->addACLGlobal($qb); $qb = $this->addACLGlobal($qb);
return $this->getResult($qb, $start, $limit, $orderBy); return $this->getResult($qb, $start, $limit, $orderBy);

View File

@ -19,6 +19,7 @@ interface SingleTaskAclAwareRepositoryInterface
public function countByAllViewable( public function countByAllViewable(
?string $pattern = null, ?string $pattern = null,
?array $flags = [], ?array $flags = [],
?array $types = [],
?array $users = [] ?array $users = []
): int; ): int;
@ -39,6 +40,7 @@ interface SingleTaskAclAwareRepositoryInterface
public function findByAllViewable( public function findByAllViewable(
?string $pattern = null, ?string $pattern = null,
?array $flags = [], ?array $flags = [],
?array $types = [],
?array $users = [], ?array $users = [],
?int $start = 0, ?int $start = 0,
?int $limit = 50, ?int $limit = 50,

View File

@ -306,4 +306,28 @@ class SingleTaskRepository extends EntityRepository
->add($qb->expr()->isNull('st.endDate')) ->add($qb->expr()->isNull('st.endDate'))
->add($qb->expr()->isNull('st.warningInterval')); ->add($qb->expr()->isNull('st.warningInterval'));
} }
public function countByDistinctTypes()
{
$qb = $this->createQueryBuilder('st')
->select('COUNT(DISTINCT st.type)');
$this->buildQuery($qb, []);
return (int) $qb
->getQuery()
->getSingleScalarResult();
}
public function findAllTaskDistinctTypes()
{
$qb = $this->createQueryBuilder('st')
->select('DISTINCT st.type');
$this->buildQuery($qb, []);
return $qb
->getQuery()
->getResult();
}
} }