mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-20 20:22:49 +00:00 
			
		
		
		
	Compare commits
	
		
			19 Commits
		
	
	
		
			2.8.0
			...
			146_parcou
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 444f37ad18 | |||
| ada28265ee | |||
| 9bbddd8405 | |||
| 935210aa1d | |||
| 9f476dddaf | |||
| dac48ea4e0 | |||
| af4bee4d50 | |||
| b0a7612329 | |||
| 0c5b35926b | |||
| b38f5800d9 | |||
| 29983cc2ad | |||
| 260a173a61 | |||
| 500b37601a | |||
| 5d41b37620 | |||
| 05e86a3360 | |||
| 9b061eeaae | |||
| 3816d68e18 | |||
| 7db7f34f62 | |||
| 6b958d193d | 
							
								
								
									
										6
									
								
								.changes/unreleased/Feature-20231004-120857.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.changes/unreleased/Feature-20231004-120857.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| kind: Feature | ||||
| body: Allow closing motives to be identified as 'canceling the accompanying period' | ||||
|   + don't take canceled accompanying periods into account in exports | ||||
| time: 2023-10-04T12:08:57.586865276+02:00 | ||||
| custom: | ||||
|   Issue: "146" | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v2.6.3 - 2023-09-19 | ||||
| ### Fixed | ||||
| * Remove id property from document  | ||||
| mappedsuperclass  | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v2.7.0 - 2023-09-27 | ||||
| ### Feature | ||||
| * ([#155](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/155)) The regulation list load accompanying periods by exact postal code (address associated with postal code), and not by the content of the postal code (postal code with same code's string)  | ||||
| ### Fixed | ||||
| * ([#142](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/142)) Fix the label of filter ActivityTypeFilter to a more obvious one  | ||||
| * ([#140](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/140)) [export] Fix association of filter "filter location by type" which did not appears on "list of activities"  | ||||
| @@ -1,19 +0,0 @@ | ||||
| ## v2.8.0 - 2023-10-05 | ||||
|  | ||||
| ### Feature | ||||
|  | ||||
| * ([#162](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/162)) Reassigning list: when reassigning courses to a new user, the job associated with the course become the one of the new user (if any) | ||||
| * Reassining list: the length of the list is increased to 100 courses | ||||
|  | ||||
| ### Fixed | ||||
|  | ||||
| * ([#143](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/143)) Fix filter "accompanying course by social action" to avoid duplication in list | ||||
| * ([#164](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/164)) View a third party: avoid errors when a contact has a civility | ||||
| * ([#163](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/163)) Fix the filters and aggregators on exports "count peoples" | ||||
| * ([#143](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/143)) From the database, avoid the creation of location history for same period and at same dates | ||||
|  | ||||
| ### Traduction francophone des principaux changements | ||||
|  | ||||
| - Fonctionnalité: Réassigner les parcours en lot: lorsque des parcours sont réassignés "en lot", les parcours sont maintenant associés au métier du nouveau référent; | ||||
| - Correction: certaines causes qui créaient des doublons dans les listes ont été corrigées; | ||||
| - Correction des associations entre l'export "nombre de personnes" et les filtres et regroupements associés | ||||
							
								
								
									
										32
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -6,38 +6,6 @@ adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html), | ||||
| and is generated by [Changie](https://github.com/miniscruff/changie). | ||||
|  | ||||
|  | ||||
| ## v2.8.0 - 2023-10-05 | ||||
|  | ||||
| ### Feature | ||||
|  | ||||
| * ([#162](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/162)) Reassigning list: when reassigning courses to a new user, the job associated with the course become the one of the new user (if any) | ||||
| * Reassining list: the length of the list is increased to 100 courses | ||||
|  | ||||
| ### Fixed | ||||
|  | ||||
| * ([#143](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/143)) Fix filter "accompanying course by social action" to avoid duplication in list | ||||
| * ([#164](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/164)) View a third party: avoid errors when a contact has a civility | ||||
| * ([#163](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/163)) Fix the filters and aggregators on exports "count peoples" | ||||
| * ([#143](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/143)) From the database, avoid the creation of location history for same period and at same dates | ||||
|  | ||||
| ### Traduction francophone des principaux changements | ||||
|  | ||||
| - Fonctionnalité: Réassigner les parcours en lot: lorsque des parcours sont réassignés "en lot", les parcours sont maintenant associés au métier du nouveau référent; | ||||
| - Correction: certaines causes qui créaient des doublons dans les listes ont été corrigées; | ||||
| - Correction des associations entre l'export "nombre de personnes" et les filtres et regroupements associés | ||||
|  | ||||
| ## v2.7.0 - 2023-09-27 | ||||
| ### Feature | ||||
| * ([#155](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/155)) The regulation list load accompanying periods by exact postal code (address associated with postal code), and not by the content of the postal code (postal code with same code's string)  | ||||
| ### Fixed | ||||
| * ([#142](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/142)) Fix the label of filter ActivityTypeFilter to a more obvious one  | ||||
| * ([#140](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/140)) [export] Fix association of filter "filter location by type" which did not appears on "list of activities"  | ||||
|  | ||||
| ## v2.6.3 - 2023-09-19 | ||||
| ### Fixed | ||||
| * Remove id property from document  | ||||
| mappedsuperclass  | ||||
|  | ||||
| ## v2.6.2 - 2023-09-18 | ||||
| ### Fixed | ||||
| * Fix doctrine mapping of AbstractTaskPlaceEvent and SingleTaskPlaceEvent: id property moved.  | ||||
|   | ||||
| @@ -40,7 +40,7 @@ About once a year, the core team discusses the opportunity to invite new members | ||||
|  | ||||
| ### Core Membership Revocation | ||||
|  | ||||
| A Chill Core membership can be revoked for any of the following reasons: | ||||
| A Symfony Core membership can be revoked for any of the following reasons: | ||||
|  | ||||
| - Refusal to follow the rules and policies stated in this document; | ||||
| - Lack of activity for the past six months; | ||||
|   | ||||
| @@ -123,8 +123,7 @@ | ||||
|             "ocramius/package-versions": true, | ||||
|             "phpro/grumphp": true, | ||||
|             "phpstan/extension-installer": true, | ||||
|             "roave/you-are-using-it-wrong": true, | ||||
|             "symfony/runtime": true | ||||
|             "roave/you-are-using-it-wrong": true | ||||
|         }, | ||||
|         "bin-dir": "bin", | ||||
|         "optimize-autoloader": true, | ||||
|   | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\AggregatorInterface; | ||||
| @@ -45,7 +45,7 @@ class ByCreatorAggregator implements AggregatorInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\AggregatorInterface; | ||||
| @@ -50,7 +50,7 @@ class ByThirdpartyAggregator implements AggregatorInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\AggregatorInterface; | ||||
| @@ -50,7 +50,7 @@ class CreatorScopeAggregator implements AggregatorInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\AggregatorInterface; | ||||
| @@ -66,7 +66,7 @@ class DateAggregator implements AggregatorInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\AggregatorInterface; | ||||
| @@ -50,7 +50,7 @@ class LocationTypeAggregator implements AggregatorInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -14,6 +14,7 @@ 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\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -31,7 +32,7 @@ class AvgActivityDuration implements ExportInterface, GroupedExportInterface | ||||
|     protected EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(Activity::class); | ||||
|     } | ||||
| @@ -108,6 +109,8 @@ class AvgActivityDuration implements ExportInterface, GroupedExportInterface | ||||
|             ) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -14,6 +14,7 @@ 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\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -31,7 +32,7 @@ class AvgActivityVisitDuration implements ExportInterface, GroupedExportInterfac | ||||
|     protected EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(Activity::class); | ||||
|     } | ||||
| @@ -111,6 +112,8 @@ class AvgActivityVisitDuration implements ExportInterface, GroupedExportInterfac | ||||
|             ) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -14,6 +14,7 @@ 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\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -31,7 +32,7 @@ class CountActivity implements ExportInterface, GroupedExportInterface | ||||
|     protected EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(Activity::class); | ||||
|     } | ||||
| @@ -105,6 +106,8 @@ class CountActivity implements ExportInterface, GroupedExportInterface | ||||
|             ) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb->select('COUNT(DISTINCT activity.id) as export_count_activity'); | ||||
|  | ||||
|         return $qb; | ||||
|   | ||||
| @@ -12,10 +12,10 @@ declare(strict_types=1); | ||||
| namespace Chill\ActivityBundle\Export\Export\LinkedToACP; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\ActivityBundle\Export\Export\ListActivityHelper; | ||||
| use Chill\ActivityBundle\Security\Authorization\ActivityStatsVoter; | ||||
| use Chill\MainBundle\Entity\Scope; | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| use Chill\MainBundle\Export\Helper\TranslatableStringExportLabelHelper; | ||||
| use Chill\MainBundle\Export\ListInterface; | ||||
| @@ -34,7 +34,7 @@ class ListActivity implements ListInterface, GroupedExportInterface | ||||
|     public function __construct( | ||||
|         ListActivityHelper $helper, | ||||
|         EntityManagerInterface $entityManager, | ||||
|         TranslatableStringExportLabelHelper $translatableStringExportLabelHelper | ||||
|         TranslatableStringExportLabelHelper $translatableStringExportLabelHelper, | ||||
|     ) { | ||||
|         $this->helper = $helper; | ||||
|         $this->entityManager = $entityManager; | ||||
| @@ -148,6 +148,8 @@ class ListActivity implements ListInterface, GroupedExportInterface | ||||
|             ->addSelect('(SELECT AGGREGATE(acpScope.name) FROM ' . Scope::class . ' acpScope WHERE acpScope MEMBER OF acp.scopes) AS scopesNames') | ||||
|             ->addGroupBy('scopesNames'); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
| @@ -161,7 +163,6 @@ class ListActivity implements ListInterface, GroupedExportInterface | ||||
|         return array_merge( | ||||
|             $this->helper->supportsModifiers(), | ||||
|             [ | ||||
|                 Declarations::ACTIVITY, | ||||
|                 \Chill\PersonBundle\Export\Declarations::ACP_TYPE, | ||||
|             ] | ||||
|         ); | ||||
|   | ||||
| @@ -14,6 +14,7 @@ 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\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -31,7 +32,7 @@ class SumActivityDuration implements ExportInterface, GroupedExportInterface | ||||
|     protected EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(Activity::class); | ||||
|     } | ||||
| @@ -111,6 +112,8 @@ class SumActivityDuration implements ExportInterface, GroupedExportInterface | ||||
|             ) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -14,6 +14,7 @@ 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\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -31,7 +32,7 @@ class SumActivityVisitDuration implements ExportInterface, GroupedExportInterfac | ||||
|     protected EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(Activity::class); | ||||
|     } | ||||
| @@ -111,6 +112,8 @@ class SumActivityVisitDuration implements ExportInterface, GroupedExportInterfac | ||||
|             ) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -299,7 +299,7 @@ class ListActivity implements ListInterface, GroupedExportInterface | ||||
|         return [ | ||||
|             Declarations::ACTIVITY, | ||||
|             Declarations::ACTIVITY_PERSON, | ||||
|             PersonDeclarations::PERSON_TYPE, | ||||
|             //PersonDeclarations::PERSON_TYPE, | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -155,7 +155,7 @@ class StatActivityDuration implements ExportInterface, GroupedExportInterface | ||||
|         return [ | ||||
|             Declarations::ACTIVITY, | ||||
|             Declarations::ACTIVITY_PERSON, | ||||
|             PersonDeclarations::PERSON_TYPE, | ||||
|             //PersonDeclarations::PERSON_TYPE, | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -21,15 +21,19 @@ use Doctrine\ORM\QueryBuilder; | ||||
| use Symfony\Bridge\Doctrine\Form\Type\EntityType; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
|  | ||||
| /** | ||||
|  * Filter accompanying period to keep only the one having at list one activity from the given ActivityType. | ||||
|  */ | ||||
| class ActivityTypeFilter implements FilterInterface | ||||
| { | ||||
|     private ActivityTypeRepositoryInterface $activityTypeRepository; | ||||
|  | ||||
|     private TranslatableStringHelperInterface $translatableStringHelper; | ||||
|  | ||||
|     public function __construct( | ||||
|         private readonly ActivityTypeRepositoryInterface $activityTypeRepository, | ||||
|         private readonly TranslatableStringHelperInterface $translatableStringHelper | ||||
|     ) {} | ||||
|         ActivityTypeRepositoryInterface $activityTypeRepository, | ||||
|         TranslatableStringHelperInterface $translatableStringHelper | ||||
|     ) { | ||||
|         $this->activityTypeRepository = $activityTypeRepository; | ||||
|         $this->translatableStringHelper = $translatableStringHelper; | ||||
|     } | ||||
|  | ||||
|     public function addRole(): ?string | ||||
|     { | ||||
| @@ -77,7 +81,7 @@ class ActivityTypeFilter implements FilterInterface | ||||
|             $types[] = $this->translatableStringHelper->localize($aty->getName()); | ||||
|         } | ||||
|  | ||||
|         return ['export.filter.activity.acp_by_activity_type.acp_containing_at_least_one_%activitytypes%', [ | ||||
|         return ['Filtered by activity types: only %activitytypes%', [ | ||||
|             '%activitytypes%' => implode(', ', $types), | ||||
|         ]]; | ||||
|     } | ||||
|   | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\FilterInterface; | ||||
| @@ -43,7 +43,7 @@ class ByCreatorFilter implements FilterInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\FilterInterface; | ||||
| @@ -58,7 +58,7 @@ class EmergencyFilter implements FilterInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -17,9 +17,6 @@ use Chill\PersonBundle\Export\Declarations; | ||||
| use Doctrine\ORM\QueryBuilder; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
|  | ||||
| /** | ||||
|  * Filter accompanying periods to keep only the one without any activity | ||||
|  */ | ||||
| class HasNoActivityFilter implements FilterInterface | ||||
| { | ||||
|     public function addRole(): ?string | ||||
|   | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\FilterInterface; | ||||
| @@ -36,7 +36,7 @@ class LocationFilter implements FilterInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\FilterInterface; | ||||
| @@ -55,7 +55,7 @@ class LocationTypeFilter implements FilterInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| @@ -59,7 +59,7 @@ class SentReceivedFilter implements FilterInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Export\FilterInterface; | ||||
| @@ -51,7 +51,7 @@ class UserFilter implements FilterInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -9,7 +9,7 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Export\Declarations; | ||||
| use Chill\MainBundle\Entity\Scope; | ||||
| @@ -57,7 +57,7 @@ class UserScopeFilter implements FilterInterface | ||||
| 
 | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::ACTIVITY; | ||||
|         return Declarations::ACTIVITY_ACP; | ||||
|     } | ||||
| 
 | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
| @@ -17,9 +17,6 @@ use Chill\ActivityBundle\Repository\ActivityReasonRepository; | ||||
| use Chill\MainBundle\Export\ExportElementValidatedInterface; | ||||
| use Chill\MainBundle\Export\FilterInterface; | ||||
| use Chill\MainBundle\Form\Type\Export\FilterType; | ||||
| use Chill\MainBundle\Form\Type\PickRollingDateType; | ||||
| use Chill\MainBundle\Service\RollingDate\RollingDate; | ||||
| use Chill\MainBundle\Service\RollingDate\RollingDateConverterInterface; | ||||
| use Chill\MainBundle\Templating\TranslatableStringHelper; | ||||
| use Chill\MainBundle\Templating\TranslatableStringHelperInterface; | ||||
| use Chill\PersonBundle\Export\Declarations; | ||||
| @@ -47,10 +44,9 @@ class PersonHavingActivityBetweenDateFilter implements ExportElementValidatedInt | ||||
|     protected TranslatorInterface $translator; | ||||
|  | ||||
|     public function __construct( | ||||
|         TranslatableStringHelper                       $translatableStringHelper, | ||||
|         ActivityReasonRepository                       $activityReasonRepository, | ||||
|         TranslatorInterface                            $translator, | ||||
|         private readonly RollingDateConverterInterface $rollingDateConverter, | ||||
|         TranslatableStringHelper $translatableStringHelper, | ||||
|         ActivityReasonRepository $activityReasonRepository, | ||||
|         TranslatorInterface $translator | ||||
|     ) { | ||||
|         $this->translatableStringHelper = $translatableStringHelper; | ||||
|         $this->activityReasonRepository = $activityReasonRepository; | ||||
| @@ -66,93 +62,131 @@ class PersonHavingActivityBetweenDateFilter implements ExportElementValidatedInt | ||||
|     { | ||||
|         // create a subquery for activity | ||||
|         $sqb = $qb->getEntityManager()->createQueryBuilder(); | ||||
|         $sqb->select('1') | ||||
|         $sqb->select('person_person_having_activity.id') | ||||
|             ->from(Activity::class, 'activity_person_having_activity') | ||||
|             ->leftJoin('activity_person_having_activity.person', 'person_person_having_activity'); | ||||
|             ->join('activity_person_having_activity.person', 'person_person_having_activity'); | ||||
|  | ||||
|         // add clause between date | ||||
|         $sqb->where('activity_person_having_activity.date BETWEEN ' | ||||
|             . ':person_having_activity_between_date_from' | ||||
|             . ' AND ' | ||||
|             . ':person_having_activity_between_date_to' | ||||
|             . ' AND ' | ||||
|             . '(person_person_having_activity.id = person.id OR person MEMBER OF activity_person_having_activity.persons)'); | ||||
|             . ':person_having_activity_between_date_to'); | ||||
|  | ||||
|         if (isset($data['reasons']) && [] !== $data['reasons']) { | ||||
|             // add clause activity reason | ||||
|             $sqb->join('activity_person_having_activity.reasons', 'reasons_person_having_activity'); | ||||
|         // add clause activity reason | ||||
|         $sqb->join('activity_person_having_activity.reasons', 'reasons_person_having_activity'); | ||||
|  | ||||
|             $sqb->andWhere( | ||||
|                 $sqb->expr()->in( | ||||
|                     'reasons_person_having_activity', | ||||
|                     ':person_having_activity_reasons' | ||||
|                 ) | ||||
|             ); | ||||
|  | ||||
|             $qb->setParameter('person_having_activity_reasons', $data['reasons']); | ||||
|         } | ||||
|  | ||||
|         $qb->andWhere( | ||||
|             $qb->expr()->exists($sqb->getDQL()) | ||||
|         $sqb->andWhere( | ||||
|             $sqb->expr()->in( | ||||
|                 'reasons_person_having_activity', | ||||
|                 ':person_having_activity_reasons' | ||||
|             ) | ||||
|         ); | ||||
|  | ||||
|         $where = $qb->getDQLPart('where'); | ||||
|         $clause = $qb->expr()->in('person.id', $sqb->getDQL()); | ||||
|  | ||||
|         if ($where instanceof Expr\Andx) { | ||||
|             $where->add($clause); | ||||
|         } else { | ||||
|             $where = $qb->expr()->andX($clause); | ||||
|         } | ||||
|  | ||||
|         $qb->add('where', $where); | ||||
|         $qb->setParameter( | ||||
|             'person_having_activity_between_date_from', | ||||
|             $this->rollingDateConverter->convert($data['date_from_rolling']) | ||||
|             $data['date_from'] | ||||
|         ); | ||||
|         $qb->setParameter( | ||||
|             'person_having_activity_between_date_to', | ||||
|             $this->rollingDateConverter->convert($data['date_to_rolling']) | ||||
|             $data['date_to'] | ||||
|         ); | ||||
|         $qb->setParameter('person_having_activity_reasons', $data['reasons']); | ||||
|     } | ||||
|  | ||||
|     public function applyOn(): string | ||||
|     { | ||||
|         return Declarations::PERSON_TYPE; | ||||
|         return Declarations::PERSON_IMPLIED_IN; | ||||
|     } | ||||
|  | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
|     { | ||||
|         $builder->add('date_from_rolling', PickRollingDateType::class, [ | ||||
|             'label' => 'export.filter.activity.person_between_dates.Implied in an activity after this date', | ||||
|         $builder->add('date_from', DateType::class, [ | ||||
|             'label' => 'Implied in an activity after this date', | ||||
|             'attr' => ['class' => 'datepicker'], | ||||
|             'widget' => 'single_text', | ||||
|             'format' => 'dd-MM-yyyy', | ||||
|         ]); | ||||
|  | ||||
|         $builder->add('date_to_rolling', PickRollingDateType::class, [ | ||||
|             'label' => 'export.filter.activity.person_between_dates.Implied in an activity before this date', | ||||
|         $builder->add('date_to', DateType::class, [ | ||||
|             'label' => 'Implied in an activity before this date', | ||||
|             'attr' => ['class' => 'datepicker'], | ||||
|             'widget' => 'single_text', | ||||
|             'format' => 'dd-MM-yyyy', | ||||
|         ]); | ||||
|  | ||||
|         if ([] !== $reasons = $this->activityReasonRepository->findAll()) { | ||||
|             $builder->add('reasons', EntityType::class, [ | ||||
|                 'class' => ActivityReason::class, | ||||
|                 'choices' => $reasons, | ||||
|                 'choice_label' => fn (ActivityReason $reason): ?string => $this->translatableStringHelper->localize($reason->getName()), | ||||
|                 'group_by' => fn (ActivityReason $reason): ?string => $this->translatableStringHelper->localize($reason->getCategory()->getName()), | ||||
|                 'multiple' => true, | ||||
|                 'expanded' => false, | ||||
|                 'label' => 'export.filter.activity.person_between_dates.Activity reasons for those activities', | ||||
|                 'help' => 'export.filter.activity.person_between_dates.if no reasons', | ||||
|             ]); | ||||
|         } | ||||
|         $builder->add('reasons', EntityType::class, [ | ||||
|             'class' => ActivityReason::class, | ||||
|             'choice_label' => fn (ActivityReason $reason): ?string => $this->translatableStringHelper->localize($reason->getName()), | ||||
|             'group_by' => fn (ActivityReason $reason): ?string => $this->translatableStringHelper->localize($reason->getCategory()->getName()), | ||||
|             'multiple' => true, | ||||
|             'expanded' => false, | ||||
|             'label' => 'Activity reasons for those activities', | ||||
|         ]); | ||||
|  | ||||
|         $builder->addEventListener(FormEvents::POST_SUBMIT, function (FormEvent $event) { | ||||
|             /** @var FormInterface $filterForm */ | ||||
|             $filterForm = $event->getForm()->getParent(); | ||||
|             $enabled = $filterForm->get(FilterType::ENABLED_FIELD)->getData(); | ||||
|  | ||||
|             if (true === $enabled) { | ||||
|                 // if the filter is enabled, add some validation | ||||
|                 $form = $event->getForm(); | ||||
|                 $date_from = $form->get('date_from')->getData(); | ||||
|                 $date_to = $form->get('date_to')->getData(); | ||||
|  | ||||
|                 // check that fields are not empty | ||||
|                 if (null === $date_from) { | ||||
|                     $form->get('date_from')->addError(new FormError( | ||||
|                         $this->translator->trans('This field ' | ||||
|                         . 'should not be empty') | ||||
|                     )); | ||||
|                 } | ||||
|  | ||||
|                 if (null === $date_to) { | ||||
|                     $form->get('date_to')->addError(new FormError( | ||||
|                         $this->translator->trans('This field ' | ||||
|                         . 'should not be empty') | ||||
|                     )); | ||||
|                 } | ||||
|  | ||||
|                 // check that date_from is before date_to | ||||
|                 if ( | ||||
|                     (null !== $date_from && null !== $date_to) | ||||
|                     && $date_from >= $date_to | ||||
|                 ) { | ||||
|                     $form->get('date_to')->addError(new FormError( | ||||
|                         $this->translator->trans('This date ' | ||||
|                         . 'should be after the date given in "Implied in an ' | ||||
|                         . 'activity after this date" field') | ||||
|                     )); | ||||
|                 } | ||||
|             } | ||||
|         }); | ||||
|     } | ||||
|     public function getFormDefaultData(): array | ||||
|     { | ||||
|         return [ | ||||
|             'date_from_rolling' => new RollingDate(RollingDate::T_YEAR_PREVIOUS_START), | ||||
|             'date_to_rolling' => new RollingDate(RollingDate::T_TODAY), | ||||
|             'reasons' => [], | ||||
|         ]; | ||||
|         return ['date_from' => new DateTime(), 'date_to' => new DateTime(), 'reasons' => $this->activityReasonRepository->findAll()]; | ||||
|     } | ||||
|  | ||||
|     public function describeAction($data, $format = 'string') | ||||
|     { | ||||
|         return [ | ||||
|             [] === $data['reasons'] ? | ||||
|                 'export.filter.person_between_dates.describe_action_with_no_subject' | ||||
|                 : 'export.filter.person_between_dates.describe_action_with_subject', | ||||
|             'Filtered by person having an activity between %date_from% and ' | ||||
|             . '%date_to% with reasons %reasons_name%', | ||||
|             [ | ||||
|                 'date_from' => $this->rollingDateConverter->convert($data['date_from_rolling']), | ||||
|                 'date_to' => $this->rollingDateConverter->convert($data['date_to_rolling']), | ||||
|                 'reasons' => implode( | ||||
|                 '%date_from%' => $data['date_from']->format('d-m-Y'), | ||||
|                 '%date_to%' => $data['date_to']->format('d-m-Y'), | ||||
|                 '%reasons_name%' => implode( | ||||
|                     ', ', | ||||
|                     array_map( | ||||
|                         fn (ActivityReason $r): string => '"' . $this->translatableStringHelper->localize($r->getName()) . '"', | ||||
| @@ -165,15 +199,13 @@ class PersonHavingActivityBetweenDateFilter implements ExportElementValidatedInt | ||||
|  | ||||
|     public function getTitle() | ||||
|     { | ||||
|         return 'export.filter.activity.person_between_dates.title'; | ||||
|         return 'Filter by person having an activity in a period'; | ||||
|     } | ||||
|  | ||||
|     public function validateForm($data, ExecutionContextInterface $context) | ||||
|     { | ||||
|         if ($this->rollingDateConverter->convert($data['date_from_rolling']) | ||||
|             >= $this->rollingDateConverter->convert($data['date_to_rolling'])) { | ||||
|             $context->buildViolation('export.filter.activity.person_between_dates.date mismatch') | ||||
|                 ->setTranslationDomain('messages') | ||||
|         if (null === $data['reasons'] || count($data['reasons']) === 0) { | ||||
|             $context->buildViolation('At least one reason must be chosen') | ||||
|                 ->addViolation(); | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -12,7 +12,7 @@ declare(strict_types=1); | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator\ACPAggregators; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Aggregator\BySocialActionAggregator; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ACPAggregators\BySocialActionAggregator; | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
|  | ||||
|   | ||||
| @@ -12,7 +12,7 @@ declare(strict_types=1); | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator\ACPAggregators; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Aggregator\BySocialIssueAggregator; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ACPAggregators\BySocialIssueAggregator; | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
|  | ||||
|   | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ByThirdpartyAggregator; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ACPAggregators\ByThirdpartyAggregator; | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| 
 | ||||
| @@ -28,7 +28,7 @@ final class ByThirdpartyAggregatorTest extends AbstractAggregatorTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->aggregator = self::$container->get(ByThirdpartyAggregator::class); | ||||
|         $this->aggregator = self::$container->get('chill.activity.export.bythirdparty_aggregator'); | ||||
|     } | ||||
| 
 | ||||
|     public function getAggregator() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ByCreatorAggregator; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ACPAggregators\ByCreatorAggregator; | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| 
 | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Aggregator\DateAggregator; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ACPAggregators\DateAggregator; | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| 
 | ||||
| @@ -28,7 +28,7 @@ final class DateAggregatorTest extends AbstractAggregatorTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->aggregator = self::$container->get(DateAggregator::class); | ||||
|         $this->aggregator = self::$container->get('chill.activity.export.date_aggregator'); | ||||
|     } | ||||
| 
 | ||||
|     public function getAggregator() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Aggregator\LocationTypeAggregator; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ACPAggregators\LocationTypeAggregator; | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| 
 | ||||
| @@ -28,7 +28,7 @@ final class LocationTypeAggregatorTest extends AbstractAggregatorTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->aggregator = self::$container->get(LocationTypeAggregator::class); | ||||
|         $this->aggregator = self::$container->get('chill.activity.export.locationtype_aggregator'); | ||||
|     } | ||||
| 
 | ||||
|     public function getAggregator() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator\ACPAggregators; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Aggregator\CreatorScopeAggregator; | ||||
| use Chill\ActivityBundle\Export\Aggregator\ACPAggregators\CreatorScopeAggregator; | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| 
 | ||||
| @@ -20,7 +20,7 @@ use Doctrine\ORM\EntityManagerInterface; | ||||
|  * @internal | ||||
|  * @coversNothing | ||||
|  */ | ||||
| final class CreatorScopeAggregatorTest extends AbstractAggregatorTest | ||||
| final class UserScopeAggregatorTest extends AbstractAggregatorTest | ||||
| { | ||||
|     private CreatorScopeAggregator $aggregator; | ||||
| 
 | ||||
| @@ -13,10 +13,9 @@ namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Entity\ActivityType; | ||||
| use Chill\ActivityBundle\Export\Filter\ActivityTypeFilter; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\ActivityTypeFilter; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Chill\PersonBundle\Entity\AccompanyingPeriod; | ||||
| use Doctrine\Common\Collections\ArrayCollection; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| use Doctrine\ORM\Query\Expr; | ||||
|  | ||||
| @@ -26,13 +25,13 @@ use Doctrine\ORM\Query\Expr; | ||||
|  */ | ||||
| final class ActivityTypeFilterTest extends AbstractFilterTest | ||||
| { | ||||
|     private \Chill\ActivityBundle\Export\Filter\ACPFilters\ActivityTypeFilter $filter; | ||||
|     private ActivityTypeFilter $filter; | ||||
|  | ||||
|     protected function setUp(): void | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|  | ||||
|         $this->filter = self::$container->get(\Chill\ActivityBundle\Export\Filter\ACPFilters\ActivityTypeFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.filter_activitytype'); | ||||
|     } | ||||
|  | ||||
|     public function getFilter() | ||||
| @@ -48,14 +47,13 @@ final class ActivityTypeFilterTest extends AbstractFilterTest | ||||
|             ->from(ActivityType::class, 'at') | ||||
|             ->select('at') | ||||
|             ->getQuery() | ||||
|             ->setMaxResults(1) | ||||
|             ->getResult(); | ||||
|  | ||||
|         $data = []; | ||||
|  | ||||
|         foreach ($array as $a) { | ||||
|             $data[] = [ | ||||
|                 'accepted_activitytypes' => new ArrayCollection([$a]), | ||||
|                 'accepted_activitytypes' => $a, | ||||
|             ]; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -12,9 +12,9 @@ declare(strict_types=1); | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialActionFilter; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Chill\PersonBundle\Entity\SocialWork\SocialAction; | ||||
| use Doctrine\Common\Collections\ArrayCollection; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
|  | ||||
| /** | ||||
| @@ -23,13 +23,13 @@ use Doctrine\ORM\EntityManagerInterface; | ||||
|  */ | ||||
| final class BySocialActionFilterTest extends AbstractFilterTest | ||||
| { | ||||
|     private \Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialActionFilter $filter; | ||||
|     private BySocialActionFilter $filter; | ||||
|  | ||||
|     protected function setUp(): void | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|  | ||||
|         $this->filter = self::$container->get(\Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialActionFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.bysocialaction_filter'); | ||||
|     } | ||||
|  | ||||
|     public function getFilter() | ||||
| @@ -39,22 +39,19 @@ final class BySocialActionFilterTest extends AbstractFilterTest | ||||
|  | ||||
|     public function getFormData(): array | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|  | ||||
|         $em = self::$container->get(EntityManagerInterface::class); | ||||
|  | ||||
|         $array = $em->createQueryBuilder() | ||||
|             ->from(SocialAction::class, 'sa') | ||||
|             ->select('sa') | ||||
|             ->getQuery() | ||||
|             ->setMaxResults(1) | ||||
|             ->getResult(); | ||||
|  | ||||
|         $data = []; | ||||
|  | ||||
|         foreach ($array as $a) { | ||||
|             $data[] = [ | ||||
|                 'accepted_socialactions' => new ArrayCollection([$a]), | ||||
|                 'accepted_socialactions' => $a, | ||||
|             ]; | ||||
|         } | ||||
|  | ||||
| @@ -63,7 +60,9 @@ final class BySocialActionFilterTest extends AbstractFilterTest | ||||
|  | ||||
|     public function getQueryBuilders(): array | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|         if (null === self::$kernel) { | ||||
|             self::bootKernel(); | ||||
|         } | ||||
|  | ||||
|         $em = self::$container->get(EntityManagerInterface::class); | ||||
|  | ||||
|   | ||||
| @@ -15,7 +15,6 @@ use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialIssueFilter; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Chill\PersonBundle\Entity\SocialWork\SocialIssue; | ||||
| use Doctrine\Common\Collections\ArrayCollection; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
|  | ||||
| /** | ||||
| @@ -30,7 +29,7 @@ final class BySocialIssueFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|  | ||||
|         $this->filter = self::$container->get(BySocialIssueFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.bysocialissue_filter'); | ||||
|     } | ||||
|  | ||||
|     public function getFilter() | ||||
| @@ -40,21 +39,19 @@ final class BySocialIssueFilterTest extends AbstractFilterTest | ||||
|  | ||||
|     public function getFormData(): array | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|         $em = self::$container->get(EntityManagerInterface::class); | ||||
|  | ||||
|         $array = $em->createQueryBuilder() | ||||
|             ->from(SocialIssue::class, 'si') | ||||
|             ->select('si') | ||||
|             ->getQuery() | ||||
|             ->setMaxResults(2) | ||||
|             ->getResult(); | ||||
|  | ||||
|         $data = []; | ||||
|  | ||||
|         foreach ($array as $a) { | ||||
|             $data[] = [ | ||||
|                 'accepted_socialissues' => new ArrayCollection([$a]), | ||||
|                 'accepted_socialissues' => $a, | ||||
|             ]; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\ByCreatorFilter; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\ByCreatorFilter; | ||||
| use Chill\MainBundle\Entity\User; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| @@ -29,7 +29,7 @@ final class ByUserFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->filter = self::$container->get(ByCreatorFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.byuser_filter'); | ||||
|     } | ||||
| 
 | ||||
|     public function getFilter() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\EmergencyFilter; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\EmergencyFilter; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| 
 | ||||
| @@ -28,7 +28,7 @@ final class EmergencyFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->filter = self::$container->get(EmergencyFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.emergency_filter'); | ||||
|     } | ||||
| 
 | ||||
|     public function getFilter() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\LocationTypeFilter; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\LocationTypeFilter; | ||||
| use Chill\MainBundle\Entity\LocationType; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| @@ -29,7 +29,7 @@ final class LocationTypeFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->filter = self::$container->get(LocationTypeFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.locationtype_filter'); | ||||
|     } | ||||
| 
 | ||||
|     public function getFilter() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\SentReceivedFilter; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\SentReceivedFilter; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| 
 | ||||
| @@ -28,7 +28,7 @@ final class SentReceivedFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->filter = self::$container->get(SentReceivedFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.sentreceived_filter'); | ||||
|     } | ||||
| 
 | ||||
|     public function getFilter() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\UserFilter; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\UserFilter; | ||||
| use Chill\MainBundle\Entity\User; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| @@ -29,7 +29,7 @@ final class UserFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->filter = self::$container->get(UserFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.user_filter'); | ||||
|     } | ||||
| 
 | ||||
|     public function getFilter() | ||||
| @@ -9,10 +9,10 @@ declare(strict_types=1); | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
| 
 | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter\ACPFilters; | ||||
| 
 | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Export\Filter\UserScopeFilter; | ||||
| use Chill\ActivityBundle\Export\Filter\ACPFilters\UserScopeFilter; | ||||
| use Chill\MainBundle\Entity\Scope; | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| @@ -29,7 +29,7 @@ final class UserScopeFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
| 
 | ||||
|         $this->filter = self::$container->get(UserScopeFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.userscope_filter'); | ||||
|     } | ||||
| 
 | ||||
|     public function getFilter() | ||||
| @@ -29,7 +29,7 @@ final class ActivityDateFilterTest extends AbstractFilterTest | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|  | ||||
|         $this->filter = self::$container->get(ActivityDateFilter::class); | ||||
|         $this->filter = self::$container->get('chill.activity.export.date_filter'); | ||||
|     } | ||||
|  | ||||
|     public function getFilter() | ||||
|   | ||||
| @@ -54,7 +54,7 @@ final class PersonHavingActivityBetweenDateFilterTest extends AbstractFilterTest | ||||
|             $data[] = [ | ||||
|                 'date_from' => DateTime::createFromFormat('Y-m-d', '2021-07-01'), | ||||
|                 'date_to' => DateTime::createFromFormat('Y-m-d', '2022-07-01'), | ||||
|                 'reasons' => [$a], | ||||
|                 'reasons' => $a, | ||||
|             ]; | ||||
|         } | ||||
|  | ||||
| @@ -72,9 +72,7 @@ final class PersonHavingActivityBetweenDateFilterTest extends AbstractFilterTest | ||||
|         return [ | ||||
|             $em->createQueryBuilder() | ||||
|                 ->select('count(activity.id)') | ||||
|                 ->from(Activity::class, 'activity') | ||||
|                 ->join('activity.person', 'person') | ||||
|             , | ||||
|                 ->from(Activity::class, 'activity'), | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -53,7 +53,8 @@ services: | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_type_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\ActivityDateFilter: | ||||
|     chill.activity.export.date_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ActivityDateFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_date_filter' } | ||||
|  | ||||
| @@ -73,43 +74,52 @@ services: | ||||
|                 name: chill.export_filter | ||||
|                 alias: 'activity_person_having_ac_bw_date_filter' | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\ACPFilters\ActivityTypeFilter: | ||||
|     chill.activity.export.filter_activitytype: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\ActivityTypeFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'accompanyingcourse_activitytype_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\LocationFilter: | ||||
|     chill.activity.export.location_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\LocationFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_location_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\LocationTypeFilter: | ||||
|     chill.activity.export.locationtype_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\LocationTypeFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_locationtype_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\ByCreatorFilter: | ||||
|     Chill\ActivityBundle\Export\Filter\ACPFilters\ByCreatorFilter: | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_bycreator_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\EmergencyFilter: | ||||
|     chill.activity.export.emergency_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\EmergencyFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_emergency_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\SentReceivedFilter: | ||||
|     chill.activity.export.sentreceived_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\SentReceivedFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_sentreceived_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialActionFilter: | ||||
|     chill.activity.export.bysocialaction_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialActionFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_bysocialaction_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialIssueFilter: | ||||
|     chill.activity.export.bysocialissue_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\BySocialIssueFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_bysocialissue_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\UserFilter: | ||||
|     chill.activity.export.user_filter: # Creator (M2O) | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\UserFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_user_filter' } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Filter\UserScopeFilter: | ||||
|     chill.activity.export.userscope_filter: | ||||
|         class: Chill\ActivityBundle\Export\Filter\ACPFilters\UserScopeFilter | ||||
|         tags: | ||||
|             - { name: chill.export_filter, alias: 'activity_userscope_filter' } | ||||
|  | ||||
| @@ -147,19 +157,22 @@ services: | ||||
|         tags: | ||||
|             - { name: chill.export_aggregator, alias: activity_user_aggregator } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Aggregator\LocationTypeAggregator: | ||||
|     chill.activity.export.locationtype_aggregator: | ||||
|         class: Chill\ActivityBundle\Export\Aggregator\ACPAggregators\LocationTypeAggregator | ||||
|         tags: | ||||
|             - { name: chill.export_aggregator, alias: activity_locationtype_aggregator } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Aggregator\DateAggregator: | ||||
|     chill.activity.export.date_aggregator: | ||||
|         class: Chill\ActivityBundle\Export\Aggregator\ACPAggregators\DateAggregator | ||||
|         tags: | ||||
|             - { name: chill.export_aggregator, alias: activity_date_aggregator } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Aggregator\ByCreatorAggregator: | ||||
|     Chill\ActivityBundle\Export\Aggregator\ACPAggregators\ByCreatorAggregator: | ||||
|         tags: | ||||
|             - { name: chill.export_aggregator, alias: activity_by_creator_aggregator } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Aggregator\ByThirdpartyAggregator: | ||||
|     chill.activity.export.bythirdparty_aggregator: | ||||
|         class: Chill\ActivityBundle\Export\Aggregator\ACPAggregators\ByThirdpartyAggregator | ||||
|         tags: | ||||
|             - { name: chill.export_aggregator, alias: activity_bythirdparty_aggregator } | ||||
|  | ||||
| @@ -173,7 +186,7 @@ services: | ||||
|         tags: | ||||
|             - { name: chill.export_aggregator, alias: activity_bysocialissue_aggregator } | ||||
|  | ||||
|     Chill\ActivityBundle\Export\Aggregator\CreatorScopeAggregator: | ||||
|     Chill\ActivityBundle\Export\Aggregator\ACPAggregators\CreatorScopeAggregator: | ||||
|         tags: | ||||
|             - { name: chill.export_aggregator, alias: activity_creator_scope_aggregator } | ||||
|  | ||||
|   | ||||
| @@ -3,9 +3,3 @@ export: | ||||
|         activity: | ||||
|             course_having_activity_between_date: | ||||
|                 Only course having an activity between from and to: Seulement les parcours ayant reçu au moins un échange entre le {from, date, short} et le {to, date, short} | ||||
|         person_between_dates: | ||||
|             describe_action_with_no_subject: >- | ||||
|                 Filtré par personne ayant eu un échange entre le {date_from, date} et le {date_to, date} | ||||
|             describe_action_with_subject: >- | ||||
|                 Filtré par personne ayant eu un échange entre le {date_from, date} et le {date_to, date}, et un de ces sujets choisis: {reasons} | ||||
|  | ||||
|   | ||||
| @@ -255,6 +255,11 @@ Activities before this date: Échanges avant cette date | ||||
| "Filtered by date of activity: only between %date_from% and %date_to%": "Filtré par date de l'échange: uniquement entre %date_from% et %date_to%" | ||||
| This date should be after the date given in "Implied in an activity after this date" field: Cette date devrait être postérieure à la date donnée dans le champ "échanges après cette date" | ||||
|  | ||||
| Filtered by person having an activity in a period: Uniquement les usagers ayant eu un échange dans la période donnée | ||||
| Implied in an activity after this date: Impliqué dans un échange après cette date | ||||
| Implied in an activity before this date: Impliqué dans un échange avant cette date | ||||
| Filtered by person having an activity between %date_from% and %date_to% with reasons %reasons_name%: Filtré par usager associées à un échange entre %date_from% et %date_to% avec les sujets %reasons_name% | ||||
| Activity reasons for those activities: Sujets de ces échanges | ||||
|  | ||||
| Filter by activity type: Filtrer les échanges par type | ||||
|  | ||||
| @@ -372,15 +377,7 @@ export: | ||||
|                 Title: Filtre les parcours ayant reçu un échange entre deux dates | ||||
|                 Receiving an activity after: Ayant reçu un échange après le | ||||
|                 Receiving an activity before: Ayant reçu un échange avant le | ||||
|             acp_by_activity_type: | ||||
|                 'acp_containing_at_least_one_%activitytypes%': 'Parcours filtrés: uniquement ceux qui contiennent au moins un échange d''un des types suivants: %activitytypes%' | ||||
|             person_between_dates: | ||||
|                 Implied in an activity after this date: Impliqué dans un échange après cette date | ||||
|                 Implied in an activity before this date: Impliqué dans un échange avant cette date | ||||
|                 Activity reasons for those activities: Sujets de ces échanges | ||||
|                 if no reasons: Si aucun sujet n'est coché, tous les sujets seront pris en compte | ||||
|                 title: Filtrer les personnes ayant été associés à un échange au cours de la période | ||||
|                 date mismatch: La date de fin de la période doit être supérieure à la date du début | ||||
|  | ||||
|  | ||||
|     aggregator: | ||||
|         activity: | ||||
|   | ||||
| @@ -13,6 +13,7 @@ namespace Chill\CalendarBundle\Export\Export; | ||||
|  | ||||
| use Chill\CalendarBundle\Export\Declarations; | ||||
| use Chill\CalendarBundle\Repository\CalendarRepository; | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -27,8 +28,9 @@ class CountCalendars implements ExportInterface, GroupedExportInterface | ||||
| { | ||||
|     private CalendarRepository $calendarRepository; | ||||
|  | ||||
|     public function __construct(CalendarRepository $calendarRepository) | ||||
|     { | ||||
|     public function __construct( | ||||
|         CalendarRepository $calendarRepository, | ||||
|     ) { | ||||
|         $this->calendarRepository = $calendarRepository; | ||||
|     } | ||||
|  | ||||
| @@ -98,6 +100,9 @@ class CountCalendars implements ExportInterface, GroupedExportInterface | ||||
|         $qb = $this->calendarRepository->createQueryBuilder('cal'); | ||||
|  | ||||
|         $qb->select('COUNT(cal.id) AS export_result'); | ||||
|         $qb->leftJoin('cal.accompanyingPeriod', 'acp'); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|   | ||||
| @@ -13,6 +13,7 @@ namespace Chill\CalendarBundle\Export\Export; | ||||
|  | ||||
| use Chill\CalendarBundle\Export\Declarations; | ||||
| use Chill\CalendarBundle\Repository\CalendarRepository; | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -27,7 +28,7 @@ class StatCalendarAvgDuration implements ExportInterface, GroupedExportInterface | ||||
|     private CalendarRepository $calendarRepository; | ||||
|  | ||||
|     public function __construct( | ||||
|         CalendarRepository $calendarRepository | ||||
|         CalendarRepository $calendarRepository, | ||||
|     ) { | ||||
|         $this->calendarRepository = $calendarRepository; | ||||
|     } | ||||
| @@ -92,8 +93,10 @@ class StatCalendarAvgDuration implements ExportInterface, GroupedExportInterface | ||||
|     { | ||||
|         $qb = $this->calendarRepository->createQueryBuilder('cal'); | ||||
|  | ||||
|         $qb | ||||
|             ->select('AVG(cal.endDate - cal.startDate) AS export_result'); | ||||
|         $qb->select('AVG(cal.endDate - cal.startDate) AS export_result'); | ||||
|         $qb->join('cal.accompanyingPeriod', 'acp'); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|   | ||||
| @@ -13,6 +13,7 @@ namespace Chill\CalendarBundle\Export\Export; | ||||
|  | ||||
| use Chill\CalendarBundle\Export\Declarations; | ||||
| use Chill\CalendarBundle\Repository\CalendarRepository; | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -27,7 +28,7 @@ class StatCalendarSumDuration implements ExportInterface, GroupedExportInterface | ||||
|     private CalendarRepository $calendarRepository; | ||||
|  | ||||
|     public function __construct( | ||||
|         CalendarRepository $calendarRepository | ||||
|         CalendarRepository $calendarRepository, | ||||
|     ) { | ||||
|         $this->calendarRepository = $calendarRepository; | ||||
|     } | ||||
| @@ -92,8 +93,10 @@ class StatCalendarSumDuration implements ExportInterface, GroupedExportInterface | ||||
|     { | ||||
|         $qb = $this->calendarRepository->createQueryBuilder('cal'); | ||||
|  | ||||
|         $qb | ||||
|             ->select('SUM(cal.endDate - cal.startDate) AS export_result'); | ||||
|         $qb->select('SUM(cal.endDate - cal.startDate) AS export_result'); | ||||
|         $qb->join('cal.accompanyingPeriod', 'acp'); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|   | ||||
| @@ -28,13 +28,6 @@ class AccompanyingCourseDocument extends Document implements HasScopesInterface, | ||||
|      */ | ||||
|     private ?AccompanyingPeriod $course = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Id | ||||
|      * @ORM\GeneratedValue | ||||
|      * @ORM\Column(type="integer") | ||||
|      */ | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     public function getCenters(): ?iterable | ||||
|     { | ||||
|         return $this->course->getCenters(); | ||||
| @@ -45,11 +38,6 @@ class AccompanyingCourseDocument extends Document implements HasScopesInterface, | ||||
|         return $this->course; | ||||
|     } | ||||
|  | ||||
|     public function getId() | ||||
|     { | ||||
|         return $this->id; | ||||
|     } | ||||
|  | ||||
|     public function getScopes(): iterable | ||||
|     { | ||||
|         if (null === $this->course) { | ||||
| @@ -65,5 +53,4 @@ class AccompanyingCourseDocument extends Document implements HasScopesInterface, | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -49,6 +49,13 @@ class Document implements TrackCreationInterface, TrackUpdateInterface | ||||
|      */ | ||||
|     private $description = ''; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Id | ||||
|      * @ORM\GeneratedValue | ||||
|      * @ORM\Column(type="integer") | ||||
|      */ | ||||
|     private $id; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne( | ||||
|      *     targetEntity="Chill\DocStoreBundle\Entity\StoredObject", | ||||
| @@ -96,6 +103,11 @@ class Document implements TrackCreationInterface, TrackUpdateInterface | ||||
|         return $this->description; | ||||
|     } | ||||
|  | ||||
|     public function getId() | ||||
|     { | ||||
|         return $this->id; | ||||
|     } | ||||
|  | ||||
|     public function getObject(): ?StoredObject | ||||
|     { | ||||
|         return $this->object; | ||||
|   | ||||
| @@ -23,13 +23,6 @@ use Doctrine\ORM\Mapping as ORM; | ||||
|  */ | ||||
| class PersonDocument extends Document implements HasCenterInterface, HasScopeInterface | ||||
| { | ||||
|     /** | ||||
|      * @ORM\Id | ||||
|      * @ORM\GeneratedValue | ||||
|      * @ORM\Column(type="integer") | ||||
|      */ | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\PersonBundle\Entity\Person") | ||||
|      */ | ||||
| @@ -47,11 +40,6 @@ class PersonDocument extends Document implements HasCenterInterface, HasScopeInt | ||||
|         return $this->getPerson()->getCenter(); | ||||
|     } | ||||
|  | ||||
|     public function getId() | ||||
|     { | ||||
|         return $this->id; | ||||
|     } | ||||
|  | ||||
|     public function getPerson(): Person | ||||
|     { | ||||
|         return $this->person; | ||||
|   | ||||
| @@ -0,0 +1,31 @@ | ||||
| <?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\MainBundle\Export; | ||||
|  | ||||
| use Doctrine\ORM\QueryBuilder; | ||||
|  | ||||
| final readonly class AccompanyingCourseExportHelper | ||||
| { | ||||
|     public static function addClosingMotiveExclusionClause(QueryBuilder $qb): QueryBuilder | ||||
|     { | ||||
|         $qb->leftJoin('acp.closingMotive', 'acpmotive') | ||||
|             ->andWhere( | ||||
|                 $qb->expr()->orX( | ||||
|                     $qb->expr()->eq('acpmotive.isCanceledAccompanyingPeriod', 'false'), | ||||
|                     $qb->expr()->isNull('acpmotive.closingMotive') | ||||
|                 ) | ||||
|             ); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -0,0 +1,122 @@ | ||||
| <?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 Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\PersonBundle\Entity\AccompanyingPeriod; | ||||
| use Chill\PersonBundle\Entity\AccompanyingPeriod\ClosingMotive; | ||||
| use Chill\PersonBundle\Repository\AccompanyingPeriodACLAwareRepositoryInterface; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| use Doctrine\ORM\EntityRepository; | ||||
| use Doctrine\ORM\QueryBuilder; | ||||
| use Symfony\Bundle\FrameworkBundle\Test\KernelTestCase; | ||||
|  | ||||
| /** | ||||
|  * @internal | ||||
|  * @coversNothing | ||||
|  */ | ||||
| class AccompanyingCourseExportHelperTest extends KernelTestCase | ||||
| { | ||||
|     /** | ||||
|      * @var list<array{0: class-string, 1: int}> | ||||
|      */ | ||||
|     private static array $entitiesToDelete = []; | ||||
|  | ||||
|     private EntityManagerInterface $em; | ||||
|  | ||||
|     private AccompanyingCourseExportHelper $accompanyingCourseExportHelper; | ||||
|  | ||||
|     protected function setUp(): void | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|         $this->em = self::$container->get(EntityManagerInterface::class); | ||||
|         $this->accompanyingCourseExportHelper = self::$container->get(AccompanyingCourseExportHelper::class); | ||||
|     } | ||||
|  | ||||
|     public static function tearDownAfterClass(): void | ||||
|     { | ||||
|         self::bootKernel(); | ||||
|         $em = self::$container->get(EntityManagerInterface::class); | ||||
|  | ||||
|         foreach (self::$entitiesToDelete as [$class, $id]) { | ||||
|             $entity = $em->find($class, $id); | ||||
|  | ||||
|             if (null !== $entity) { | ||||
|                 $em->remove($entity); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $em->flush(); | ||||
|     } | ||||
|  | ||||
|     public function testExclusionOnClosingMotive(): void | ||||
|     { | ||||
|         [$periodA, $periodB, $periodC] = $this->prepareData(); | ||||
|  | ||||
|         $qb = $this->em->getRepository(AccompanyingPeriod::class)->createQueryBuilder('acp'); | ||||
|         $this->accompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb->select('acp.id'); | ||||
|  | ||||
|         $periodIdsFound = array_map(fn ($el) => $el['id'], $qb->getQuery()->getResult()); | ||||
|  | ||||
|         $periodA = $this->em->find(AccompanyingPeriod::class, $periodA->getId()); | ||||
|         $periodB = $this->em->find(AccompanyingPeriod::class, $periodB->getId()); | ||||
|         $periodC = $this->em->find(AccompanyingPeriod::class, $periodC->getId()); | ||||
|  | ||||
|         self::assertContains($periodA->getId(), $periodIdsFound, 'Period without canceled closing motive has been found'); | ||||
|         self::assertNotContains($periodB->getId(), $periodIdsFound, 'Period with canceled closing motive has not been found'); | ||||
|         self::assertNotContains($periodC->getId(), $periodIdsFound, 'Period with child canceled closing motive has not been found'); | ||||
|     } | ||||
|  | ||||
|     private function prepareData() | ||||
|     { | ||||
|         $cmA = new ClosingMotive(); | ||||
|         $cmA->setIsCanceledAccompanyingPeriod(false); | ||||
|  | ||||
|         $cmB = new ClosingMotive(); | ||||
|         $cmB->setIsCanceledAccompanyingPeriod(true); | ||||
|  | ||||
|         $cmChild = new ClosingMotive(); | ||||
|         $cmB->addChildren($cmChild); | ||||
|  | ||||
|         $this->em->persist($cmA); | ||||
|         $this->em->persist($cmB); | ||||
|         $this->em->persist($cmChild); | ||||
|  | ||||
|         $periodA = new AccompanyingPeriod(); | ||||
|         $periodB = new AccompanyingPeriod(); | ||||
|         $periodC = new AccompanyingPeriod(); | ||||
|  | ||||
|         $periodA->setClosingMotive($cmA); | ||||
|         $periodB->setClosingMotive($cmB); | ||||
|         $periodC->setClosingMotive($cmChild); | ||||
|  | ||||
|         $this->em->persist($periodA); | ||||
|         $this->em->persist($periodB); | ||||
|         $this->em->persist($periodC); | ||||
|  | ||||
|         self::$entitiesToDelete[] = [ClosingMotive::class, $cmChild]; | ||||
|         self::$entitiesToDelete[] = [ClosingMotive::class, $cmA]; | ||||
|         self::$entitiesToDelete[] = [ClosingMotive::class, $cmB]; | ||||
|  | ||||
|         self::$entitiesToDelete[] = [AccompanyingPeriod::class, $periodA]; | ||||
|         self::$entitiesToDelete[] = [AccompanyingPeriod::class, $periodB]; | ||||
|         self::$entitiesToDelete[] = [AccompanyingPeriod::class, $periodC]; | ||||
|  | ||||
|         $this->em->flush(); | ||||
|         $this->em->clear(); | ||||
|  | ||||
|         return [$periodA, $periodB, $periodC]; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -52,3 +52,4 @@ services: | ||||
|             $exportManager: '@Chill\MainBundle\Export\ExportManager' | ||||
|         tags: | ||||
|             - { name: chill.export_formatter, alias: 'csv_pivoted_list' } | ||||
|  | ||||
|   | ||||
| @@ -100,7 +100,7 @@ class ReassignAccompanyingPeriodController extends AbstractController | ||||
|  | ||||
|         $total = $this->accompanyingPeriodACLAwareRepository->countByUserAndPostalCodesOpenedAccompanyingPeriod($userFrom, $postalCodes); | ||||
|         $paginator = $this->paginatorFactory->create($total); | ||||
|         $paginator->setItemsPerPage(100); | ||||
|         $paginator->setItemsPerPage(50); | ||||
|         $periods = $this->accompanyingPeriodACLAwareRepository | ||||
|             ->findByUserAndPostalCodesOpenedAccompanyingPeriod( | ||||
|                 $userFrom, | ||||
| @@ -123,7 +123,6 @@ class ReassignAccompanyingPeriodController extends AbstractController | ||||
|  | ||||
|         if ($assignForm->isSubmitted() && $assignForm->isValid()) { | ||||
|             $assignPeriodIds = json_decode($assignForm->get('periods')->getData(), true, 512, JSON_THROW_ON_ERROR); | ||||
|             /** @var User $userTo */ | ||||
|             $userTo = $assignForm->get('userTo')->getData(); | ||||
|             $userFrom = $assignForm->get('userFrom')->getData(); | ||||
|  | ||||
| @@ -132,10 +131,6 @@ class ReassignAccompanyingPeriodController extends AbstractController | ||||
|  | ||||
|                 if ($period->getUser() === $userFrom) { | ||||
|                     $period->setUser($userTo, true); | ||||
|  | ||||
|                     if (null !== $userTo->getUserJob() && $period->getJob() !== $userTo->getUserJob()) { | ||||
|                         $period->setJob($userTo->getUserJob()); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|   | ||||
| @@ -69,6 +69,11 @@ class ClosingMotive | ||||
|      */ | ||||
|     private ?ClosingMotive $parent = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="boolean", nullable=false, options={"default": false}) | ||||
|      */ | ||||
|     private bool $isCanceledAccompanyingPeriod = false; | ||||
|  | ||||
|     /** | ||||
|      * ClosingMotive constructor. | ||||
|      */ | ||||
| @@ -84,7 +89,7 @@ class ClosingMotive | ||||
|         } | ||||
|  | ||||
|         $this->children->add($child); | ||||
|         $child->setParent($this); | ||||
|         $child->setParent($this)->setIsCanceledAccompanyingPeriod($this->getIsCanceledAccompanyingPeriod()); | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
| @@ -127,6 +132,11 @@ class ClosingMotive | ||||
|         return $this->parent; | ||||
|     } | ||||
|  | ||||
|     public function getIsCanceledAccompanyingPeriod(): bool | ||||
|     { | ||||
|         return $this->isCanceledAccompanyingPeriod; | ||||
|     } | ||||
|  | ||||
|     public function hasParent(): bool | ||||
|     { | ||||
|         return null !== $this->parent; | ||||
| @@ -152,6 +162,11 @@ class ClosingMotive | ||||
|         return $this->children->count() > 0; | ||||
|     } | ||||
|  | ||||
|     public function isCanceledAccompanyingPeriod(): bool | ||||
|     { | ||||
|         return $this->isCanceledAccompanyingPeriod; | ||||
|     } | ||||
|  | ||||
|     public function removeChildren(ClosingMotive $child): ClosingMotive | ||||
|     { | ||||
|         if ($this->children->removeElement($child)) { | ||||
| @@ -218,4 +233,15 @@ class ClosingMotive | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     public function setIsCanceledAccompanyingPeriod(bool $isCanceledAP): ClosingMotive | ||||
|     { | ||||
|         $this->isCanceledAccompanyingPeriod = $isCanceledAP; | ||||
|  | ||||
|         foreach ($this->getChildren() as $child) { | ||||
|             $child->setIsCanceledAccompanyingPeriod($isCanceledAP); | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -224,7 +224,7 @@ class SocialIssue | ||||
|     /** | ||||
|      * @param array|SocialIssue[] $socialIssues | ||||
|      */ | ||||
|     public static function getDescendantsWithThisForIssues(array|Collection $socialIssues): Collection | ||||
|     public static function getDescendantsWithThisForIssues(array $socialIssues): Collection | ||||
|     { | ||||
|         $unique = []; | ||||
|  | ||||
|   | ||||
| @@ -22,9 +22,6 @@ abstract class Declarations | ||||
|  | ||||
|     public const HOUSEHOLD_TYPE = 'household'; | ||||
|  | ||||
|     /** | ||||
|      * @deprecated consider using the PERSON_TYPE instead | ||||
|      */ | ||||
|     public const PERSON_IMPLIED_IN = 'person_implied_in'; | ||||
|  | ||||
|     public const PERSON_TYPE = 'person'; | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -30,7 +31,7 @@ class CountAccompanyingCourse implements ExportInterface, GroupedExportInterface | ||||
|     protected EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(AccompanyingPeriod::class); | ||||
|     } | ||||
| @@ -111,6 +112,8 @@ class CountAccompanyingCourse implements ExportInterface, GroupedExportInterface | ||||
|             ->setParameter('count_acp_step', AccompanyingPeriod::STEP_DRAFT) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb->select('COUNT(DISTINCT acp.id) AS export_result'); | ||||
|  | ||||
|         return $qb; | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -29,7 +30,7 @@ class CountAccompanyingPeriodWork implements ExportInterface, GroupedExportInter | ||||
|     protected EntityManagerInterface $em; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->em = $em; | ||||
|     } | ||||
| @@ -112,6 +113,8 @@ class CountAccompanyingPeriodWork implements ExportInterface, GroupedExportInter | ||||
|  | ||||
|         $qb->select('COUNT(DISTINCT acpw.id) as export_result'); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -28,7 +29,7 @@ class CountEvaluation implements ExportInterface, GroupedExportInterface | ||||
|     private EntityManagerInterface $entityManager; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->entityManager = $em; | ||||
|     } | ||||
| @@ -110,6 +111,8 @@ class CountEvaluation implements ExportInterface, GroupedExportInterface | ||||
|             ) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb->select('COUNT(DISTINCT workeval.id) AS export_result'); | ||||
|  | ||||
|         return $qb; | ||||
|   | ||||
| @@ -120,7 +120,9 @@ class CountPerson implements ExportInterface, GroupedExportInterface | ||||
|     public function supportsModifiers() | ||||
|     { | ||||
|         return [ | ||||
|             Declarations::PERSON_TYPE, | ||||
|             'abcde', | ||||
|             //Declarations::PERSON_TYPE, | ||||
|             //Declarations::PERSON_IMPLIED_IN, | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -30,7 +31,7 @@ class CountPersonWithAccompanyingCourse implements ExportInterface, GroupedExpor | ||||
|     private EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(AccompanyingPeriod::class); | ||||
|     } | ||||
| @@ -111,6 +112,8 @@ class CountPersonWithAccompanyingCourse implements ExportInterface, GroupedExpor | ||||
|             ) | ||||
|         )->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb->select('COUNT(DISTINCT person.id) AS export_result'); | ||||
|  | ||||
|         return $qb; | ||||
|   | ||||
| @@ -13,6 +13,7 @@ namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Entity\Address; | ||||
| use Chill\MainBundle\Entity\Scope; | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| use Chill\MainBundle\Export\Helper\DateTimeHelper; | ||||
| @@ -132,6 +133,8 @@ final readonly class ListAccompanyingPeriod implements ListInterface, GroupedExp | ||||
|  | ||||
|         $this->listAccompanyingPeriodHelper->addSelectClauses($qb, $this->rollingDateConverter->convert($data['calc_date'])); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb | ||||
|             ->addOrderBy('acp.openingDate') | ||||
|             ->addOrderBy('acp.closingDate') | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| use Chill\MainBundle\Export\Helper\AggregateStringHelper; | ||||
| @@ -112,7 +113,7 @@ class ListAccompanyingPeriodWork implements ListInterface, GroupedExportInterfac | ||||
|         SocialActionRender $socialActionRender, | ||||
|         RollingDateConverterInterface $rollingDateConverter, | ||||
|         AggregateStringHelper $aggregateStringHelper, | ||||
|         SocialActionRepository $socialActionRepository | ||||
|         SocialActionRepository $socialActionRepository, | ||||
|     ) { | ||||
|         $this->entityManager = $entityManager; | ||||
|         $this->dateTimeHelper = $dateTimeHelper; | ||||
| @@ -291,6 +292,8 @@ class ListAccompanyingPeriodWork implements ListInterface, GroupedExportInterfac | ||||
|             ->setParameter('authorized_centers', $centers) | ||||
|             ->setParameter('calc_date', $this->rollingDateConverter->convert($data['calc_date'])); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $this->addSelectClauses($qb, $this->rollingDateConverter->convert($data['calc_date'])); | ||||
|  | ||||
|         return $qb; | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| use Chill\MainBundle\Export\Helper\AggregateStringHelper; | ||||
| @@ -101,7 +102,7 @@ class ListEvaluation implements ListInterface, GroupedExportInterface | ||||
|         DateTimeHelper $dateTimeHelper, | ||||
|         TranslatableStringExportLabelHelper $translatableStringExportLabelHelper, | ||||
|         AggregateStringHelper $aggregateStringHelper, | ||||
|         RollingDateConverterInterface $rollingDateConverter | ||||
|         RollingDateConverterInterface $rollingDateConverter, | ||||
|     ) { | ||||
|         $this->entityManager = $entityManager; | ||||
|         $this->socialIssueRender = $socialIssueRender; | ||||
| @@ -270,6 +271,8 @@ class ListEvaluation implements ListInterface, GroupedExportInterface | ||||
|             ->setParameter('authorized_centers', $centers) | ||||
|             ->setParameter('calc_date', $this->rollingDateConverter->convert($data['calc_date'])); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $this->addSelectClauses($qb, $this->rollingDateConverter->convert($data['calc_date'])); | ||||
|  | ||||
|         return $qb; | ||||
|   | ||||
| @@ -266,7 +266,7 @@ class ListPerson implements ExportElementValidatedInterface, ListInterface, Grou | ||||
|  | ||||
|     public function supportsModifiers() | ||||
|     { | ||||
|         return [Declarations::PERSON_TYPE]; | ||||
|         return [Declarations::PERSON_TYPE, Declarations::PERSON_IMPLIED_IN]; | ||||
|     } | ||||
|  | ||||
|     public function validateForm($data, ExecutionContextInterface $context) | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportElementValidatedInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -51,7 +52,7 @@ class ListPersonHavingAccompanyingPeriod implements ExportElementValidatedInterf | ||||
|     public function __construct( | ||||
|         ExportAddressHelper $addressHelper, | ||||
|         ListPersonHelper $listPersonHelper, | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->addressHelper = $addressHelper; | ||||
|         $this->listPersonHelper = $listPersonHelper; | ||||
| @@ -190,6 +191,8 @@ class ListPersonHavingAccompanyingPeriod implements ExportElementValidatedInterf | ||||
|  | ||||
|         $this->listPersonHelper->addSelect($qb, $fields, $data['address_date']); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb | ||||
|             ->addOrderBy('person.lastName') | ||||
|             ->addOrderBy('person.firstName') | ||||
| @@ -205,7 +208,7 @@ class ListPersonHavingAccompanyingPeriod implements ExportElementValidatedInterf | ||||
|  | ||||
|     public function supportsModifiers() | ||||
|     { | ||||
|         return [Declarations::PERSON_TYPE, Declarations::ACP_TYPE]; | ||||
|         return [Declarations::PERSON_TYPE, Declarations::PERSON_IMPLIED_IN, Declarations::ACP_TYPE]; | ||||
|     } | ||||
|  | ||||
|     public function validateForm($data, ExecutionContextInterface $context) | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportElementValidatedInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -133,6 +134,8 @@ final readonly class ListPersonWithAccompanyingPeriodDetails implements ListInte | ||||
|         $this->listPersonHelper->addSelect($qb, ListPersonHelper::FIELDS, $this->rollingDateConverter->convert($data['address_date'])); | ||||
|         $this->listAccompanyingPeriodHelper->addSelectClauses($qb, $this->rollingDateConverter->convert($data['address_date'])); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         $qb | ||||
|             ->addOrderBy('person.lastName') | ||||
|             ->addOrderBy('person.firstName') | ||||
| @@ -149,6 +152,6 @@ final readonly class ListPersonWithAccompanyingPeriodDetails implements ListInte | ||||
|  | ||||
|     public function supportsModifiers() | ||||
|     { | ||||
|         return [Declarations::PERSON_TYPE, Declarations::ACP_TYPE]; | ||||
|         return [Declarations::PERSON_TYPE, Declarations::PERSON_IMPLIED_IN, Declarations::ACP_TYPE]; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -11,6 +11,7 @@ declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\PersonBundle\Export\Export; | ||||
|  | ||||
| use Chill\MainBundle\Export\AccompanyingCourseExportHelper; | ||||
| use Chill\MainBundle\Export\ExportInterface; | ||||
| use Chill\MainBundle\Export\FormatterInterface; | ||||
| use Chill\MainBundle\Export\GroupedExportInterface; | ||||
| @@ -32,7 +33,7 @@ class StatAccompanyingCourseDuration implements ExportInterface, GroupedExportIn | ||||
|     private EntityRepository $repository; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em | ||||
|         EntityManagerInterface $em, | ||||
|     ) { | ||||
|         $this->repository = $em->getRepository(AccompanyingPeriod::class); | ||||
|     } | ||||
| @@ -142,6 +143,8 @@ class StatAccompanyingCourseDuration implements ExportInterface, GroupedExportIn | ||||
|             ->setParameter('count_acp_step', AccompanyingPeriod::STEP_DRAFT) | ||||
|             ->setParameter('authorized_centers', $centers); | ||||
|  | ||||
|         AccompanyingCourseExportHelper::addClosingMotiveExclusionClause($qb); | ||||
|  | ||||
|         return $qb; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -12,17 +12,28 @@ declare(strict_types=1); | ||||
| namespace Chill\PersonBundle\Export\Filter\AccompanyingCourseFilters; | ||||
|  | ||||
| use Chill\MainBundle\Export\FilterInterface; | ||||
| use Chill\PersonBundle\Entity\AccompanyingPeriod; | ||||
| use Chill\MainBundle\Templating\TranslatableStringHelper; | ||||
| use Chill\PersonBundle\Entity\SocialWork\SocialAction; | ||||
| use Chill\PersonBundle\Export\Declarations; | ||||
| use Chill\PersonBundle\Form\Type\PickSocialActionType; | ||||
| use Chill\PersonBundle\Templating\Entity\SocialActionRender; | ||||
| use Doctrine\ORM\QueryBuilder; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
| use function in_array; | ||||
|  | ||||
| final readonly class SocialActionFilter implements FilterInterface | ||||
| class SocialActionFilter implements FilterInterface | ||||
| { | ||||
|     public function __construct(private SocialActionRender $actionRender) {} | ||||
|     private SocialActionRender $actionRender; | ||||
|  | ||||
|     private TranslatableStringHelper $translatableStringHelper; | ||||
|  | ||||
|     public function __construct( | ||||
|         TranslatableStringHelper $translatableStringHelper, | ||||
|         SocialActionRender $actionRender | ||||
|     ) { | ||||
|         $this->translatableStringHelper = $translatableStringHelper; | ||||
|         $this->actionRender = $actionRender; | ||||
|     } | ||||
|  | ||||
|     public function addRole(): ?string | ||||
|     { | ||||
| @@ -31,17 +42,21 @@ final readonly class SocialActionFilter implements FilterInterface | ||||
|  | ||||
|     public function alterQuery(QueryBuilder $qb, $data) | ||||
|     { | ||||
|         $qb->andWhere( | ||||
|             $qb->expr()->exists( | ||||
|                 sprintf( | ||||
|                     "SELECT 1 FROM %s acp_by_social_action_filter WHERE acp_by_social_action_filter.socialAction " | ||||
|                     . "IN (:acp_by_social_action_filter_actions) AND acp_by_social_action_filter.accompanyingPeriod = acp", | ||||
|                     AccompanyingPeriod\AccompanyingPeriodWork::class | ||||
|                 ) | ||||
|             ) | ||||
|         ); | ||||
|         if (!in_array('acpw', $qb->getAllAliases(), true)) { | ||||
|             $qb->join('acp.works', 'acpw'); | ||||
|         } | ||||
|  | ||||
|         $qb->setParameter('acp_by_social_action_filter_actions', SocialAction::getDescendantsWithThisForActions($data['accepted_socialactions'])); | ||||
|         if (!in_array('acpwsocialaction', $qb->getAllAliases(), true)) { | ||||
|             $qb->join('acpw.socialAction', 'acpwsocialaction'); | ||||
|         } | ||||
|  | ||||
|         $clause = $qb->expr()->in('acpwsocialaction.id', ':socialactions'); | ||||
|  | ||||
|         $qb->andWhere($clause) | ||||
|             ->setParameter( | ||||
|                 'socialactions', | ||||
|                 SocialAction::getDescendantsWithThisForActions($data['accepted_socialactions'])->toArray() | ||||
|             ); | ||||
|     } | ||||
|  | ||||
|     public function applyOn(): string | ||||
|   | ||||
| @@ -45,22 +45,23 @@ class CompositionFilter implements FilterInterface | ||||
|  | ||||
|     public function alterQuery(QueryBuilder $qb, $data) | ||||
|     { | ||||
|         // there is no test on the aliases here: the name should be unique | ||||
|         $clause = | ||||
|             $qb->expr()->andX( | ||||
|                 $qb->expr()->lte('composition_type_filter_composition.startDate', ':ondate_composition_type_filter'), | ||||
|                 $qb->expr()->orX( | ||||
|                     $qb->expr()->gt('composition_type_filter_composition.endDate', ':ondate_composition_type_filter'), | ||||
|                     $qb->expr()->isNull('composition_type_filter_composition.endDate') | ||||
|                 ) | ||||
|             ); | ||||
|         if (!in_array('composition_type_filter', $qb->getAllAliases(), true)) { | ||||
|             $clause = | ||||
|                 $qb->expr()->andX( | ||||
|                     $qb->expr()->lte('composition_type_filter.startDate', ':ondate_composition_type_filter'), | ||||
|                     $qb->expr()->orX( | ||||
|                         $qb->expr()->gt('composition_type_filter.endDate', ':ondate_composition_type_filter'), | ||||
|                         $qb->expr()->isNull('composition_type_filter.endDate') | ||||
|                     ) | ||||
|                 ); | ||||
|  | ||||
|         $qb->join('household.compositions', 'composition_type_filter_composition', Expr\Join::WITH, $clause); | ||||
|             $qb->join('household.compositions', 'composition', Expr\Join::WITH, $clause); | ||||
|         } | ||||
|  | ||||
|         $whereClause = $qb->expr()->in('composition_type_filter_composition.householdCompositionType', ':compositions_composition_type_filter'); | ||||
|         $whereClause = $qb->expr()->in('composition_type_filter.householdCompositionType', ':compositions'); | ||||
|  | ||||
|         $qb->andWhere($whereClause); | ||||
|         $qb->setParameter('compositions_composition_type_filter', $data['accepted_composition']); | ||||
|         $qb->setParameter('compositions', $data['accepted_composition']); | ||||
|         $qb->setParameter( | ||||
|             'ondate_composition_type_filter', | ||||
|             $this->rollingDateConverter->convert($data['on_date']) | ||||
|   | ||||
| @@ -19,12 +19,20 @@ use Symfony\Component\Form\Extension\Core\Type\CheckboxType; | ||||
| use Symfony\Component\Form\Extension\Core\Type\NumberType; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
| use Symfony\Component\OptionsResolver\OptionsResolver; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| /** | ||||
|  * Class ClosingMotiveType. | ||||
|  */ | ||||
| class ClosingMotiveType extends AbstractType | ||||
| { | ||||
|     private TranslatorInterface $translator; | ||||
|  | ||||
|     public function __construct(TranslatorInterface $translator) | ||||
|     { | ||||
|         $this->translator = $translator; | ||||
|     } | ||||
|  | ||||
|     public function buildForm(FormBuilderInterface $builder, array $options) | ||||
|     { | ||||
|         $builder | ||||
| @@ -46,6 +54,11 @@ class ClosingMotiveType extends AbstractType | ||||
|                 'placeholder' => 'closing_motive.any parent', | ||||
|                 'multiple' => false, | ||||
|                 'only_leaf' => false, | ||||
|             ]) | ||||
|             ->add('isCanceledAccompanyingPeriod', CheckboxType::class, [ | ||||
|                 'label' => $this->translator->trans('Consider canceled'), | ||||
|                 'required' => false, | ||||
|                 'help' => $this->translator->trans('Canceled parcours help') | ||||
|             ]); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -122,7 +122,7 @@ final class AccompanyingPeriodWorkRepository implements ObjectRepository | ||||
|                 . ")"; | ||||
|         } | ||||
|  | ||||
|         $sql .= " AND daterange(:after::date, :before::date) && daterange(w.startDate, w.endDate, '[]')"; | ||||
|         $sql .= " AND daterange(:after::date, :before::date) && daterange(w.startDate, w.endDate)"; | ||||
|  | ||||
|         // if the start and end date were inversed, we inverse the order to avoid an error | ||||
|         if (null !== ($filters['after'] ?? null) && null !== ($filters['before']) && $filters['after'] > $filters['before']) { | ||||
|   | ||||
| @@ -79,10 +79,11 @@ final readonly class AccompanyingPeriodACLAwareRepository implements Accompanyin | ||||
|                     Join::WITH, | ||||
|                     'COALESCE(IDENTITY(person_address.address), IDENTITY(location_history.addressLocation)) = address.id' | ||||
|                 ) | ||||
|                 ->join('address.postcode', 'postcode') | ||||
|                 ->andWhere( | ||||
|                     $qb->expr()->in('address.postcode', ':postal_codes') | ||||
|                     $qb->expr()->in('postcode.code', ':postal_codes') | ||||
|                 ) | ||||
|                 ->setParameter('postal_codes', $postalCodes); | ||||
|                 ->setParameter('postal_codes', array_map(fn (PostalCode $postalCode) => $postalCode->getCode(), $postalCodes)); | ||||
|         } | ||||
|  | ||||
|         return $qb; | ||||
|   | ||||
| @@ -16,6 +16,7 @@ use Chill\MainBundle\Templating\Entity\BoxUtilsChillEntityRenderTrait; | ||||
| use Chill\MainBundle\Templating\Entity\ChillEntityRenderInterface; | ||||
| use Chill\MainBundle\Templating\TranslatableStringHelper; | ||||
| use Chill\PersonBundle\Entity\AccompanyingPeriod\ClosingMotive; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| /** | ||||
|  * Render closing motive. | ||||
| @@ -32,7 +33,7 @@ class ClosingMotiveRender implements ChillEntityRenderInterface | ||||
|      */ | ||||
|     private $translatableStringHelper; | ||||
|  | ||||
|     public function __construct(TranslatableStringHelper $translatableStringHelper) | ||||
|     public function __construct(TranslatableStringHelper $translatableStringHelper, private TranslatorInterface $translator) | ||||
|     { | ||||
|         $this->translatableStringHelper = $translatableStringHelper; | ||||
|     } | ||||
| @@ -62,6 +63,7 @@ class ClosingMotiveRender implements ChillEntityRenderInterface | ||||
|     private function renderStringRecursive(ClosingMotive $motive, string $existing, array $options) | ||||
|     { | ||||
|         $newExisting = $this->translatableStringHelper->localize($motive->getName()); | ||||
|         $isCancled = $motive->getIsCanceledAccompanyingPeriod() ? $this->translator->trans('( Canceled period )') : ''; | ||||
|  | ||||
|         if ($motive->hasParent()) { | ||||
|             if ('' !== $existing) { | ||||
| @@ -70,7 +72,7 @@ class ClosingMotiveRender implements ChillEntityRenderInterface | ||||
|  | ||||
|             return $this->renderStringRecursive( | ||||
|                 $motive->getParent(), | ||||
|                 $newExisting, | ||||
|                 $newExisting . ' ' . $isCancled, | ||||
|                 $options | ||||
|             ); | ||||
|         } | ||||
| @@ -79,6 +81,6 @@ class ClosingMotiveRender implements ChillEntityRenderInterface | ||||
|             return $newExisting . self::SEPARATOR . $existing; | ||||
|         } | ||||
|  | ||||
|         return $newExisting; | ||||
|         return $newExisting . ' ' . $isCancled; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -15,6 +15,7 @@ use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Chill\PersonBundle\Entity\Household\Household; | ||||
| use Chill\PersonBundle\Entity\Household\HouseholdCompositionType; | ||||
| use Chill\PersonBundle\Export\Filter\HouseholdFilters\CompositionFilter; | ||||
| use DateTime; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -0,0 +1,36 @@ | ||||
| <?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\Migrations\Person; | ||||
|  | ||||
| use Doctrine\DBAL\Schema\Schema; | ||||
| use Doctrine\Migrations\AbstractMigration; | ||||
|  | ||||
| /** | ||||
|  * Add isCanceledAccompanyingPeriod property to ClosingMotive | ||||
|  */ | ||||
| final class Version20230918115305 extends AbstractMigration | ||||
| { | ||||
|     public function getDescription(): string | ||||
|     { | ||||
|         return 'Add isCanceledAccompanyingPeriod property to ClosingMotive'; | ||||
|     } | ||||
|  | ||||
|     public function up(Schema $schema): void | ||||
|     { | ||||
|         $this->addSql('ALTER TABLE chill_person_accompanying_period_closingmotive ADD isCanceledAccompanyingPeriod BOOLEAN DEFAULT FALSE NOT NULL'); | ||||
|     } | ||||
|  | ||||
|     public function down(Schema $schema): void | ||||
|     { | ||||
|         $this->addSql('ALTER TABLE chill_person_accompanying_period_closingmotive DROP isCanceledAccompanyingPeriod'); | ||||
|     } | ||||
| } | ||||
| @@ -1,60 +0,0 @@ | ||||
| <?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\Migrations\Person; | ||||
|  | ||||
| use Doctrine\DBAL\Schema\Schema; | ||||
| use Doctrine\Migrations\AbstractMigration; | ||||
|  | ||||
| final class Version20231002094521 extends AbstractMigration | ||||
| { | ||||
|     public function getDescription(): string | ||||
|     { | ||||
|         return 'Remove doublons in chill_person_accompanying_period_location_history and add a constraint on startdate / endDate by period'; | ||||
|     } | ||||
|  | ||||
|     public function up(Schema $schema): void | ||||
|     { | ||||
|         $this->addSql( | ||||
|             <<<'SQL' | ||||
|             WITH doublons_ordered AS ( | ||||
|                 SELECT h2.id AS h2id, h2.createdAt AS h2createdAt, h2.startDate AS h2start, h2.endDate AS h2end, h1.*, | ||||
|                        rank() OVER (partition by h1.period_id ORDER BY h1.id, h2.id) AS ranking | ||||
|                 FROM chill_person_accompanying_period_location_history h1 | ||||
|                          JOIN chill_person_accompanying_period_location_history h2 ON h1.period_id = h2.period_id  AND h1.id <> h2.id | ||||
|                 WHERE daterange(h1.startdate, h1.enddate) && daterange(h2.startdate, h2.enddate) ORDER BY h1.period_id, h1.id | ||||
|             ), | ||||
|             keep_only_first AS ( | ||||
|                 SELECT id FROM doublons_ordered WHERE ranking > 1 | ||||
|             ) | ||||
|             DELETE FROM chill_person_accompanying_period_location_history WHERE id IN (SELECT id FROM doublons_ordered); | ||||
|             SQL | ||||
|         ); | ||||
|  | ||||
|         $this->addSql( | ||||
|             <<<'SQL' | ||||
|                     ALTER TABLE chill_person_accompanying_period_location_history | ||||
|                     ADD CONSTRAINT acc_period_location_history_not_overlaps | ||||
|                     EXCLUDE USING GIST (period_id with =, tsrange(startdate, enddate) with &&) | ||||
|                     DEFERRABLE INITIALLY DEFERRED | ||||
|             SQL | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     public function down(Schema $schema): void | ||||
|     { | ||||
|         $this->addSql( | ||||
|             <<<'SQL' | ||||
|             ALTER TABLE chill_person_accompanying_period_location_history DROP CONSTRAINT acc_period_location_history_not_overlaps | ||||
|             SQL | ||||
|         ); | ||||
|     } | ||||
| } | ||||
| @@ -349,6 +349,9 @@ CHILL_PERSON_HOUSEHOLD_STATS: Statistiques sur les ménages | ||||
| #period | ||||
| Period closed!: Parcours clôturé! | ||||
| Pediod closing form is not valide: Le formulaire de fermeture n'est pas valide | ||||
| Consider canceled: Permet de considérer les parcours comme annulés | ||||
| Canceled parcours help: Si coché, les parcours avec ce motif de cloture seront considérés comme annulés et ne seront pas pris en compte pour les statistiques. La modification se reflétera pour tous les motifs enfants | ||||
| ( Canceled period ): ( annulé ) | ||||
|  | ||||
| #widget | ||||
|  | ||||
|   | ||||
| @@ -463,7 +463,7 @@ class ReportList implements ExportElementValidatedInterface, ListInterface | ||||
|  | ||||
|     public function supportsModifiers() | ||||
|     { | ||||
|         return [Declarations::PERSON_TYPE, 'report']; | ||||
|         return [Declarations::PERSON_IMPLIED_IN, Declarations::PERSON_TYPE, 'report']; | ||||
|     } | ||||
|  | ||||
|     public function validateForm($data, ExecutionContextInterface $context) | ||||
|   | ||||
| @@ -38,7 +38,7 @@ class SingleTaskPlaceEvent extends AbstractTaskPlaceEvent | ||||
|      * @ORM\Id | ||||
|      * @ORM\GeneratedValue(strategy="AUTO") | ||||
|      */ | ||||
|     private ?int $id = null; | ||||
|     private $id; | ||||
|  | ||||
|     /** | ||||
|      * @var SingleTask | ||||
| @@ -70,4 +70,11 @@ class SingleTaskPlaceEvent extends AbstractTaskPlaceEvent | ||||
|     { | ||||
|         return $this->id; | ||||
|     } | ||||
|  | ||||
|     public function setId($id): self | ||||
|     { | ||||
|         $this->id = $id; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -25,7 +25,7 @@ | ||||
|  | ||||
|                     <dt>{{ 'Name'|trans }}</dt> | ||||
|                     <dd> | ||||
|                         {% if thirdParty.isLeaf == true and thirdParty.civility is not same as null %}{{ thirdParty.civility.name|localize_translatable_string }}{% endif %} | ||||
|                         {% if thirdParty.isLeaf == true %}{{ thirdParty.civility }}{% endif %} | ||||
|                         {{ thirdParty.firstname ~ ' ' ~ thirdParty.name }} | ||||
|                     </dd> | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user