mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
129 lines
3.9 KiB
PHP
129 lines
3.9 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
/*
|
|
* Chill is a software for social workers
|
|
*
|
|
* For the full copyright and license information, please view
|
|
* the LICENSE file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Chill\ActivityBundle\Export\Export\LinkedToACP;
|
|
|
|
use Chill\ActivityBundle\Entity\Activity;
|
|
use Chill\ActivityBundle\Export\Declarations;
|
|
use Chill\ActivityBundle\Security\Authorization\ActivityStatsVoter;
|
|
use Chill\MainBundle\Export\ExportInterface;
|
|
use Chill\MainBundle\Export\FormatterInterface;
|
|
use Chill\MainBundle\Export\GroupedExportInterface;
|
|
use Chill\PersonBundle\Entity\AccompanyingPeriodParticipation;
|
|
use Chill\PersonBundle\Entity\Person\PersonCenterHistory;
|
|
use Chill\PersonBundle\Export\Declarations as PersonDeclarations;
|
|
use Doctrine\ORM\EntityManagerInterface;
|
|
use Doctrine\ORM\EntityRepository;
|
|
use Doctrine\ORM\Query;
|
|
use LogicException;
|
|
use Symfony\Component\Form\FormBuilderInterface;
|
|
|
|
class SumActivityVisitDuration implements ExportInterface, GroupedExportInterface
|
|
{
|
|
protected EntityRepository $repository;
|
|
|
|
public function __construct(
|
|
EntityManagerInterface $em
|
|
) {
|
|
$this->repository = $em->getRepository(Activity::class);
|
|
}
|
|
|
|
public function buildForm(FormBuilderInterface $builder)
|
|
{
|
|
// TODO: Implement buildForm() method.
|
|
}
|
|
|
|
public function getAllowedFormattersTypes(): array
|
|
{
|
|
return [FormatterInterface::TYPE_TABULAR];
|
|
}
|
|
|
|
public function getDescription(): string
|
|
{
|
|
return 'Sum activities linked to an accompanying period visit duration by various parameters.';
|
|
}
|
|
|
|
public function getGroup(): string
|
|
{
|
|
return 'Exports of activities linked to an accompanying period';
|
|
}
|
|
|
|
public function getLabels($key, array $values, $data)
|
|
{
|
|
if ('export_sum_activity_visit_duration' !== $key) {
|
|
throw new LogicException("the key {$key} is not used by this export");
|
|
}
|
|
|
|
return static fn ($value) => '_header' === $value ? 'Sum activities linked to an accompanying period visit duration' : $value;
|
|
}
|
|
|
|
public function getQueryKeys($data): array
|
|
{
|
|
return ['export_sum_activity_visit_duration'];
|
|
}
|
|
|
|
public function getResult($qb, $data)
|
|
{
|
|
return $qb->getQuery()->getResult(Query::HYDRATE_SCALAR);
|
|
}
|
|
|
|
public function getTitle(): string
|
|
{
|
|
return 'Sum activity linked to an accompanying period visit duration';
|
|
}
|
|
|
|
public function getType(): string
|
|
{
|
|
return Declarations::ACTIVITY;
|
|
}
|
|
|
|
public function initiateQuery(array $requiredModifiers, array $acl, array $data = [])
|
|
{
|
|
$centers = array_map(static function ($el) {
|
|
return $el['center'];
|
|
}, $acl);
|
|
|
|
$qb = $this->repository
|
|
->createQueryBuilder('activity')
|
|
->join('activity.accompanyingPeriod', 'acp');
|
|
|
|
$qb->select('SUM(activity.travelTime) as export_sum_activity_visit_duration')
|
|
->andWhere($qb->expr()->isNotNull('activity.travelTime'));
|
|
|
|
$qb
|
|
->andWhere(
|
|
$qb->expr()->exists(
|
|
'SELECT 1 FROM ' . AccompanyingPeriodParticipation::class . ' acl_count_part
|
|
JOIN ' . PersonCenterHistory::class . ' acl_count_person_history WITH IDENTITY(acl_count_person_history.person) = IDENTITY(acl_count_part.person)
|
|
WHERE acl_count_part.accompanyingPeriod = acp.id AND acl_count_person_history.center IN (:authorized_centers)
|
|
'
|
|
)
|
|
)
|
|
->setParameter('authorized_centers', $centers);
|
|
|
|
return $qb;
|
|
}
|
|
|
|
public function requiredRole(): string
|
|
{
|
|
return ActivityStatsVoter::STATS;
|
|
}
|
|
|
|
public function supportsModifiers(): array
|
|
{
|
|
return [
|
|
Declarations::ACTIVITY,
|
|
Declarations::ACTIVITY_ACP,
|
|
PersonDeclarations::ACP_TYPE,
|
|
];
|
|
}
|
|
}
|