mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
Refactor ListAccompanyingPeriod to use a helper for most of the work
This commit is contained in:
parent
c19232de35
commit
7ccff61c25
@ -29,6 +29,7 @@ use Chill\PersonBundle\Entity\Household\PersonHouseholdAddress;
|
|||||||
use Chill\PersonBundle\Entity\Person\PersonCenterHistory;
|
use Chill\PersonBundle\Entity\Person\PersonCenterHistory;
|
||||||
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
||||||
use Chill\PersonBundle\Export\Declarations;
|
use Chill\PersonBundle\Export\Declarations;
|
||||||
|
use Chill\PersonBundle\Export\Helper\ListAccompanyingPeriodHelper;
|
||||||
use Chill\PersonBundle\Repository\PersonRepository;
|
use Chill\PersonBundle\Repository\PersonRepository;
|
||||||
use Chill\PersonBundle\Repository\SocialWork\SocialIssueRepository;
|
use Chill\PersonBundle\Repository\SocialWork\SocialIssueRepository;
|
||||||
use Chill\PersonBundle\Security\Authorization\PersonVoter;
|
use Chill\PersonBundle\Security\Authorization\PersonVoter;
|
||||||
@ -45,95 +46,13 @@ use Symfony\Component\Form\FormBuilderInterface;
|
|||||||
use Symfony\Contracts\Translation\TranslatorInterface;
|
use Symfony\Contracts\Translation\TranslatorInterface;
|
||||||
use function strlen;
|
use function strlen;
|
||||||
|
|
||||||
class ListAccompanyingPeriod implements ListInterface, GroupedExportInterface
|
final readonly class ListAccompanyingPeriod implements ListInterface, GroupedExportInterface
|
||||||
{
|
{
|
||||||
private const FIELDS = [
|
|
||||||
'id',
|
|
||||||
'step',
|
|
||||||
'stepSince',
|
|
||||||
'openingDate',
|
|
||||||
'closingDate',
|
|
||||||
'referrer',
|
|
||||||
'referrerSince',
|
|
||||||
'administrativeLocation',
|
|
||||||
'locationIsPerson',
|
|
||||||
'locationIsTemp',
|
|
||||||
'locationPersonName',
|
|
||||||
'locationPersonId',
|
|
||||||
'origin',
|
|
||||||
'closingMotive',
|
|
||||||
'confidential',
|
|
||||||
'emergency',
|
|
||||||
'intensity',
|
|
||||||
'job',
|
|
||||||
'isRequestorPerson',
|
|
||||||
'isRequestorThirdParty',
|
|
||||||
'requestorPerson',
|
|
||||||
'requestorPersonId',
|
|
||||||
'requestorThirdParty',
|
|
||||||
'requestorThirdPartyId',
|
|
||||||
'scopes',
|
|
||||||
'socialIssues',
|
|
||||||
'createdAt',
|
|
||||||
'createdBy',
|
|
||||||
'updatedAt',
|
|
||||||
'updatedBy',
|
|
||||||
];
|
|
||||||
|
|
||||||
private ExportAddressHelper $addressHelper;
|
|
||||||
|
|
||||||
private DateTimeHelper $dateTimeHelper;
|
|
||||||
|
|
||||||
private EntityManagerInterface $entityManager;
|
|
||||||
|
|
||||||
private PersonRenderInterface $personRender;
|
|
||||||
|
|
||||||
private PersonRepository $personRepository;
|
|
||||||
|
|
||||||
private RollingDateConverterInterface $rollingDateConverter;
|
|
||||||
|
|
||||||
private SocialIssueRender $socialIssueRender;
|
|
||||||
|
|
||||||
private SocialIssueRepository $socialIssueRepository;
|
|
||||||
|
|
||||||
private ThirdPartyRender $thirdPartyRender;
|
|
||||||
|
|
||||||
private ThirdPartyRepository $thirdPartyRepository;
|
|
||||||
|
|
||||||
private TranslatableStringHelperInterface $translatableStringHelper;
|
|
||||||
|
|
||||||
private TranslatorInterface $translator;
|
|
||||||
|
|
||||||
private UserHelper $userHelper;
|
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
ExportAddressHelper $addressHelper,
|
private EntityManagerInterface $entityManager,
|
||||||
DateTimeHelper $dateTimeHelper,
|
private RollingDateConverterInterface $rollingDateConverter,
|
||||||
EntityManagerInterface $entityManager,
|
private ListAccompanyingPeriodHelper $listAccompanyingPeriodHelper,
|
||||||
PersonRenderInterface $personRender,
|
|
||||||
PersonRepository $personRepository,
|
|
||||||
ThirdPartyRepository $thirdPartyRepository,
|
|
||||||
ThirdPartyRender $thirdPartyRender,
|
|
||||||
SocialIssueRepository $socialIssueRepository,
|
|
||||||
SocialIssueRender $socialIssueRender,
|
|
||||||
TranslatableStringHelperInterface $translatableStringHelper,
|
|
||||||
TranslatorInterface $translator,
|
|
||||||
RollingDateConverterInterface $rollingDateConverter,
|
|
||||||
UserHelper $userHelper
|
|
||||||
) {
|
) {
|
||||||
$this->addressHelper = $addressHelper;
|
|
||||||
$this->dateTimeHelper = $dateTimeHelper;
|
|
||||||
$this->entityManager = $entityManager;
|
|
||||||
$this->personRender = $personRender;
|
|
||||||
$this->personRepository = $personRepository;
|
|
||||||
$this->socialIssueRender = $socialIssueRender;
|
|
||||||
$this->socialIssueRepository = $socialIssueRepository;
|
|
||||||
$this->thirdPartyRender = $thirdPartyRender;
|
|
||||||
$this->thirdPartyRepository = $thirdPartyRepository;
|
|
||||||
$this->translatableStringHelper = $translatableStringHelper;
|
|
||||||
$this->translator = $translator;
|
|
||||||
$this->rollingDateConverter = $rollingDateConverter;
|
|
||||||
$this->userHelper = $userHelper;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function buildForm(FormBuilderInterface $builder)
|
public function buildForm(FormBuilderInterface $builder)
|
||||||
@ -169,141 +88,12 @@ class ListAccompanyingPeriod implements ListInterface, GroupedExportInterface
|
|||||||
|
|
||||||
public function getLabels($key, array $values, $data)
|
public function getLabels($key, array $values, $data)
|
||||||
{
|
{
|
||||||
if (substr($key, 0, strlen('address_fields')) === 'address_fields') {
|
return $this->listAccompanyingPeriodHelper->getLabels($key, $values, $data);
|
||||||
return $this->addressHelper->getLabel($key, $values, $data, 'address_fields');
|
|
||||||
}
|
|
||||||
|
|
||||||
switch ($key) {
|
|
||||||
case 'stepSince':
|
|
||||||
case 'openingDate':
|
|
||||||
case 'closingDate':
|
|
||||||
case 'referrerSince':
|
|
||||||
case 'createdAt':
|
|
||||||
case 'updatedAt':
|
|
||||||
return $this->dateTimeHelper->getLabel('export.list.acp.' . $key);
|
|
||||||
|
|
||||||
case 'origin':
|
|
||||||
case 'closingMotive':
|
|
||||||
case 'job':
|
|
||||||
return function ($value) use ($key) {
|
|
||||||
if ('_header' === $value) {
|
|
||||||
return 'export.list.acp.' . $key;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (null === $value) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->translatableStringHelper->localize(json_decode($value, true, 512, JSON_THROW_ON_ERROR));
|
|
||||||
};
|
|
||||||
|
|
||||||
case 'locationPersonName':
|
|
||||||
case 'requestorPerson':
|
|
||||||
return function ($value) use ($key) {
|
|
||||||
if ('_header' === $value) {
|
|
||||||
return 'export.list.acp.' . $key;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (null === $value || null === $person = $this->personRepository->find($value)) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->personRender->renderString($person, []);
|
|
||||||
};
|
|
||||||
|
|
||||||
case 'requestorThirdParty':
|
|
||||||
return function ($value) use ($key) {
|
|
||||||
if ('_header' === $value) {
|
|
||||||
return 'export.list.acp.' . $key;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (null === $value || null === $thirdparty = $this->thirdPartyRepository->find($value)) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->thirdPartyRender->renderString($thirdparty, []);
|
|
||||||
};
|
|
||||||
|
|
||||||
case 'scopes':
|
|
||||||
return function ($value) use ($key) {
|
|
||||||
if ('_header' === $value) {
|
|
||||||
return 'export.list.acp.' . $key;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (null === $value) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
return implode(
|
|
||||||
'|',
|
|
||||||
array_map(
|
|
||||||
fn ($s) => $this->translatableStringHelper->localize($s),
|
|
||||||
json_decode($value, true, 512, JSON_THROW_ON_ERROR)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
case 'socialIssues':
|
|
||||||
return function ($value) use ($key) {
|
|
||||||
if ('_header' === $value) {
|
|
||||||
return 'export.list.acp.' . $key;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (null === $value) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
return implode(
|
|
||||||
'|',
|
|
||||||
array_map(
|
|
||||||
fn ($s) => $this->socialIssueRender->renderString($this->socialIssueRepository->find($s), []),
|
|
||||||
json_decode($value, true, 512, JSON_THROW_ON_ERROR)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
case 'step':
|
|
||||||
return fn ($value) => match ($value) {
|
|
||||||
'_header' => 'export.list.acp.step',
|
|
||||||
null => '',
|
|
||||||
AccompanyingPeriod::STEP_DRAFT => $this->translator->trans('course.draft'),
|
|
||||||
AccompanyingPeriod::STEP_CONFIRMED => $this->translator->trans('course.confirmed'),
|
|
||||||
AccompanyingPeriod::STEP_CLOSED => $this->translator->trans('course.closed'),
|
|
||||||
AccompanyingPeriod::STEP_CONFIRMED_INACTIVE_SHORT => $this->translator->trans('course.inactive_short'),
|
|
||||||
AccompanyingPeriod::STEP_CONFIRMED_INACTIVE_LONG => $this->translator->trans('course.inactive_long'),
|
|
||||||
default => $value,
|
|
||||||
};
|
|
||||||
|
|
||||||
case 'intensity':
|
|
||||||
return fn ($value) => match ($value) {
|
|
||||||
'_header' => 'export.list.acp.intensity',
|
|
||||||
null => '',
|
|
||||||
AccompanyingPeriod::INTENSITY_OCCASIONAL => $this->translator->trans('occasional'),
|
|
||||||
AccompanyingPeriod::INTENSITY_REGULAR => $this->translator->trans('regular'),
|
|
||||||
default => $value,
|
|
||||||
};
|
|
||||||
|
|
||||||
default:
|
|
||||||
return static function ($value) use ($key) {
|
|
||||||
if ('_header' === $value) {
|
|
||||||
return 'export.list.acp.' . $key;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (null === $value) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $value;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getQueryKeys($data)
|
public function getQueryKeys($data)
|
||||||
{
|
{
|
||||||
return array_merge(
|
return $this->listAccompanyingPeriodHelper->getQueryKeys($data);
|
||||||
self::FIELDS,
|
|
||||||
$this->addressHelper->getKeys(ExportAddressHelper::F_ALL, 'address_fields')
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getResult($query, $data)
|
public function getResult($query, $data)
|
||||||
@ -341,7 +131,7 @@ class ListAccompanyingPeriod implements ListInterface, GroupedExportInterface
|
|||||||
->setParameter('list_acp_step', AccompanyingPeriod::STEP_DRAFT)
|
->setParameter('list_acp_step', AccompanyingPeriod::STEP_DRAFT)
|
||||||
->setParameter('authorized_centers', $centers);
|
->setParameter('authorized_centers', $centers);
|
||||||
|
|
||||||
$this->addSelectClauses($qb, $this->rollingDateConverter->convert($data['calc_date']));
|
$this->listAccompanyingPeriodHelper->addSelectClauses($qb, $this->rollingDateConverter->convert($data['calc_date']));
|
||||||
|
|
||||||
return $qb;
|
return $qb;
|
||||||
}
|
}
|
||||||
@ -357,91 +147,4 @@ class ListAccompanyingPeriod implements ListInterface, GroupedExportInterface
|
|||||||
Declarations::ACP_TYPE,
|
Declarations::ACP_TYPE,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
private function addSelectClauses(QueryBuilder $qb, DateTimeImmutable $calcDate): void
|
|
||||||
{
|
|
||||||
// add the regular fields
|
|
||||||
foreach (['id', 'openingDate', 'closingDate', 'confidential', 'emergency', 'intensity', 'createdAt', 'updatedAt'] as $field) {
|
|
||||||
$qb->addSelect(sprintf('acp.%s AS %s', $field, $field));
|
|
||||||
}
|
|
||||||
|
|
||||||
// add the field which are simple association
|
|
||||||
foreach (['origin' => 'label', 'closingMotive' => 'name', 'job' => 'label', 'createdBy' => 'label', 'updatedBy' => 'label', 'administrativeLocation' => 'name'] as $entity => $field) {
|
|
||||||
$qb
|
|
||||||
->leftJoin(sprintf('acp.%s', $entity), "{$entity}_t")
|
|
||||||
->addSelect(sprintf('%s_t.%s AS %s', $entity, $field, $entity));
|
|
||||||
}
|
|
||||||
|
|
||||||
// step at date
|
|
||||||
$qb
|
|
||||||
->addSelect('stepHistory.step AS step')
|
|
||||||
->addSelect('stepHistory.startDate AS stepSince')
|
|
||||||
->leftJoin('acp.stepHistories', 'stepHistory')
|
|
||||||
->andWhere(
|
|
||||||
$qb->expr()->andX(
|
|
||||||
$qb->expr()->lte('stepHistory.startDate', ':calcDate'),
|
|
||||||
$qb->expr()->orX($qb->expr()->isNull('stepHistory.endDate'), $qb->expr()->gt('stepHistory.endDate', ':calcDate'))
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
// referree at date
|
|
||||||
$qb
|
|
||||||
->addSelect('referrer_t.label AS referrer')
|
|
||||||
->addSelect('userHistory.startDate AS referrerSince')
|
|
||||||
->leftJoin('acp.userHistories', 'userHistory')
|
|
||||||
->leftJoin('userHistory.user', 'referrer_t')
|
|
||||||
->andWhere(
|
|
||||||
$qb->expr()->orX(
|
|
||||||
$qb->expr()->isNull('userHistory'),
|
|
||||||
$qb->expr()->andX(
|
|
||||||
$qb->expr()->lte('userHistory.startDate', ':calcDate'),
|
|
||||||
$qb->expr()->orX($qb->expr()->isNull('userHistory.endDate'), $qb->expr()->gt('userHistory.endDate', ':calcDate'))
|
|
||||||
)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
// location of the acp
|
|
||||||
$qb
|
|
||||||
->addSelect('CASE WHEN locationHistory.personLocation IS NOT NULL THEN 1 ELSE 0 END AS locationIsPerson')
|
|
||||||
->addSelect('CASE WHEN locationHistory.personLocation IS NOT NULL THEN 0 ELSE 1 END AS locationIsTemp')
|
|
||||||
->addSelect('IDENTITY(locationHistory.personLocation) AS locationPersonName')
|
|
||||||
->addSelect('IDENTITY(locationHistory.personLocation) AS locationPersonId')
|
|
||||||
->leftJoin('acp.locationHistories', 'locationHistory')
|
|
||||||
->andWhere(
|
|
||||||
$qb->expr()->orX(
|
|
||||||
$qb->expr()->isNull('locationHistory'),
|
|
||||||
$qb->expr()->andX(
|
|
||||||
$qb->expr()->lte('locationHistory.startDate', ':calcDate'),
|
|
||||||
$qb->expr()->orX($qb->expr()->isNull('locationHistory.endDate'), $qb->expr()->gt('locationHistory.endDate', ':calcDate'))
|
|
||||||
)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
->leftJoin(
|
|
||||||
PersonHouseholdAddress::class,
|
|
||||||
'personAddress',
|
|
||||||
Join::WITH,
|
|
||||||
'locationHistory.personLocation = personAddress.person AND (personAddress.validFrom <= :calcDate AND (personAddress.validTo IS NULL OR personAddress.validTo > :calcDate))'
|
|
||||||
)
|
|
||||||
->leftJoin(Address::class, 'acp_address', Join::WITH, 'COALESCE(IDENTITY(locationHistory.addressLocation), IDENTITY(personAddress.address)) = acp_address.id');
|
|
||||||
|
|
||||||
$this->addressHelper->addSelectClauses(ExportAddressHelper::F_ALL, $qb, 'acp_address', 'address_fields');
|
|
||||||
|
|
||||||
// requestor
|
|
||||||
$qb
|
|
||||||
->addSelect('CASE WHEN acp.requestorPerson IS NULL THEN 1 ELSE 0 END AS isRequestorPerson')
|
|
||||||
->addSelect('CASE WHEN acp.requestorPerson IS NULL THEN 0 ELSE 1 END AS isRequestorThirdParty')
|
|
||||||
->addSelect('IDENTITY(acp.requestorPerson) AS requestorPersonId')
|
|
||||||
->addSelect('IDENTITY(acp.requestorThirdParty) AS requestorThirdPartyId')
|
|
||||||
->addSelect('IDENTITY(acp.requestorPerson) AS requestorPerson')
|
|
||||||
->addSelect('IDENTITY(acp.requestorThirdParty) AS requestorThirdParty');
|
|
||||||
|
|
||||||
$qb
|
|
||||||
// scopes
|
|
||||||
->addSelect('(SELECT AGGREGATE(scope.name) FROM ' . Scope::class . ' scope WHERE scope MEMBER OF acp.scopes) AS scopes')
|
|
||||||
// social issues
|
|
||||||
->addSelect('(SELECT AGGREGATE(socialIssue.id) FROM ' . SocialIssue::class . ' socialIssue WHERE socialIssue MEMBER OF acp.socialIssues) AS socialIssues');
|
|
||||||
|
|
||||||
// add parameter
|
|
||||||
$qb->setParameter('calcDate', $calcDate);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,306 @@
|
|||||||
|
<?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\PersonBundle\Export\Helper;
|
||||||
|
|
||||||
|
use Chill\MainBundle\Entity\Address;
|
||||||
|
use Chill\MainBundle\Entity\Scope;
|
||||||
|
use Chill\MainBundle\Export\Helper\DateTimeHelper;
|
||||||
|
use Chill\MainBundle\Export\Helper\ExportAddressHelper;
|
||||||
|
use Chill\MainBundle\Templating\TranslatableStringHelperInterface;
|
||||||
|
use Chill\PersonBundle\Entity\AccompanyingPeriod;
|
||||||
|
use Chill\PersonBundle\Entity\Household\PersonHouseholdAddress;
|
||||||
|
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
||||||
|
use Chill\PersonBundle\Repository\PersonRepository;
|
||||||
|
use Chill\PersonBundle\Repository\SocialWork\SocialIssueRepository;
|
||||||
|
use Chill\PersonBundle\Templating\Entity\PersonRenderInterface;
|
||||||
|
use Chill\PersonBundle\Templating\Entity\SocialIssueRender;
|
||||||
|
use Chill\ThirdPartyBundle\Repository\ThirdPartyRepository;
|
||||||
|
use Chill\ThirdPartyBundle\Templating\Entity\ThirdPartyRender;
|
||||||
|
use Doctrine\ORM\Query\Expr\Join;
|
||||||
|
use Doctrine\ORM\QueryBuilder;
|
||||||
|
use Symfony\Contracts\Translation\TranslatorInterface;
|
||||||
|
|
||||||
|
final readonly class ListAccompanyingPeriodHelper
|
||||||
|
{
|
||||||
|
public const FIELDS = [
|
||||||
|
'id',
|
||||||
|
'step',
|
||||||
|
'stepSince',
|
||||||
|
'openingDate',
|
||||||
|
'closingDate',
|
||||||
|
'referrer',
|
||||||
|
'referrerSince',
|
||||||
|
'administrativeLocation',
|
||||||
|
'locationIsPerson',
|
||||||
|
'locationIsTemp',
|
||||||
|
'locationPersonName',
|
||||||
|
'locationPersonId',
|
||||||
|
'origin',
|
||||||
|
'closingMotive',
|
||||||
|
'confidential',
|
||||||
|
'emergency',
|
||||||
|
'intensity',
|
||||||
|
'job',
|
||||||
|
'isRequestorPerson',
|
||||||
|
'isRequestorThirdParty',
|
||||||
|
'requestorPerson',
|
||||||
|
'requestorPersonId',
|
||||||
|
'requestorThirdParty',
|
||||||
|
'requestorThirdPartyId',
|
||||||
|
'scopes',
|
||||||
|
'socialIssues',
|
||||||
|
'createdAt',
|
||||||
|
'createdBy',
|
||||||
|
'updatedAt',
|
||||||
|
'updatedBy',
|
||||||
|
];
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
private ExportAddressHelper $addressHelper,
|
||||||
|
private DateTimeHelper $dateTimeHelper,
|
||||||
|
private PersonRenderInterface $personRender,
|
||||||
|
private PersonRepository $personRepository,
|
||||||
|
private ThirdPartyRepository $thirdPartyRepository,
|
||||||
|
private ThirdPartyRender $thirdPartyRender,
|
||||||
|
private SocialIssueRepository $socialIssueRepository,
|
||||||
|
private SocialIssueRender $socialIssueRender,
|
||||||
|
private TranslatableStringHelperInterface $translatableStringHelper,
|
||||||
|
private TranslatorInterface $translator,
|
||||||
|
) {
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getQueryKeys($data)
|
||||||
|
{
|
||||||
|
return array_merge(
|
||||||
|
ListAccompanyingPeriodHelper::FIELDS,
|
||||||
|
$this->addressHelper->getKeys(ExportAddressHelper::F_ALL, 'address_fields')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getLabels($key, array $values, $data)
|
||||||
|
{
|
||||||
|
if (substr($key, 0, strlen('address_fields')) === 'address_fields') {
|
||||||
|
return $this->addressHelper->getLabel($key, $values, $data, 'address_fields');
|
||||||
|
}
|
||||||
|
|
||||||
|
switch ($key) {
|
||||||
|
case 'stepSince':
|
||||||
|
case 'openingDate':
|
||||||
|
case 'closingDate':
|
||||||
|
case 'referrerSince':
|
||||||
|
case 'createdAt':
|
||||||
|
case 'updatedAt':
|
||||||
|
return $this->dateTimeHelper->getLabel('export.list.acp.' . $key);
|
||||||
|
|
||||||
|
case 'origin':
|
||||||
|
case 'closingMotive':
|
||||||
|
case 'job':
|
||||||
|
return function ($value) use ($key) {
|
||||||
|
if ('_header' === $value) {
|
||||||
|
return 'export.list.acp.' . $key;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null === $value) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->translatableStringHelper->localize(json_decode($value, true, 512, JSON_THROW_ON_ERROR));
|
||||||
|
};
|
||||||
|
|
||||||
|
case 'locationPersonName':
|
||||||
|
case 'requestorPerson':
|
||||||
|
return function ($value) use ($key) {
|
||||||
|
if ('_header' === $value) {
|
||||||
|
return 'export.list.acp.' . $key;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null === $value || null === $person = $this->personRepository->find($value)) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->personRender->renderString($person, []);
|
||||||
|
};
|
||||||
|
|
||||||
|
case 'requestorThirdParty':
|
||||||
|
return function ($value) use ($key) {
|
||||||
|
if ('_header' === $value) {
|
||||||
|
return 'export.list.acp.' . $key;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null === $value || null === $thirdparty = $this->thirdPartyRepository->find($value)) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->thirdPartyRender->renderString($thirdparty, []);
|
||||||
|
};
|
||||||
|
|
||||||
|
case 'scopes':
|
||||||
|
return function ($value) use ($key) {
|
||||||
|
if ('_header' === $value) {
|
||||||
|
return 'export.list.acp.' . $key;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null === $value) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return implode(
|
||||||
|
'|',
|
||||||
|
array_map(
|
||||||
|
fn ($s) => $this->translatableStringHelper->localize($s),
|
||||||
|
json_decode($value, true, 512, JSON_THROW_ON_ERROR)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
case 'socialIssues':
|
||||||
|
return function ($value) use ($key) {
|
||||||
|
if ('_header' === $value) {
|
||||||
|
return 'export.list.acp.' . $key;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null === $value) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return implode(
|
||||||
|
'|',
|
||||||
|
array_map(
|
||||||
|
fn ($s) => $this->socialIssueRender->renderString($this->socialIssueRepository->find($s), []),
|
||||||
|
json_decode($value, true, 512, JSON_THROW_ON_ERROR)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
case 'step':
|
||||||
|
return fn ($value) => match ($value) {
|
||||||
|
'_header' => 'export.list.acp.step',
|
||||||
|
null => '',
|
||||||
|
AccompanyingPeriod::STEP_DRAFT => $this->translator->trans('course.draft'),
|
||||||
|
AccompanyingPeriod::STEP_CONFIRMED => $this->translator->trans('course.confirmed'),
|
||||||
|
AccompanyingPeriod::STEP_CLOSED => $this->translator->trans('course.closed'),
|
||||||
|
AccompanyingPeriod::STEP_CONFIRMED_INACTIVE_SHORT => $this->translator->trans('course.inactive_short'),
|
||||||
|
AccompanyingPeriod::STEP_CONFIRMED_INACTIVE_LONG => $this->translator->trans('course.inactive_long'),
|
||||||
|
default => $value,
|
||||||
|
};
|
||||||
|
|
||||||
|
case 'intensity':
|
||||||
|
return fn ($value) => match ($value) {
|
||||||
|
'_header' => 'export.list.acp.intensity',
|
||||||
|
null => '',
|
||||||
|
AccompanyingPeriod::INTENSITY_OCCASIONAL => $this->translator->trans('occasional'),
|
||||||
|
AccompanyingPeriod::INTENSITY_REGULAR => $this->translator->trans('regular'),
|
||||||
|
default => $value,
|
||||||
|
};
|
||||||
|
|
||||||
|
default:
|
||||||
|
return static function ($value) use ($key) {
|
||||||
|
if ('_header' === $value) {
|
||||||
|
return 'export.list.acp.' . $key;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null === $value) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $value;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function addSelectClauses(QueryBuilder $qb, \DateTimeImmutable $calcDate): void
|
||||||
|
{
|
||||||
|
// add the regular fields
|
||||||
|
foreach (['id', 'openingDate', 'closingDate', 'confidential', 'emergency', 'intensity', 'createdAt', 'updatedAt'] as $field) {
|
||||||
|
$qb->addSelect(sprintf('acp.%s AS %s', $field, $field));
|
||||||
|
}
|
||||||
|
|
||||||
|
// add the field which are simple association
|
||||||
|
foreach (['origin' => 'label', 'closingMotive' => 'name', 'job' => 'label', 'createdBy' => 'label', 'updatedBy' => 'label', 'administrativeLocation' => 'name'] as $entity => $field) {
|
||||||
|
$qb
|
||||||
|
->leftJoin(sprintf('acp.%s', $entity), "{$entity}_t")
|
||||||
|
->addSelect(sprintf('%s_t.%s AS %s', $entity, $field, $entity));
|
||||||
|
}
|
||||||
|
|
||||||
|
// step at date
|
||||||
|
$qb
|
||||||
|
->addSelect('stepHistory.step AS step')
|
||||||
|
->addSelect('stepHistory.startDate AS stepSince')
|
||||||
|
->leftJoin('acp.stepHistories', 'stepHistory')
|
||||||
|
->andWhere(
|
||||||
|
$qb->expr()->andX(
|
||||||
|
$qb->expr()->lte('stepHistory.startDate', ':calcDate'),
|
||||||
|
$qb->expr()->orX($qb->expr()->isNull('stepHistory.endDate'), $qb->expr()->gt('stepHistory.endDate', ':calcDate'))
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// referree at date
|
||||||
|
$qb
|
||||||
|
->addSelect('referrer_t.label AS referrer')
|
||||||
|
->addSelect('userHistory.startDate AS referrerSince')
|
||||||
|
->leftJoin('acp.userHistories', 'userHistory')
|
||||||
|
->leftJoin('userHistory.user', 'referrer_t')
|
||||||
|
->andWhere(
|
||||||
|
$qb->expr()->orX(
|
||||||
|
$qb->expr()->isNull('userHistory'),
|
||||||
|
$qb->expr()->andX(
|
||||||
|
$qb->expr()->lte('userHistory.startDate', ':calcDate'),
|
||||||
|
$qb->expr()->orX($qb->expr()->isNull('userHistory.endDate'), $qb->expr()->gt('userHistory.endDate', ':calcDate'))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// location of the acp
|
||||||
|
$qb
|
||||||
|
->addSelect('CASE WHEN locationHistory.personLocation IS NOT NULL THEN 1 ELSE 0 END AS locationIsPerson')
|
||||||
|
->addSelect('CASE WHEN locationHistory.personLocation IS NOT NULL THEN 0 ELSE 1 END AS locationIsTemp')
|
||||||
|
->addSelect('IDENTITY(locationHistory.personLocation) AS locationPersonName')
|
||||||
|
->addSelect('IDENTITY(locationHistory.personLocation) AS locationPersonId')
|
||||||
|
->leftJoin('acp.locationHistories', 'locationHistory')
|
||||||
|
->andWhere(
|
||||||
|
$qb->expr()->orX(
|
||||||
|
$qb->expr()->isNull('locationHistory'),
|
||||||
|
$qb->expr()->andX(
|
||||||
|
$qb->expr()->lte('locationHistory.startDate', ':calcDate'),
|
||||||
|
$qb->expr()->orX($qb->expr()->isNull('locationHistory.endDate'), $qb->expr()->gt('locationHistory.endDate', ':calcDate'))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
->leftJoin(
|
||||||
|
PersonHouseholdAddress::class,
|
||||||
|
'personAddress',
|
||||||
|
Join::WITH,
|
||||||
|
'locationHistory.personLocation = personAddress.person AND (personAddress.validFrom <= :calcDate AND (personAddress.validTo IS NULL OR personAddress.validTo > :calcDate))'
|
||||||
|
)
|
||||||
|
->leftJoin(Address::class, 'acp_address', Join::WITH, 'COALESCE(IDENTITY(locationHistory.addressLocation), IDENTITY(personAddress.address)) = acp_address.id');
|
||||||
|
|
||||||
|
$this->addressHelper->addSelectClauses(ExportAddressHelper::F_ALL, $qb, 'acp_address', 'address_fields');
|
||||||
|
|
||||||
|
// requestor
|
||||||
|
$qb
|
||||||
|
->addSelect('CASE WHEN acp.requestorPerson IS NULL THEN 1 ELSE 0 END AS isRequestorPerson')
|
||||||
|
->addSelect('CASE WHEN acp.requestorPerson IS NULL THEN 0 ELSE 1 END AS isRequestorThirdParty')
|
||||||
|
->addSelect('IDENTITY(acp.requestorPerson) AS requestorPersonId')
|
||||||
|
->addSelect('IDENTITY(acp.requestorThirdParty) AS requestorThirdPartyId')
|
||||||
|
->addSelect('IDENTITY(acp.requestorPerson) AS requestorPerson')
|
||||||
|
->addSelect('IDENTITY(acp.requestorThirdParty) AS requestorThirdParty');
|
||||||
|
|
||||||
|
$qb
|
||||||
|
// scopes
|
||||||
|
->addSelect('(SELECT AGGREGATE(scope.name) FROM ' . Scope::class . ' scope WHERE scope MEMBER OF acp.scopes) AS scopes')
|
||||||
|
// social issues
|
||||||
|
->addSelect('(SELECT AGGREGATE(socialIssue.id) FROM ' . SocialIssue::class . ' socialIssue WHERE socialIssue MEMBER OF acp.socialIssues) AS socialIssues');
|
||||||
|
|
||||||
|
// add parameter
|
||||||
|
$qb->setParameter('calcDate', $calcDate);
|
||||||
|
}
|
||||||
|
}
|
@ -1175,7 +1175,7 @@ export:
|
|||||||
referrerSince: Référent depuis le
|
referrerSince: Référent depuis le
|
||||||
locationIsPerson: Parcours localisé auprès d'un usager concerné
|
locationIsPerson: Parcours localisé auprès d'un usager concerné
|
||||||
locationIsTemp: Parcours avec une localisation temporaire
|
locationIsTemp: Parcours avec une localisation temporaire
|
||||||
acpLocationPersonName: Usager auprès duquel le parcours est localisé
|
locationPersonName: Usager auprès duquel le parcours est localisé
|
||||||
locationPersonId: Identifiant de l'usager auprès duquel le parcours est localisé
|
locationPersonId: Identifiant de l'usager auprès duquel le parcours est localisé
|
||||||
acpaddress_fieldscountry: Pays de l'adresse
|
acpaddress_fieldscountry: Pays de l'adresse
|
||||||
isRequestorPerson: Le demandeur est-il un usager ?
|
isRequestorPerson: Le demandeur est-il un usager ?
|
||||||
|
Loading…
x
Reference in New Issue
Block a user