mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-24 22:23:13 +00:00 
			
		
		
		
	Merge branch 'rector/rules-up-to-php74' into 'master'
Rector/rules up to php74 See merge request Chill-Projet/chill-bundles!522
This commit is contained in:
		| @@ -21,7 +21,7 @@ return static function (RectorConfig $rectorConfig): void { | ||||
|  | ||||
|     //define sets of rules | ||||
|     $rectorConfig->sets([ | ||||
|         LevelSetList::UP_TO_PHP_73 | ||||
|         LevelSetList::UP_TO_PHP_74 | ||||
|     ]); | ||||
|  | ||||
|     // skip some path... | ||||
|   | ||||
| @@ -59,9 +59,7 @@ class Configuration implements ConfigurationInterface | ||||
|             ->info('The number of seconds of this duration. Must be an integer.') | ||||
|             ->cannotBeEmpty() | ||||
|             ->validate() | ||||
|             ->ifTrue(static function ($data) { | ||||
|                 return !is_int($data); | ||||
|             })->thenInvalid('The value %s is not a valid integer') | ||||
|             ->ifTrue(static fn ($data) => !is_int($data))->thenInvalid('The value %s is not a valid integer') | ||||
|             ->end() | ||||
|             ->end() | ||||
|             ->scalarNode('label') | ||||
|   | ||||
| @@ -195,7 +195,7 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\MainBundle\Entity\User") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private ?User $user; | ||||
|     private ?User $user = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToMany(targetEntity="Chill\MainBundle\Entity\User") | ||||
|   | ||||
| @@ -34,7 +34,7 @@ class ActivityPresence | ||||
|      * @ORM\GeneratedValue(strategy="AUTO") | ||||
|      * @Serializer\Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private ?int $id; | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="json") | ||||
|   | ||||
| @@ -122,7 +122,7 @@ class ActivityType | ||||
|      * @ORM\GeneratedValue(strategy="AUTO") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private ?int $id; | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="string", nullable=false, options={"default": ""}) | ||||
|   | ||||
| @@ -86,9 +86,7 @@ class AvgActivityDuration implements ExportInterface, GroupedExportInterface | ||||
|  | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []) | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         $qb = $this->repository->createQueryBuilder('activity'); | ||||
|  | ||||
|   | ||||
| @@ -87,9 +87,7 @@ class AvgActivityVisitDuration implements ExportInterface, GroupedExportInterfac | ||||
|  | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []) | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         $qb = $this->repository->createQueryBuilder('activity'); | ||||
|  | ||||
|   | ||||
| @@ -86,9 +86,7 @@ class CountActivity implements ExportInterface, GroupedExportInterface | ||||
|  | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []) | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         $qb = $this->repository | ||||
|             ->createQueryBuilder('activity') | ||||
|   | ||||
| @@ -109,9 +109,7 @@ class ListActivity implements ListInterface, GroupedExportInterface | ||||
|  | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []) | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         $qb = $this->entityManager->createQueryBuilder(); | ||||
|  | ||||
|   | ||||
| @@ -87,9 +87,7 @@ class SumActivityDuration implements ExportInterface, GroupedExportInterface | ||||
|  | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []) | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         $qb = $this->repository | ||||
|             ->createQueryBuilder('activity') | ||||
|   | ||||
| @@ -87,9 +87,7 @@ class SumActivityVisitDuration implements ExportInterface, GroupedExportInterfac | ||||
|  | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []) | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         $qb = $this->repository | ||||
|             ->createQueryBuilder('activity') | ||||
|   | ||||
| @@ -137,13 +137,11 @@ class ListActivity implements ListInterface, GroupedExportInterface | ||||
|  | ||||
|                     $activity = $activityRepository->find($value); | ||||
|  | ||||
|                     return implode(', ', array_map(function (ActivityReason $r) { | ||||
|                         return '"' . | ||||
|                                 $this->translatableStringHelper->localize($r->getCategory()->getName()) | ||||
|                                 . ' > ' . | ||||
|                                 $this->translatableStringHelper->localize($r->getName()) | ||||
|                                 . '"'; | ||||
|                     }, $activity->getReasons()->toArray())); | ||||
|                     return implode(', ', array_map(fn (ActivityReason $r) => '"' . | ||||
|                             $this->translatableStringHelper->localize($r->getCategory()->getName()) | ||||
|                             . ' > ' . | ||||
|                             $this->translatableStringHelper->localize($r->getName()) | ||||
|                             . '"', $activity->getReasons()->toArray())); | ||||
|                 }; | ||||
|  | ||||
|             case 'circle_name': | ||||
| @@ -197,9 +195,7 @@ class ListActivity implements ListInterface, GroupedExportInterface | ||||
|  | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []) | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         // throw an error if any fields are present | ||||
|         if (!array_key_exists('fields', $data)) { | ||||
|   | ||||
| @@ -61,12 +61,9 @@ class ActivityTypeFilter implements FilterInterface | ||||
|         $builder->add('accepted_activitytypes', EntityType::class, [ | ||||
|             'class' => ActivityType::class, | ||||
|             'choices' => $this->activityTypeRepository->findAllActive(), | ||||
|             'choice_label' => function (ActivityType $aty) { | ||||
|                 return | ||||
|                     ($aty->hasCategory() ? $this->translatableStringHelper->localize($aty->getCategory()->getName()) . ' > ' : '') | ||||
|                     . | ||||
|                     $this->translatableStringHelper->localize($aty->getName()); | ||||
|             }, | ||||
|             'choice_label' => fn (ActivityType $aty) => ($aty->hasCategory() ? $this->translatableStringHelper->localize($aty->getCategory()->getName()) . ' > ' : '') | ||||
|             . | ||||
|             $this->translatableStringHelper->localize($aty->getName()), | ||||
|             'multiple' => true, | ||||
|             'expanded' => true, | ||||
|         ]); | ||||
|   | ||||
| @@ -64,11 +64,9 @@ class UserScopeFilter implements FilterInterface | ||||
|     { | ||||
|         $builder->add('accepted_userscope', EntityType::class, [ | ||||
|             'class' => Scope::class, | ||||
|             'choice_label' => function (Scope $s) { | ||||
|                 return $this->translatableStringHelper->localize( | ||||
|                     $s->getName() | ||||
|                 ); | ||||
|             }, | ||||
|             'choice_label' => fn (Scope $s) => $this->translatableStringHelper->localize( | ||||
|                 $s->getName() | ||||
|             ), | ||||
|             'multiple' => true, | ||||
|             'expanded' => true, | ||||
|         ]); | ||||
|   | ||||
| @@ -61,12 +61,9 @@ class ActivityTypeFilter implements ExportElementValidatedInterface, FilterInter | ||||
|         $builder->add('types', EntityType::class, [ | ||||
|             'choices' => $this->activityTypeRepository->findAllActive(), | ||||
|             'class' => ActivityType::class, | ||||
|             'choice_label' => function (ActivityType $aty) { | ||||
|                 return | ||||
|                     ($aty->hasCategory() ? $this->translatableStringHelper->localize($aty->getCategory()->getName()) . ' > ' : '') | ||||
|                     . | ||||
|                     $this->translatableStringHelper->localize($aty->getName()); | ||||
|             }, | ||||
|             'choice_label' => fn (ActivityType $aty) => ($aty->hasCategory() ? $this->translatableStringHelper->localize($aty->getCategory()->getName()) . ' > ' : '') | ||||
|             . | ||||
|             $this->translatableStringHelper->localize($aty->getName()), | ||||
|             'group_by' => function (ActivityType $type) { | ||||
|                 if (!$type->hasCategory()) { | ||||
|                     return null; | ||||
|   | ||||
| @@ -211,13 +211,9 @@ class ActivityType extends AbstractType | ||||
|                 'required' => $activityType->isRequired('attendee'), | ||||
|                 'expanded' => true, | ||||
|                 'class' => ActivityPresence::class, | ||||
|                 'choice_label' => function (ActivityPresence $activityPresence) { | ||||
|                     return $this->translatableStringHelper->localize($activityPresence->getName()); | ||||
|                 }, | ||||
|                 'query_builder' => static function (EntityRepository $er) { | ||||
|                     return $er->createQueryBuilder('a') | ||||
|                         ->where('a.active = true'); | ||||
|                 }, | ||||
|                 'choice_label' => fn (ActivityPresence $activityPresence) => $this->translatableStringHelper->localize($activityPresence->getName()), | ||||
|                 'query_builder' => static fn (EntityRepository $er) => $er->createQueryBuilder('a') | ||||
|                     ->where('a.active = true'), | ||||
|             ]); | ||||
|         } | ||||
|  | ||||
| @@ -357,9 +353,7 @@ class ActivityType extends AbstractType | ||||
|  | ||||
|                         return (string) $location->getId(); | ||||
|                     }, | ||||
|                     function (?string $id): ?Location { | ||||
|                         return $this->om->getRepository(Location::class)->findOneBy(['id' => (int) $id]); | ||||
|                     } | ||||
|                     fn (?string $id): ?Location => $this->om->getRepository(Location::class)->findOneBy(['id' => (int) $id]) | ||||
|                 )); | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -45,9 +45,7 @@ class ActivityTypeType extends AbstractType | ||||
|             ]) | ||||
|             ->add('category', EntityType::class, [ | ||||
|                 'class' => ActivityTypeCategory::class, | ||||
|                 'choice_label' => function (ActivityTypeCategory $activityTypeCategory) { | ||||
|                     return $this->translatableStringHelper->localize($activityTypeCategory->getName()); | ||||
|                 }, | ||||
|                 'choice_label' => fn (ActivityTypeCategory $activityTypeCategory) => $this->translatableStringHelper->localize($activityTypeCategory->getName()), | ||||
|             ]) | ||||
|             ->add('ordering', NumberType::class, [ | ||||
|                 'required' => true, | ||||
|   | ||||
| @@ -45,9 +45,7 @@ class PickActivityReasonType extends AbstractType | ||||
|         $resolver->setDefaults( | ||||
|             [ | ||||
|                 'class' => ActivityReason::class, | ||||
|                 'choice_label' => function (ActivityReason $choice) { | ||||
|                     return $this->reasonRender->renderString($choice, []); | ||||
|                 }, | ||||
|                 'choice_label' => fn (ActivityReason $choice) => $this->reasonRender->renderString($choice, []), | ||||
|                 'group_by' => function (ActivityReason $choice): ?string { | ||||
|                     if (null !== $category = $choice->getCategory()) { | ||||
|                         return $this->translatableStringHelper->localize($category->getName()); | ||||
|   | ||||
| @@ -38,10 +38,8 @@ class TranslatableActivityReasonCategoryType extends AbstractType | ||||
|         $resolver->setDefaults( | ||||
|             [ | ||||
|                 'class' => ActivityReasonCategory::class, | ||||
|                 'choice_label' => function (ActivityReasonCategory $category) { | ||||
|                     return $this->translatableStringHelper->localize($category->getName()) | ||||
|                         . (!$category->getActive() ? ' (' . $this->translator->trans('inactive') . ')' : ''); | ||||
|                 }, | ||||
|                 'choice_label' => fn (ActivityReasonCategory $category) => $this->translatableStringHelper->localize($category->getName()) | ||||
|                     . (!$category->getActive() ? ' (' . $this->translator->trans('inactive') . ')' : ''), | ||||
|             ] | ||||
|         ); | ||||
|     } | ||||
|   | ||||
| @@ -39,9 +39,7 @@ class TranslatableActivityType extends AbstractType | ||||
|                 'class' => ActivityType::class, | ||||
|                 'active_only' => true, | ||||
|                 'choices' => $this->activityTypeRepository->findAllActive(), | ||||
|                 'choice_label' => function (ActivityType $type) { | ||||
|                     return $this->translatableStringHelper->localize($type->getName()); | ||||
|                 }, | ||||
|                 'choice_label' => fn (ActivityType $type) => $this->translatableStringHelper->localize($type->getName()), | ||||
|             ] | ||||
|         ); | ||||
|     } | ||||
|   | ||||
| @@ -254,9 +254,7 @@ final class ActivityACLAwareRepository implements ActivityACLAwareRepositoryInte | ||||
|             $reachableScopes = $this->authorizationHelper->getReachableScopes($this->tokenStorage->getToken()->getUser(), ActivityVoter::SEE, $center); | ||||
|             // we get the ids for those scopes | ||||
|             $reachablesScopesId = array_map( | ||||
|                 static function (Scope $scope) { | ||||
|                     return $scope->getId(); | ||||
|                 }, | ||||
|                 static fn (Scope $scope) => $scope->getId(), | ||||
|                 $reachableScopes | ||||
|             ); | ||||
|  | ||||
|   | ||||
| @@ -134,9 +134,7 @@ class ActivityContext implements | ||||
|                 $builder->add($key, EntityType::class, [ | ||||
|                     'class' => Person::class, | ||||
|                     'choices' => $persons, | ||||
|                     'choice_label' => function (Person $p) { | ||||
|                         return $this->personRender->renderString($p, []); | ||||
|                     }, | ||||
|                     'choice_label' => fn (Person $p) => $this->personRender->renderString($p, []), | ||||
|                     'multiple' => false, | ||||
|                     'required' => false, | ||||
|                     'expanded' => true, | ||||
|   | ||||
| @@ -145,9 +145,7 @@ class ListActivitiesByAccompanyingPeriodContext implements | ||||
|         return array_filter( | ||||
|             $activities, | ||||
|             function ($activity) use ($user) { | ||||
|                 $activityUsernames = array_map(static function ($user) { | ||||
|                     return $user['username']; | ||||
|                 }, $activity['users'] ?? []); | ||||
|                 $activityUsernames = array_map(static fn ($user) => $user['username'], $activity['users'] ?? []); | ||||
|                 return in_array($user->getUsername(), $activityUsernames, true); | ||||
|             } | ||||
|         ); | ||||
| @@ -158,9 +156,7 @@ class ListActivitiesByAccompanyingPeriodContext implements | ||||
|         return array_filter( | ||||
|             $works, | ||||
|             function ($work) use ($user) { | ||||
|                 $workUsernames = array_map(static function ($user) { | ||||
|                     return $user['username']; | ||||
|                 }, $work['referrers'] ?? []); | ||||
|                 $workUsernames = array_map(static fn ($user) => $user['username'], $work['referrers'] ?? []); | ||||
|  | ||||
|                 return in_array($user->getUsername(), $workUsernames, true); | ||||
|             } | ||||
|   | ||||
| @@ -369,12 +369,8 @@ final class ActivityControllerTest extends WebTestCase | ||||
|                 $center | ||||
|             ); | ||||
|         $reachableScopesId = array_intersect( | ||||
|             array_map(static function ($s) { | ||||
|                 return $s->getId(); | ||||
|             }, $reachableScopesDelete), | ||||
|             array_map(static function ($s) { | ||||
|                 return $s->getId(); | ||||
|             }, $reachableScopesUpdate) | ||||
|             array_map(static fn ($s) => $s->getId(), $reachableScopesDelete), | ||||
|             array_map(static fn ($s) => $s->getId(), $reachableScopesUpdate) | ||||
|         ); | ||||
|  | ||||
|         if (count($reachableScopesId) === 0) { | ||||
|   | ||||
| @@ -188,9 +188,7 @@ final class ActivityTypeTest extends KernelTestCase | ||||
|  | ||||
|         // map all the values in an array | ||||
|         $values = array_map( | ||||
|             static function ($choice) { | ||||
|                 return $choice->value; | ||||
|             }, | ||||
|             static fn ($choice) => $choice->value, | ||||
|             $view['activity']['durationTime']->vars['choices'] | ||||
|         ); | ||||
|  | ||||
|   | ||||
| @@ -83,9 +83,7 @@ final class TranslatableActivityReasonTest extends TypeTestCase | ||||
|         $request->getLocale()->willReturn($fallbackLocale); | ||||
|  | ||||
|         $requestStack->willExtend(\Symfony\Component\HttpFoundation\RequestStack::class); | ||||
|         $requestStack->getCurrentRequest()->will(static function () use ($request) { | ||||
|             return $request; | ||||
|         }); | ||||
|         $requestStack->getCurrentRequest()->will(static fn () => $request); | ||||
|  | ||||
|         $translator->willExtend(\Symfony\Component\Translation\Translator::class); | ||||
|         $translator->getFallbackLocales()->willReturn($locale); | ||||
|   | ||||
| @@ -132,9 +132,7 @@ class Configuration implements ConfigurationInterface | ||||
|             ->info('The number of seconds of this duration. Must be an integer.') | ||||
|             ->cannotBeEmpty() | ||||
|             ->validate() | ||||
|             ->ifTrue(static function ($data) { | ||||
|                 return !is_int($data); | ||||
|             })->thenInvalid('The value %s is not a valid integer') | ||||
|             ->ifTrue(static fn ($data) => !is_int($data))->thenInvalid('The value %s is not a valid integer') | ||||
|             ->end() | ||||
|             ->end() | ||||
|             ->scalarNode('label') | ||||
|   | ||||
| @@ -57,7 +57,7 @@ class AsideActivity implements TrackCreationInterface, TrackUpdateInterface | ||||
|      * @ORM\GeneratedValue | ||||
|      * @ORM\Column(type="integer") | ||||
|      */ | ||||
|     private ?int $id; | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="string", length=100, nullable=true) | ||||
|   | ||||
| @@ -59,9 +59,7 @@ class CountAsideActivity implements ExportInterface, GroupedExportInterface | ||||
|         $labels = array_combine($values, $values); | ||||
|         $labels['_header'] = $this->getTitle(); | ||||
|  | ||||
|         return static function ($value) use ($labels) { | ||||
|             return $labels[$value]; | ||||
|         }; | ||||
|         return static fn ($value) => $labels[$value]; | ||||
|     } | ||||
|  | ||||
|     public function getQueryKeys($data): array | ||||
|   | ||||
| @@ -41,7 +41,7 @@ abstract class AbstractElement | ||||
|     /** | ||||
|      * @ORM\Column(name="comment", type="text", nullable=true) | ||||
|      */ | ||||
|     private ?string $comment; | ||||
|     private ?string $comment = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(name="endDate", type="datetime_immutable", nullable=true) | ||||
| @@ -50,7 +50,7 @@ abstract class AbstractElement | ||||
|      *     message="The budget element's end date must be after the start date" | ||||
|      * ) | ||||
|      */ | ||||
|     private ?DateTimeImmutable $endDate; | ||||
|     private ?DateTimeImmutable $endDate = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne( | ||||
|   | ||||
| @@ -52,9 +52,7 @@ class ChargeType extends AbstractType | ||||
|                 'label' => 'Charge type', | ||||
|                 'required' => true, | ||||
|                 'placeholder' => $this->translator->trans('admin.form.Choose the type of charge'), | ||||
|                 'choice_label' => function (ChargeKind $resource) { | ||||
|                     return $this->translatableStringHelper->localize($resource->getName()); | ||||
|                 }, | ||||
|                 'choice_label' => fn (ChargeKind $resource) => $this->translatableStringHelper->localize($resource->getName()), | ||||
|                 'attr' => ['class' => 'select2'], | ||||
|             ]) | ||||
|             ->add('amount', MoneyType::class) | ||||
|   | ||||
| @@ -51,9 +51,7 @@ class ResourceType extends AbstractType | ||||
|                 'label' => 'Resource type', | ||||
|                 'required' => true, | ||||
|                 'placeholder' => $this->translator->trans('admin.form.Choose the type of resource'), | ||||
|                 'choice_label' => function (ResourceKind $resource) { | ||||
|                     return $this->translatableStringHelper->localize($resource->getName()); | ||||
|                 }, | ||||
|                 'choice_label' => fn (ResourceKind $resource) => $this->translatableStringHelper->localize($resource->getName()), | ||||
|                 'attr' => ['class' => 'select2'], | ||||
|             ]) | ||||
|             ->add('amount', MoneyType::class) | ||||
|   | ||||
| @@ -66,9 +66,7 @@ final class SummaryBudget implements SummaryBudgetInterface | ||||
|             ]; | ||||
|         } | ||||
|  | ||||
|         $personIds = $household->getCurrentPersons()->map(static function (Person $p) { | ||||
|             return $p->getId(); | ||||
|         }); | ||||
|         $personIds = $household->getCurrentPersons()->map(static fn (Person $p) => $p->getId()); | ||||
|         $ids = implode(', ', array_fill(0, count($personIds), '?')); | ||||
|  | ||||
|         $parameters = [...$personIds, $household->getId()]; | ||||
| @@ -127,18 +125,14 @@ final class SummaryBudget implements SummaryBudgetInterface | ||||
|     { | ||||
|         $keys = array_map(static fn (ChargeKind $kind) => $kind->getKind(), $this->chargeKindRepository->findAll()); | ||||
|  | ||||
|         return array_combine($keys, array_map(function ($kind) { | ||||
|             return ['sum' => 0.0, 'label' => $this->translatableStringHelper->localize($this->chargeKindRepository->findOneByKind($kind)->getName()), 'comment' => '']; | ||||
|         }, $keys)); | ||||
|         return array_combine($keys, array_map(fn ($kind) => ['sum' => 0.0, 'label' => $this->translatableStringHelper->localize($this->chargeKindRepository->findOneByKind($kind)->getName()), 'comment' => ''], $keys)); | ||||
|     } | ||||
|  | ||||
|     private function getEmptyResourceArray(): array | ||||
|     { | ||||
|         $keys = array_map(static fn (ResourceKind $kind) => $kind->getKind(), $this->resourceKindRepository->findAll()); | ||||
|  | ||||
|         return array_combine($keys, array_map(function ($kind) { | ||||
|             return ['sum' => 0.0, 'label' => $this->translatableStringHelper->localize($this->resourceKindRepository->findOneByKind($kind)->getName()), 'comment' => '']; | ||||
|         }, $keys)); | ||||
|         return array_combine($keys, array_map(fn ($kind) => ['sum' => 0.0, 'label' => $this->translatableStringHelper->localize($this->resourceKindRepository->findOneByKind($kind)->getName()), 'comment' => ''], $keys)); | ||||
|     } | ||||
|  | ||||
|     private function rowToArray(array $rows, string $kind): array | ||||
|   | ||||
| @@ -50,9 +50,7 @@ final class SummaryBudgetTest extends TestCase | ||||
|             ], | ||||
|         ]); | ||||
|         $queryCharges->setParameters(Argument::type('array')) | ||||
|             ->will(static function ($args, $query) { | ||||
|                 return $query; | ||||
|             }); | ||||
|             ->will(static fn ($args, $query) => $query); | ||||
|  | ||||
|         $queryResources = $this->prophesize(AbstractQuery::class); | ||||
|         $queryResources->getResult()->willReturn([ | ||||
| @@ -63,9 +61,7 @@ final class SummaryBudgetTest extends TestCase | ||||
|             ], | ||||
|         ]); | ||||
|         $queryResources->setParameters(Argument::type('array')) | ||||
|             ->will(static function ($args, $query) { | ||||
|                 return $query; | ||||
|             }); | ||||
|             ->will(static fn ($args, $query) => $query); | ||||
|  | ||||
|         $em = $this->prophesize(EntityManagerInterface::class); | ||||
|         $em->createNativeQuery(Argument::type('string'), Argument::type(Query\ResultSetMapping::class)) | ||||
| @@ -100,9 +96,7 @@ final class SummaryBudgetTest extends TestCase | ||||
|         $resourceRepository->findOneByKind('misc')->willReturn($misc); | ||||
|  | ||||
|         $translatableStringHelper = $this->prophesize(TranslatableStringHelperInterface::class); | ||||
|         $translatableStringHelper->localize(Argument::type('array'))->will(static function ($arg) { | ||||
|             return $arg[0]['fr']; | ||||
|         }); | ||||
|         $translatableStringHelper->localize(Argument::type('array'))->will(static fn ($arg) => $arg[0]['fr']); | ||||
|  | ||||
|         $person = new Person(); | ||||
|         $personReflection = new ReflectionClass($person); | ||||
|   | ||||
| @@ -514,9 +514,7 @@ class Calendar implements TrackCreationInterface, TrackUpdateInterface, HasCente | ||||
|      */ | ||||
|     public function getUsers(): ReadableCollection | ||||
|     { | ||||
|         return $this->getInvites()->map(static function (Invite $i) { | ||||
|             return $i->getUser(); | ||||
|         }); | ||||
|         return $this->getInvites()->map(static fn (Invite $i) => $i->getUser()); | ||||
|     } | ||||
|  | ||||
|     public function hasCalendarRange(): bool | ||||
| @@ -601,9 +599,7 @@ class Calendar implements TrackCreationInterface, TrackUpdateInterface, HasCente | ||||
|         } | ||||
|  | ||||
|         $invite = $this->invites | ||||
|             ->filter(static function (Invite $invite) use ($user) { | ||||
|                 return $invite->getUser() === $user; | ||||
|             }) | ||||
|             ->filter(static fn (Invite $invite) => $invite->getUser() === $user) | ||||
|             ->first(); | ||||
|         $this->removeInvite($invite); | ||||
|  | ||||
|   | ||||
| @@ -63,7 +63,7 @@ class CalendarRange implements TrackCreationInterface, TrackUpdateInterface | ||||
|      * @Groups({"read", "write", "calendar:read"}) | ||||
|      * @Assert\NotNull | ||||
|      */ | ||||
|     private ?Location $location; | ||||
|     private ?Location $location = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="datetime_immutable", nullable=false) | ||||
|   | ||||
| @@ -61,9 +61,7 @@ class CountCalendars implements ExportInterface, GroupedExportInterface | ||||
|         $labels = array_combine($values, $values); | ||||
|         $labels['_header'] = $this->getTitle(); | ||||
|  | ||||
|         return static function ($value) use ($labels) { | ||||
|             return $labels[$value]; | ||||
|         }; | ||||
|         return static fn ($value) => $labels[$value]; | ||||
|     } | ||||
|  | ||||
|     public function getQueryKeys($data): array | ||||
| @@ -91,9 +89,7 @@ class CountCalendars implements ExportInterface, GroupedExportInterface | ||||
|      */ | ||||
|     public function initiateQuery(array $requiredModifiers, array $acl, array $data = []): QueryBuilder | ||||
|     { | ||||
|         $centers = array_map(static function ($el) { | ||||
|             return $el['center']; | ||||
|         }, $acl); | ||||
|         $centers = array_map(static fn ($el) => $el['center'], $acl); | ||||
|  | ||||
|         $qb = $this->calendarRepository->createQueryBuilder('cal'); | ||||
|  | ||||
|   | ||||
| @@ -61,9 +61,7 @@ class StatCalendarAvgDuration implements ExportInterface, GroupedExportInterface | ||||
|         $labels = array_combine($values, $values); | ||||
|         $labels['_header'] = $this->getTitle(); | ||||
|  | ||||
|         return static function ($value) use ($labels) { | ||||
|             return $labels[$value]; | ||||
|         }; | ||||
|         return static fn ($value) => $labels[$value]; | ||||
|     } | ||||
|  | ||||
|     public function getQueryKeys($data): array | ||||
|   | ||||
| @@ -61,9 +61,7 @@ class StatCalendarSumDuration implements ExportInterface, GroupedExportInterface | ||||
|         $labels = array_combine($values, $values); | ||||
|         $labels['_header'] = $this->getTitle(); | ||||
|  | ||||
|         return static function ($value) use ($labels) { | ||||
|             return $labels[$value]; | ||||
|         }; | ||||
|         return static fn ($value) => $labels[$value]; | ||||
|     } | ||||
|  | ||||
|     public function getQueryKeys($data): array | ||||
|   | ||||
| @@ -58,9 +58,7 @@ class AgentFilter implements FilterInterface | ||||
|     { | ||||
|         $builder->add('accepted_agents', EntityType::class, [ | ||||
|             'class' => User::class, | ||||
|             'choice_label' => function (User $u) { | ||||
|                 return $this->userRender->renderString($u, []); | ||||
|             }, | ||||
|             'choice_label' => fn (User $u) => $this->userRender->renderString($u, []), | ||||
|             'multiple' => true, | ||||
|             'expanded' => true, | ||||
|         ]); | ||||
|   | ||||
| @@ -69,11 +69,9 @@ class JobFilter implements FilterInterface | ||||
|     { | ||||
|         $builder->add('job', EntityType::class, [ | ||||
|             'class' => UserJob::class, | ||||
|             'choice_label' => function (UserJob $j) { | ||||
|                 return $this->translatableStringHelper->localize( | ||||
|                     $j->getLabel() | ||||
|                 ); | ||||
|             }, | ||||
|             'choice_label' => fn (UserJob $j) => $this->translatableStringHelper->localize( | ||||
|                 $j->getLabel() | ||||
|             ), | ||||
|             'multiple' => true, | ||||
|             'expanded' => true, | ||||
|         ]); | ||||
|   | ||||
| @@ -69,11 +69,9 @@ class ScopeFilter implements FilterInterface | ||||
|     { | ||||
|         $builder->add('scope', EntityType::class, [ | ||||
|             'class' => Scope::class, | ||||
|             'choice_label' => function (Scope $s) { | ||||
|                 return $this->translatableStringHelper->localize( | ||||
|                     $s->getName() | ||||
|                 ); | ||||
|             }, | ||||
|             'choice_label' => fn (Scope $s) => $this->translatableStringHelper->localize( | ||||
|                 $s->getName() | ||||
|             ), | ||||
|             'multiple' => true, | ||||
|             'expanded' => true, | ||||
|         ]); | ||||
|   | ||||
| @@ -89,14 +89,10 @@ class CalendarToRemoteHandler implements MessageHandlerInterface | ||||
|  | ||||
|         $newInvites = array_filter( | ||||
|             array_map( | ||||
|                 function ($id) { | ||||
|                     return $this->inviteRepository->find($id); | ||||
|                 }, | ||||
|                 fn ($id) => $this->inviteRepository->find($id), | ||||
|                 $calendarMessage->getNewInvitesIds(), | ||||
|             ), | ||||
|             static function (?Invite $invite) { | ||||
|                 return null !== $invite; | ||||
|             } | ||||
|             static fn (?Invite $invite) => null !== $invite | ||||
|         ); | ||||
|  | ||||
|         $this->calendarConnector->syncCalendar( | ||||
|   | ||||
| @@ -58,14 +58,12 @@ class CalendarMessage | ||||
|         $this->previousMainUserId = null !== $calendar->previousMainUser ? | ||||
|             $calendar->previousMainUser->getId() : null; | ||||
|         $this->newInvitesIds = array_map(static fn (Invite $i) => $i->getId(), $calendar->newInvites); | ||||
|         $this->oldInvites = array_map(static function (Invite $i) { | ||||
|             return [ | ||||
|                 'inviteId' => $i->getId(), | ||||
|                 'userId' => $i->getUser()->getId(), | ||||
|                 'userEmail' => $i->getUser()->getEmail(), | ||||
|                 'userLabel' => $i->getUser()->getLabel(), | ||||
|             ]; | ||||
|         }, $calendar->oldInvites); | ||||
|         $this->oldInvites = array_map(static fn (Invite $i) => [ | ||||
|             'inviteId' => $i->getId(), | ||||
|             'userId' => $i->getUser()->getId(), | ||||
|             'userEmail' => $i->getUser()->getEmail(), | ||||
|             'userLabel' => $i->getUser()->getLabel(), | ||||
|         ], $calendar->oldInvites); | ||||
|     } | ||||
|  | ||||
|     public function getAction(): string | ||||
|   | ||||
| @@ -121,9 +121,7 @@ class RemoteEventConverter | ||||
|                 'subject' => '[Chill] ' . | ||||
|                     implode( | ||||
|                         ', ', | ||||
|                         $calendar->getPersons()->map(function (Person $p) { | ||||
|                             return $this->personRender->renderString($p, []); | ||||
|                         })->toArray() | ||||
|                         $calendar->getPersons()->map(fn (Person $p) => $this->personRender->renderString($p, []))->toArray() | ||||
|                     ), | ||||
|                 'start' => [ | ||||
|                     'dateTime' => $calendar->getStartDate()->setTimezone($this->remoteDateTimeZone) | ||||
| @@ -161,9 +159,7 @@ class RemoteEventConverter | ||||
|     { | ||||
|         return [ | ||||
|             'attendees' => $calendar->getInvites()->map( | ||||
|                 function (Invite $i) { | ||||
|                     return $this->buildInviteToAttendee($i); | ||||
|                 } | ||||
|                 fn (Invite $i) => $this->buildInviteToAttendee($i) | ||||
|             )->toArray(), | ||||
|         ]; | ||||
|     } | ||||
|   | ||||
| @@ -190,23 +190,17 @@ class MSGraphRemoteCalendarConnector implements RemoteCalendarConnectorInterface | ||||
|                 ] | ||||
|             )->toArray(); | ||||
|  | ||||
|             $ids = array_map(static function ($item) { | ||||
|                 return $item['id']; | ||||
|             }, $bareEvents['value']); | ||||
|             $ids = array_map(static fn ($item) => $item['id'], $bareEvents['value']); | ||||
|             $existingIdsInRange = $this->calendarRangeRepository->findRemoteIdsPresent($ids); | ||||
|             $existingIdsInCalendar = $this->calendarRepository->findRemoteIdsPresent($ids); | ||||
|  | ||||
|             return array_values( | ||||
|                 array_map( | ||||
|                     function ($item) { | ||||
|                         return $this->remoteEventConverter->convertToRemote($item); | ||||
|                     }, | ||||
|                     fn ($item) => $this->remoteEventConverter->convertToRemote($item), | ||||
|                     // filter all event to keep only the one not in range | ||||
|                     array_filter( | ||||
|                         $bareEvents['value'], | ||||
|                         static function ($item) use ($existingIdsInRange, $existingIdsInCalendar) { | ||||
|                             return ((!$existingIdsInRange[$item['id']]) ?? true) && ((!$existingIdsInCalendar[$item['id']]) ?? true); | ||||
|                         } | ||||
|                         static fn ($item) => ((!$existingIdsInRange[$item['id']]) ?? true) && ((!$existingIdsInCalendar[$item['id']]) ?? true) | ||||
|                     ) | ||||
|                 ) | ||||
|             ); | ||||
| @@ -604,9 +598,7 @@ class MSGraphRemoteCalendarConnector implements RemoteCalendarConnectorInterface | ||||
|         } | ||||
|  | ||||
|         $this->cacheScheduleTimeForUser[$userId] = array_map( | ||||
|             function ($item) { | ||||
|                 return $this->remoteEventConverter->convertAvailabilityToRemoteEvent($item); | ||||
|             }, | ||||
|             fn ($item) => $this->remoteEventConverter->convertAvailabilityToRemoteEvent($item), | ||||
|             $response['value'][0]['scheduleItems'] | ||||
|         ); | ||||
|  | ||||
|   | ||||
| @@ -114,12 +114,8 @@ final class CalendarTypeTest extends TypeTestCase | ||||
|         $this->assertEquals(8, $calendar->getCalendarRange()->getId()); | ||||
|         $this->assertEquals(9, $calendar->getLocation()->getId()); | ||||
|         $this->assertEquals(true, $calendar->getSendSMS()); | ||||
|         $this->assertContains(2, $calendar->getUsers()->map(static function (User $u) { | ||||
|             return $u->getId(); | ||||
|         })); | ||||
|         $this->assertContains(3, $calendar->getUsers()->map(static function (User $u) { | ||||
|             return $u->getId(); | ||||
|         })); | ||||
|         $this->assertContains(2, $calendar->getUsers()->map(static fn (User $u) => $u->getId())); | ||||
|         $this->assertContains(3, $calendar->getUsers()->map(static fn (User $u) => $u->getId())); | ||||
|     } | ||||
|  | ||||
|     protected function getExtensions() | ||||
| @@ -148,25 +144,17 @@ final class CalendarTypeTest extends TypeTestCase | ||||
|     ) { | ||||
|         $transformer = $this->prophesize($classTransformer); | ||||
|         $transformer->transform(Argument::type('array')) | ||||
|             ->will(static function ($args) { | ||||
|                 return implode( | ||||
|                     ',', | ||||
|                     array_map(static function ($p) { | ||||
|                         return $p->getId(); | ||||
|                     }, $args[0]) | ||||
|                 ); | ||||
|             }); | ||||
|             ->will(static fn ($args) => implode( | ||||
|                 ',', | ||||
|                 array_map(static fn ($p) => $p->getId(), $args[0]) | ||||
|             )); | ||||
|         $transformer->transform(Argument::exact(null)) | ||||
|             ->willReturn([]); | ||||
|         $transformer->transform(Argument::type(Collection::class)) | ||||
|             ->will(static function ($args) { | ||||
|                 return implode( | ||||
|                     ',', | ||||
|                     array_map(static function ($p) { | ||||
|                         return $p->getId(); | ||||
|                     }, $args[0]->toArray()) | ||||
|                 ); | ||||
|             }); | ||||
|             ->will(static fn ($args) => implode( | ||||
|                 ',', | ||||
|                 array_map(static fn ($p) => $p->getId(), $args[0]->toArray()) | ||||
|             )); | ||||
|         $transformer->reverseTransform(Argument::type('string')) | ||||
|             ->will(static function ($args) use ($objClass) { | ||||
|                 if (null === $args[0]) { | ||||
| @@ -195,9 +183,7 @@ final class CalendarTypeTest extends TypeTestCase | ||||
|     ) { | ||||
|         $transformer = $this->prophesize($classTransformer); | ||||
|         $transformer->transform(Argument::type('object')) | ||||
|             ->will(static function ($args) { | ||||
|                 return (string) $args[0]->getId(); | ||||
|             }); | ||||
|             ->will(static fn ($args) => (string) $args[0]->getId()); | ||||
|         $transformer->transform(Argument::exact(null)) | ||||
|             ->willReturn(''); | ||||
|         $transformer->reverseTransform(Argument::type('string')) | ||||
|   | ||||
| @@ -63,9 +63,7 @@ final class AddressConverterTest extends TestCase | ||||
|     { | ||||
|         $engine = $this->prophesize(EngineInterface::class); | ||||
|         $translatableStringHelper = $this->prophesize(TranslatableStringHelperInterface::class); | ||||
|         $translatableStringHelper->localize(Argument::type('array'))->will(static function ($args): string { | ||||
|             return ($args[0] ?? ['fr' => 'not provided'])['fr'] ?? 'not provided'; | ||||
|         }); | ||||
|         $translatableStringHelper->localize(Argument::type('array'))->will(static fn ($args): string => ($args[0] ?? ['fr' => 'not provided'])['fr'] ?? 'not provided'); | ||||
|  | ||||
|         $addressRender = new AddressRender($engine->reveal(), $translatableStringHelper->reveal()); | ||||
|  | ||||
|   | ||||
| @@ -72,17 +72,13 @@ final class CalendarForShortMessageProviderTest extends TestCase | ||||
|             Argument::type(DateTimeImmutable::class), | ||||
|             Argument::type('int'), | ||||
|             Argument::exact(0) | ||||
|         )->will(static function ($args) { | ||||
|             return array_fill(0, $args[2], new Calendar()); | ||||
|         })->shouldBeCalledTimes(1); | ||||
|         )->will(static fn ($args) => array_fill(0, $args[2], new Calendar()))->shouldBeCalledTimes(1); | ||||
|         $calendarRepository->findByNotificationAvailable( | ||||
|             Argument::type(DateTimeImmutable::class), | ||||
|             Argument::type(DateTimeImmutable::class), | ||||
|             Argument::type('int'), | ||||
|             Argument::not(0) | ||||
|         )->will(static function ($args) { | ||||
|             return array_fill(0, $args[2] - 1, new Calendar()); | ||||
|         })->shouldBeCalledTimes(1); | ||||
|         )->will(static fn ($args) => array_fill(0, $args[2] - 1, new Calendar()))->shouldBeCalledTimes(1); | ||||
|  | ||||
|         $em = $this->prophesize(EntityManagerInterface::class); | ||||
|         $em->clear()->shouldBeCalled(); | ||||
| @@ -108,17 +104,13 @@ final class CalendarForShortMessageProviderTest extends TestCase | ||||
|             Argument::type(DateTimeImmutable::class), | ||||
|             Argument::type('int'), | ||||
|             Argument::exact(0) | ||||
|         )->will(static function ($args) { | ||||
|             return array_fill(0, 1, new Calendar()); | ||||
|         })->shouldBeCalledTimes(1); | ||||
|         )->will(static fn ($args) => array_fill(0, 1, new Calendar()))->shouldBeCalledTimes(1); | ||||
|         $calendarRepository->findByNotificationAvailable( | ||||
|             Argument::type(DateTimeImmutable::class), | ||||
|             Argument::type(DateTimeImmutable::class), | ||||
|             Argument::type('int'), | ||||
|             Argument::not(0) | ||||
|         )->will(static function ($args) { | ||||
|             return []; | ||||
|         })->shouldBeCalledTimes(1); | ||||
|         )->will(static fn ($args) => [])->shouldBeCalledTimes(1); | ||||
|  | ||||
|         $em = $this->prophesize(EntityManagerInterface::class); | ||||
|         $em->clear()->shouldBeCalled(); | ||||
|   | ||||
| @@ -58,9 +58,7 @@ class CustomFieldLongChoice extends AbstractCustomField | ||||
|         $translatableStringHelper = $this->translatableStringHelper; | ||||
|         $builder->add($customField->getSlug(), Select2ChoiceType::class, [ | ||||
|             'choices' => $entries, | ||||
|             'choice_label' => static function (Option $option) use ($translatableStringHelper) { | ||||
|                 return $translatableStringHelper->localize($option->getText()); | ||||
|             }, | ||||
|             'choice_label' => static fn (Option $option) => $translatableStringHelper->localize($option->getText()), | ||||
|             'choice_value' => static fn (Option $key): ?int => null === $key ? null : $key->getId(), | ||||
|             'multiple' => false, | ||||
|             'expanded' => false, | ||||
|   | ||||
| @@ -57,8 +57,6 @@ class OptionRepository extends EntityRepository | ||||
|             ->getQuery() | ||||
|             ->getScalarResult(); | ||||
|  | ||||
|         return array_map(static function ($r) { | ||||
|             return $r['key']; | ||||
|         }, $keys); | ||||
|         return array_map(static fn ($r) => $r['key'], $keys); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -70,9 +70,7 @@ class CustomFieldType extends AbstractType | ||||
|         if ('entity' === $options['group_widget']) { | ||||
|             $builder->add('customFieldsGroup', EntityType::class, [ | ||||
|                 'class' => 'ChillCustomFieldsBundle:CustomFieldsGroup', | ||||
|                 'choice_label' => function ($g) { | ||||
|                     return $this->translatableStringHelper->localize($g->getName()); | ||||
|                 }, | ||||
|                 'choice_label' => fn ($g) => $this->translatableStringHelper->localize($g->getName()), | ||||
|             ]); | ||||
|         } elseif ('hidden' === $options['group_widget']) { | ||||
|             $builder->add('customFieldsGroup', HiddenType::class); | ||||
|   | ||||
| @@ -38,9 +38,7 @@ class JsonCustomFieldToArrayTransformer implements DataTransformerInterface | ||||
|  | ||||
|         // @TODO: in the array_map callback, CustomField::getLabel() does not exist. What do we do here? | ||||
|         $customFieldsLablels = array_map( | ||||
|             static function ($e) { | ||||
|                 return $e->getLabel(); | ||||
|             }, | ||||
|             static fn ($e) => $e->getLabel(), | ||||
|             $customFields | ||||
|         ); | ||||
|  | ||||
|   | ||||
| @@ -61,12 +61,8 @@ class DocGeneratorTemplateType extends AbstractType | ||||
|             $sub = $builder | ||||
|                 ->create('options', null, ['compound' => true]) | ||||
|                 ->addModelTransformer(new CallbackTransformer( | ||||
|                     static function (array $data) use ($context) { | ||||
|                         return $context->adminFormTransform($data); | ||||
|                     }, | ||||
|                     static function (array $data) use ($context) { | ||||
|                         return $context->adminFormReverseTransform($data); | ||||
|                     } | ||||
|                     static fn (array $data) => $context->adminFormTransform($data), | ||||
|                     static fn (array $data) => $context->adminFormReverseTransform($data) | ||||
|                 )); | ||||
|             $context->buildAdminForm($sub); | ||||
|             $builder->add($sub); | ||||
|   | ||||
| @@ -17,6 +17,6 @@ class ObjectReadyException extends RuntimeException | ||||
| { | ||||
|     public function __construct() | ||||
|     { | ||||
|         parent::__construct('object is already ready', 6698856); | ||||
|         parent::__construct('object is already ready', 6_698_856); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -19,7 +19,7 @@ class RelatedEntityNotFoundException extends RuntimeException | ||||
|     { | ||||
|         parent::__construct( | ||||
|             sprintf('Related entity not found: %s, %s', $relatedEntityClass, $relatedEntityId), | ||||
|             99876652, | ||||
|             99_876_652, | ||||
|             $previous | ||||
|         ); | ||||
|     } | ||||
|   | ||||
| @@ -58,7 +58,7 @@ class StoredObject implements AsyncFileInterface, Document, TrackCreationInterfa | ||||
|      * @ORM\Column(type="integer") | ||||
|      * @Serializer\Groups({"read", "write"}) | ||||
|      */ | ||||
|     private ?int $id; | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     /** | ||||
|      * @var int[] | ||||
| @@ -94,7 +94,7 @@ class StoredObject implements AsyncFileInterface, Document, TrackCreationInterfa | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity=DocGeneratorTemplate::class) | ||||
|      */ | ||||
|     private ?DocGeneratorTemplate $template; | ||||
|     private ?DocGeneratorTemplate $template = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="text", options={"default": "ready"}) | ||||
|   | ||||
| @@ -72,14 +72,10 @@ class AccompanyingCourseDocumentType extends AbstractType | ||||
|             ->add('category', EntityType::class, [ | ||||
|                 'placeholder' => 'Choose a document category', | ||||
|                 'class' => DocumentCategory::class, | ||||
|                 'query_builder' => static function (EntityRepository $er) { | ||||
|                     return $er->createQueryBuilder('c') | ||||
|                         ->where('c.documentClass = :docClass') | ||||
|                         ->setParameter('docClass', AccompanyingCourseDocument::class); | ||||
|                 }, | ||||
|                 'choice_label' => function ($entity = null) { | ||||
|                     return $entity ? $this->translatableStringHelper->localize($entity->getName()) : ''; | ||||
|                 }, | ||||
|                 'query_builder' => static fn (EntityRepository $er) => $er->createQueryBuilder('c') | ||||
|                     ->where('c.documentClass = :docClass') | ||||
|                     ->setParameter('docClass', AccompanyingCourseDocument::class), | ||||
|                 'choice_label' => fn ($entity = null) => $entity ? $this->translatableStringHelper->localize($entity->getName()) : '', | ||||
|             ]); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -67,14 +67,10 @@ class PersonDocumentType extends AbstractType | ||||
|             ->add('category', EntityType::class, [ | ||||
|                 'placeholder' => 'Choose a document category', | ||||
|                 'class' => DocumentCategory::class, | ||||
|                 'query_builder' => static function (EntityRepository $er) { | ||||
|                     return $er->createQueryBuilder('c') | ||||
|                         ->where('c.documentClass = :docClass') | ||||
|                         ->setParameter('docClass', PersonDocument::class); | ||||
|                 }, | ||||
|                 'choice_label' => function ($entity = null) { | ||||
|                     return $entity ? $this->translatableStringHelper->localize($entity->getName()) : ''; | ||||
|                 }, | ||||
|                 'query_builder' => static fn (EntityRepository $er) => $er->createQueryBuilder('c') | ||||
|                     ->where('c.documentClass = :docClass') | ||||
|                     ->setParameter('docClass', PersonDocument::class), | ||||
|                 'choice_label' => fn ($entity = null) => $entity ? $this->translatableStringHelper->localize($entity->getName()) : '', | ||||
|             ]); | ||||
|  | ||||
|         if ($isScopeConcerned && $this->parameterBag->get('chill_main')['acl']['form_show_scopes']) { | ||||
|   | ||||
| @@ -51,9 +51,7 @@ class AccompanyingCourseDocumentWorkflowHandler implements EntityWorkflowHandler | ||||
|         $persons = []; | ||||
|  | ||||
|         if (null !== $course) { | ||||
|             $persons = $course->getCurrentParticipations()->map(static function (AccompanyingPeriodParticipation $participation) { | ||||
|                 return $participation->getPerson(); | ||||
|             })->toArray(); | ||||
|             $persons = $course->getCurrentParticipations()->map(static fn (AccompanyingPeriodParticipation $participation) => $participation->getPerson())->toArray(); | ||||
|         } | ||||
|  | ||||
|         return [ | ||||
|   | ||||
| @@ -113,9 +113,7 @@ class ParticipationController extends AbstractController | ||||
|                     [ | ||||
|                         'event_id' => current($participations)->getEvent()->getId(), | ||||
|                         'persons_ids' => implode(',', array_map( | ||||
|                             static function (Participation $p) { | ||||
|                                 return $p->getPerson()->getId(); | ||||
|                             }, | ||||
|                             static fn (Participation $p) => $p->getPerson()->getId(), | ||||
|                             $participations | ||||
|                         )), | ||||
|                     ] | ||||
| @@ -649,19 +647,14 @@ class ParticipationController extends AbstractController | ||||
|  | ||||
|             // create a collection of person's id participating to the event | ||||
|             /** @var \Doctrine\Common\Collections\ArrayCollection $peopleParticipating */ | ||||
|             $peopleParticipating = $peopleParticipating ?? | ||||
|                     $participation->getEvent()->getParticipations()->map( | ||||
|                         static function (Participation $p) { | ||||
|                             return $p->getPerson()->getId(); | ||||
|                         } | ||||
|                     ); | ||||
|             $peopleParticipating ??= $participation->getEvent()->getParticipations()->map( | ||||
|                 static fn (Participation $p) => $p->getPerson()->getId() | ||||
|             ); | ||||
|             // check that the user is not already in the event | ||||
|             if ($peopleParticipating->contains($participation->getPerson()->getId())) { | ||||
|                 $ignoredParticipations[] = $participation | ||||
|                     ->getEvent()->getParticipations()->filter( | ||||
|                         static function (Participation $p) use ($participation) { | ||||
|                             return $p->getPerson()->getId() === $participation->getPerson()->getId(); | ||||
|                         } | ||||
|                         static fn (Participation $p) => $p->getPerson()->getId() === $participation->getPerson()->getId() | ||||
|                     )->first(); | ||||
|             } else { | ||||
|                 $newParticipations[] = $participation; | ||||
|   | ||||
| @@ -176,9 +176,7 @@ class Event implements HasCenterInterface, HasScopeInterface | ||||
|     { | ||||
|         $iterator = $this->participations->getIterator(); | ||||
|  | ||||
|         $iterator->uasort(static function ($first, $second) { | ||||
|             return strnatcasecmp($first->getPerson()->getFirstName(), $second->getPerson()->getFirstName()); | ||||
|         }); | ||||
|         $iterator->uasort(static fn ($first, $second) => strnatcasecmp($first->getPerson()->getFirstName(), $second->getPerson()->getFirstName())); | ||||
|  | ||||
|         return $iterator; | ||||
|     } | ||||
|   | ||||
| @@ -62,9 +62,7 @@ class EventChoiceLoader implements ChoiceLoaderInterface | ||||
|     { | ||||
|         return new \Symfony\Component\Form\ChoiceList\ArrayChoiceList( | ||||
|             $this->lazyLoadedEvents, | ||||
|             static function (Event $p) use ($value) { | ||||
|                 return call_user_func($value, $p); | ||||
|             } | ||||
|             static fn (Event $p) => call_user_func($value, $p) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -38,9 +38,7 @@ class RoleType extends AbstractType | ||||
|             ->add('active') | ||||
|             ->add('type', EntityType::class, [ | ||||
|                 'class' => EventType::class, | ||||
|                 'choice_label' => function (EventType $e) { | ||||
|                     return $this->translatableStringHelper->localize($e->getName()); | ||||
|                 }, | ||||
|                 'choice_label' => fn (EventType $e) => $this->translatableStringHelper->localize($e->getName()), | ||||
|             ]); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -109,16 +109,12 @@ class PickEventType extends AbstractType | ||||
|         // add the default options | ||||
|         $resolver->setDefaults([ | ||||
|             'class' => Event::class, | ||||
|             'choice_label' => static function (Event $e) { | ||||
|                 return $e->getDate()->format('d/m/Y, H:i') . ' → ' . | ||||
|                         // $e->getType()->getName()['fr'] . ':  ' .    // display the type of event | ||||
|                         $e->getName(); | ||||
|             }, | ||||
|             'choice_label' => static fn (Event $e) => $e->getDate()->format('d/m/Y, H:i') . ' → ' . | ||||
|                     // $e->getType()->getName()['fr'] . ':  ' .    // display the type of event | ||||
|                     $e->getName(), | ||||
|             'placeholder' => 'Pick an event', | ||||
|             'attr' => ['class' => 'select2 '], | ||||
|             'choice_attr' => static function (Event $e) { | ||||
|                 return ['data-center' => $e->getCenter()->getId()]; | ||||
|             }, | ||||
|             'choice_attr' => static fn (Event $e) => ['data-center' => $e->getCenter()->getId()], | ||||
|             'choiceloader' => function (Options $options) { | ||||
|                 $centers = $this->filterCenters($options); | ||||
|  | ||||
| @@ -143,9 +139,7 @@ class PickEventType extends AbstractType | ||||
|         // option role | ||||
|         if (null === $options['role']) { | ||||
|             $centers = array_map( | ||||
|                 static function (GroupCenter $g) { | ||||
|                     return $g->getCenter(); | ||||
|                 }, | ||||
|                 static fn (GroupCenter $g) => $g->getCenter(), | ||||
|                 $this->user->getGroupCenters()->toArray() | ||||
|             ); | ||||
|         } else { | ||||
| @@ -173,9 +167,7 @@ class PickEventType extends AbstractType | ||||
|  | ||||
|                 if ( | ||||
|                     !in_array($c->getId(), array_map( | ||||
|                         static function (Center $c) { | ||||
|                             return $c->getId(); | ||||
|                         }, | ||||
|                         static fn (Center $c) => $c->getId(), | ||||
|                         $centers | ||||
|                     ), true) | ||||
|                 ) { | ||||
|   | ||||
| @@ -39,16 +39,10 @@ class PickEventTypeType extends AbstractType | ||||
|         $resolver->setDefaults( | ||||
|             [ | ||||
|                 'class' => EventType::class, | ||||
|                 'query_builder' => static function (EntityRepository $er) { | ||||
|                     return $er->createQueryBuilder('et') | ||||
|                         ->where('et.active = true'); | ||||
|                 }, | ||||
|                 'choice_label' => static function (EventType $t) use ($helper) { | ||||
|                     return $helper->localize($t->getName()); | ||||
|                 }, | ||||
|                 'choice_attrs' => static function (EventType $t) { | ||||
|                     return ['data-link-category' => $t->getId()]; | ||||
|                 }, | ||||
|                 'query_builder' => static fn (EntityRepository $er) => $er->createQueryBuilder('et') | ||||
|                     ->where('et.active = true'), | ||||
|                 'choice_label' => static fn (EventType $t) => $helper->localize($t->getName()), | ||||
|                 'choice_attrs' => static fn (EventType $t) => ['data-link-category' => $t->getId()], | ||||
|             ] | ||||
|         ); | ||||
|     } | ||||
|   | ||||
| @@ -80,9 +80,7 @@ class PickRoleType extends AbstractType | ||||
|                         $options = $config->getOptions(); | ||||
|  | ||||
|                         $form->getParent()->add($name, $type, array_replace($options, [ | ||||
|                             'group_by' => function (Role $r) { | ||||
|                                 return $this->translatableStringHelper->localize($r->getType()->getName()); | ||||
|                             }, | ||||
|                             'group_by' => fn (Role $r) => $this->translatableStringHelper->localize($r->getType()->getName()), | ||||
|                         ])); | ||||
|                     } | ||||
|                 } | ||||
| @@ -111,17 +109,13 @@ class PickRoleType extends AbstractType | ||||
|             'class' => Role::class, | ||||
|             'query_builder' => $qb, | ||||
|             'group_by' => null, | ||||
|             'choice_attr' => static function (Role $r) { | ||||
|                 return [ | ||||
|                     'data-event-type' => $r->getType()->getId(), | ||||
|                     'data-link-category' => $r->getType()->getId(), | ||||
|                 ]; | ||||
|             }, | ||||
|             'choice_label' => static function (Role $r) use ($translatableStringHelper, $translator) { | ||||
|                 return $translatableStringHelper->localize($r->getName()) . | ||||
|                           ($r->getActive() === true ? '' : | ||||
|                                 ' (' . $translator->trans('unactive') . ')'); | ||||
|             }, | ||||
|             'choice_attr' => static fn (Role $r) => [ | ||||
|                 'data-event-type' => $r->getType()->getId(), | ||||
|                 'data-link-category' => $r->getType()->getId(), | ||||
|             ], | ||||
|             'choice_label' => static fn (Role $r) => $translatableStringHelper->localize($r->getName()) . | ||||
|                       ($r->getActive() === true ? '' : | ||||
|                             ' (' . $translator->trans('unactive') . ')'), | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -82,9 +82,7 @@ class PickStatusType extends AbstractType | ||||
|                     $type = $config->getType()->getName(); | ||||
|                     $options = $config->getOptions(); | ||||
|                     $form->getParent()->add($name, $type, array_replace($options, [ | ||||
|                         'group_by' => function (Status $s) { | ||||
|                             return $this->translatableStringHelper->localize($s->getType()->getName()); | ||||
|                         }, | ||||
|                         'group_by' => fn (Status $s) => $this->translatableStringHelper->localize($s->getType()->getName()), | ||||
|                     ])); | ||||
|                 } | ||||
|             ); | ||||
| @@ -112,17 +110,13 @@ class PickStatusType extends AbstractType | ||||
|             'class' => Status::class, | ||||
|             'query_builder' => $qb, | ||||
|             'group_by' => null, | ||||
|             'choice_attr' => static function (Status $s) { | ||||
|                 return [ | ||||
|                     'data-event-type' => $s->getType()->getId(), | ||||
|                     'data-link-category' => $s->getType()->getId(), | ||||
|                 ]; | ||||
|             }, | ||||
|             'choice_label' => static function (Status $s) use ($translatableStringHelper, $translator) { | ||||
|                 return $translatableStringHelper->localize($s->getName()) . | ||||
|                           ($s->getActive() === true ? '' : | ||||
|                                 ' (' . $translator->trans('unactive') . ')'); | ||||
|             }, | ||||
|             'choice_attr' => static fn (Status $s) => [ | ||||
|                 'data-event-type' => $s->getType()->getId(), | ||||
|                 'data-link-category' => $s->getType()->getId(), | ||||
|             ], | ||||
|             'choice_label' => static fn (Status $s) => $translatableStringHelper->localize($s->getName()) . | ||||
|                       ($s->getActive() === true ? '' : | ||||
|                             ' (' . $translator->trans('unactive') . ')'), | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -239,9 +239,7 @@ final class ParticipationControllerTest extends WebTestCase | ||||
|         $this->personsIdsCache = array_merge( | ||||
|             $this->personsIdsCache, | ||||
|             $event->getParticipations()->map( | ||||
|                 static function ($p) { | ||||
|                     return $p->getPerson()->getId(); | ||||
|                 } | ||||
|                 static fn ($p) => $p->getPerson()->getId() | ||||
|             ) | ||||
|                 ->toArray() | ||||
|         ); | ||||
| @@ -305,9 +303,7 @@ final class ParticipationControllerTest extends WebTestCase | ||||
|         $event = $this->getRandomEventWithMultipleParticipations(); | ||||
|  | ||||
|         $persons_id = implode(',', $event->getParticipations()->map( | ||||
|             static function ($p) { | ||||
|                 return $p->getPerson()->getId(); | ||||
|             } | ||||
|             static fn ($p) => $p->getPerson()->getId() | ||||
|         )->toArray()); | ||||
|  | ||||
|         $crawler = $this->client->request( | ||||
| @@ -333,9 +329,7 @@ final class ParticipationControllerTest extends WebTestCase | ||||
|         $nbParticipations = $event->getParticipations()->count(); | ||||
|         // get the persons_id participating on this event | ||||
|         $persons_id = $event->getParticipations()->map( | ||||
|             static function ($p) { | ||||
|                 return $p->getPerson()->getId(); | ||||
|             } | ||||
|             static fn ($p) => $p->getPerson()->getId() | ||||
|         )->toArray(); | ||||
|         // exclude the existing persons_ids from the new person | ||||
|         $this->personsIdsCache = array_merge($this->personsIdsCache, $persons_id); | ||||
| @@ -464,9 +458,7 @@ final class ParticipationControllerTest extends WebTestCase | ||||
|  | ||||
|         $circles = $this->em->getRepository(\Chill\MainBundle\Entity\Scope::class) | ||||
|             ->findAll(); | ||||
|         array_filter($circles, static function ($circle) use ($circleName) { | ||||
|             return in_array($circleName, $circle->getName(), true); | ||||
|         }); | ||||
|         array_filter($circles, static fn ($circle) => in_array($circleName, $circle->getName(), true)); | ||||
|         $circle = $circles[0]; | ||||
|  | ||||
|         $events = $this->em->getRepository(\Chill\EventBundle\Entity\Event::class) | ||||
|   | ||||
| @@ -208,9 +208,7 @@ class TimelineEventProvider implements TimelineProviderInterface | ||||
|  | ||||
|         foreach ($reachableCenters as $center) { | ||||
|             $reachableCircleId = array_map( | ||||
|                 static function (Scope $scope) { | ||||
|                     return $scope->getId(); | ||||
|                 }, | ||||
|                 static fn (Scope $scope) => $scope->getId(), | ||||
|                 $this->helper->getReachableCircles($this->user, $role, $person->getCenter()) | ||||
|             ); | ||||
|             $centerAndScopeLines[] = sprintf( | ||||
|   | ||||
| @@ -230,7 +230,7 @@ class CRUDController extends AbstractController | ||||
|      */ | ||||
|     protected function createFormFor(string $action, $entity, ?string $formClass = null, array $formOptions = []): FormInterface | ||||
|     { | ||||
|         $formClass = $formClass ?? $this->getFormClassFor($action); | ||||
|         $formClass ??= $this->getFormClassFor($action); | ||||
|  | ||||
|         $form = $this->createForm($formClass, $entity, $formOptions); | ||||
|  | ||||
|   | ||||
| @@ -141,9 +141,7 @@ class CRUDRoutesLoader extends Loader | ||||
|  | ||||
|             $methods = array_keys(array_filter( | ||||
|                 $action['methods'], | ||||
|                 static function ($value, $key) { | ||||
|                     return $value; | ||||
|                 }, | ||||
|                 static fn ($value, $key) => $value, | ||||
|                 ARRAY_FILTER_USE_BOTH | ||||
|             )); | ||||
|  | ||||
|   | ||||
| @@ -282,9 +282,7 @@ class NotificationController extends AbstractController | ||||
|  | ||||
|         if ($request->query->has('edit')) { | ||||
|             $commentId = $request->query->getInt('edit'); | ||||
|             $editedComment = $notification->getComments()->filter(static function (NotificationComment $c) use ($commentId) { | ||||
|                 return $c->getId() === $commentId; | ||||
|             })->first(); | ||||
|             $editedComment = $notification->getComments()->filter(static fn (NotificationComment $c) => $c->getId() === $commentId)->first(); | ||||
|  | ||||
|             if (false === $editedComment) { | ||||
|                 throw $this->createNotFoundException("Comment with id {$commentId} does not exists nor belong to this notification"); | ||||
|   | ||||
| @@ -158,9 +158,7 @@ class PermissionsGroupController extends AbstractController | ||||
|             'edit_form' => $editForm->createView(), | ||||
|             'role_scopes_sorted' => $roleScopesSorted, | ||||
|             'expanded_roles' => $this->getExpandedRoles($permissionsGroup->getRoleScopes()->toArray()), | ||||
|             'delete_role_scopes_form' => array_map(static function ($form) { | ||||
|                 return $form->createView(); | ||||
|             }, $deleteRoleScopesForm), | ||||
|             'delete_role_scopes_form' => array_map(static fn ($form) => $form->createView(), $deleteRoleScopesForm), | ||||
|             'add_role_scopes_form' => $addRoleScopesForm->createView(), | ||||
|         ]); | ||||
|     } | ||||
| @@ -305,9 +303,7 @@ class PermissionsGroupController extends AbstractController | ||||
|             'role_scopes_sorted' => $roleScopesSorted, | ||||
|             'edit_form' => $editForm->createView(), | ||||
|             'expanded_roles' => $this->getExpandedRoles($permissionsGroup->getRoleScopes()->toArray()), | ||||
|             'delete_role_scopes_form' => array_map(static function ($form) { | ||||
|                 return $form->createView(); | ||||
|             }, $deleteRoleScopesForm), | ||||
|             'delete_role_scopes_form' => array_map(static fn ($form) => $form->createView(), $deleteRoleScopesForm), | ||||
|             'add_role_scopes_form' => $addRoleScopesForm->createView(), | ||||
|         ]); | ||||
|     } | ||||
| @@ -449,9 +445,7 @@ class PermissionsGroupController extends AbstractController | ||||
|             'role_scopes_sorted' => $roleScopesSorted, | ||||
|             'edit_form' => $editForm->createView(), | ||||
|             'expanded_roles' => $this->getExpandedRoles($permissionsGroup->getRoleScopes()->toArray()), | ||||
|             'delete_role_scopes_form' => array_map(static function ($form) { | ||||
|                 return $form->createView(); | ||||
|             }, $deleteRoleScopesForm), | ||||
|             'delete_role_scopes_form' => array_map(static fn ($form) => $form->createView(), $deleteRoleScopesForm), | ||||
|             'add_role_scopes_form' => $addRoleScopesForm->createView(), | ||||
|         ]); | ||||
|     } | ||||
| @@ -573,9 +567,7 @@ class PermissionsGroupController extends AbstractController | ||||
|             if (!array_key_exists($roleScope->getRole(), $expandedRoles)) { | ||||
|                 $expandedRoles[$roleScope->getRole()] = | ||||
|                       array_map( | ||||
|                           static function (Role $role) { | ||||
|                               return $role->getRole(); | ||||
|                           }, | ||||
|                           static fn (Role $role) => $role->getRole(), | ||||
|                           $this->roleHierarchy | ||||
|                               ->getReachableRoles( | ||||
|                                   [new Role($roleScope->getRole())] | ||||
|   | ||||
| @@ -337,14 +337,13 @@ class UserController extends CRUDController | ||||
|                 [ | ||||
|                     'add_groupcenter_form' => $this->createAddLinkGroupCenterForm($entity, $request)->createView(), | ||||
|                     'delete_groupcenter_form' => array_map( | ||||
|                         static function (Form $form) { | ||||
|                             return $form->createView(); | ||||
|                         }, | ||||
|                         static fn (Form $form) => $form->createView(), | ||||
|                         iterator_to_array($this->getDeleteLinkGroupCenterByUser($entity, $request), true) | ||||
|                     ), | ||||
|                 ] | ||||
|             ); | ||||
|         } elseif ('index' === $action) { | ||||
|         } | ||||
|         if ('index' === $action) { | ||||
|             return array_merge( | ||||
|                 ['allow_change_password' => $this->parameterBag->get('chill_main.access_user_change_password')], | ||||
|                 $defaultTemplateParameters | ||||
|   | ||||
| @@ -345,12 +345,10 @@ class WorkflowController extends AbstractController | ||||
|             if ($transitionForm->isSubmitted() && $transitionForm->isValid()) { | ||||
|                 if (!$workflow->can($entityWorkflow, $transition = $transitionForm['transition']->getData()->getName())) { | ||||
|                     $blockers = $workflow->buildTransitionBlockerList($entityWorkflow, $transition); | ||||
|                     $msgs = array_map(function (TransitionBlocker $tb) { | ||||
|                         return $this->translator->trans( | ||||
|                             $tb->getMessage(), | ||||
|                             $tb->getParameters() | ||||
|                         ); | ||||
|                     }, iterator_to_array($blockers)); | ||||
|                     $msgs = array_map(fn (TransitionBlocker $tb) => $this->translator->trans( | ||||
|                         $tb->getMessage(), | ||||
|                         $tb->getParameters() | ||||
|                     ), iterator_to_array($blockers)); | ||||
|  | ||||
|                     throw $this->createAccessDeniedException( | ||||
|                         sprintf( | ||||
|   | ||||
| @@ -37,9 +37,7 @@ class MenuCompilerPass implements CompilerPassInterface | ||||
|             ]; | ||||
|         } | ||||
|  | ||||
|         usort($services, static function ($a, $b) { | ||||
|             return $a['priority'] <=> $b['priority']; | ||||
|         }); | ||||
|         usort($services, static fn ($a, $b) => $a['priority'] <=> $b['priority']); | ||||
|  | ||||
|         foreach ($services as $service) { | ||||
|             $class = $container->getDefinition($service['id'])->getClass(); | ||||
|   | ||||
| @@ -33,9 +33,7 @@ class Greatest extends FunctionNode | ||||
|  | ||||
|     public function getSql(SqlWalker $sqlWalker) | ||||
|     { | ||||
|         return 'GREATEST(' . implode(', ', array_map(static function (Node $expr) use ($sqlWalker) { | ||||
|             return $expr->dispatch($sqlWalker); | ||||
|         }, $this->exprs)) . ')'; | ||||
|         return 'GREATEST(' . implode(', ', array_map(static fn (Node $expr) => $expr->dispatch($sqlWalker), $this->exprs)) . ')'; | ||||
|     } | ||||
|  | ||||
|     public function parse(Parser $parser) | ||||
|   | ||||
| @@ -33,9 +33,7 @@ class Least extends FunctionNode | ||||
|  | ||||
|     public function getSql(SqlWalker $sqlWalker) | ||||
|     { | ||||
|         return 'LEAST(' . implode(', ', array_map(static function (Node $expr) use ($sqlWalker) { | ||||
|             return $expr->dispatch($sqlWalker); | ||||
|         }, $this->exprs)) . ')'; | ||||
|         return 'LEAST(' . implode(', ', array_map(static fn (Node $expr) => $expr->dispatch($sqlWalker), $this->exprs)) . ')'; | ||||
|     } | ||||
|  | ||||
|     public function parse(Parser $parser) | ||||
|   | ||||
| @@ -149,7 +149,7 @@ class Address implements TrackCreationInterface, TrackUpdateInterface | ||||
|      * @Groups({"write"}) | ||||
|      * @ORM\JoinColumn(nullable=true, onDelete="SET NULL") | ||||
|      */ | ||||
|     private ?ThirdParty $linkedToThirdParty; | ||||
|     private ?ThirdParty $linkedToThirdParty = null; | ||||
|  | ||||
|     /** | ||||
|      * A geospatial field storing the coordinates of the Address. | ||||
|   | ||||
| @@ -55,7 +55,7 @@ class AddressReference | ||||
|      * @ORM\Column(type="integer") | ||||
|      * @groups({"read"}) | ||||
|      */ | ||||
|     private ?int $id; | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="text", nullable=false, options={"default": ""}) | ||||
| @@ -79,7 +79,7 @@ class AddressReference | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\MainBundle\Entity\PostalCode") | ||||
|      * @groups({"read"}) | ||||
|      */ | ||||
|     private ?PostalCode $postcode; | ||||
|     private ?PostalCode $postcode = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="text", nullable=false, options={"default": ""}) | ||||
|   | ||||
| @@ -36,7 +36,7 @@ class GeographicalUnit | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity=GeographicalUnitLayer::class, inversedBy="units") | ||||
|      */ | ||||
|     private ?GeographicalUnitLayer $layer; | ||||
|     private ?GeographicalUnitLayer $layer = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="text", nullable=false, options={"default": ""}) | ||||
|   | ||||
| @@ -120,12 +120,12 @@ class Notification implements TrackUpdateInterface | ||||
|     /** | ||||
|      * @ORM\Column(type="datetime_immutable") | ||||
|      */ | ||||
|     private ?DateTimeImmutable $updatedAt; | ||||
|     private ?DateTimeImmutable $updatedAt = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity=User::class) | ||||
|      */ | ||||
|     private ?User $updatedBy; | ||||
|     private ?User $updatedBy = null; | ||||
|  | ||||
|     public function __construct() | ||||
|     { | ||||
|   | ||||
| @@ -121,9 +121,7 @@ class PermissionsGroup | ||||
|     public function isRoleScopePresentOnce(ExecutionContextInterface $context) | ||||
|     { | ||||
|         $roleScopesId = array_map( | ||||
|             static function (RoleScope $roleScope) { | ||||
|                 return $roleScope->getId(); | ||||
|             }, | ||||
|             static fn (RoleScope $roleScope) => $roleScope->getId(), | ||||
|             $this->getRoleScopes()->toArray() | ||||
|         ); | ||||
|         $countedIds = array_count_values($roleScopesId); | ||||
|   | ||||
| @@ -291,9 +291,7 @@ class EntityWorkflowStep | ||||
|  | ||||
|     public function removeDestEmail(string $email): self | ||||
|     { | ||||
|         $this->destEmail = array_filter($this->destEmail, static function (string $existing) use ($email) { | ||||
|             return $email !== $existing; | ||||
|         }); | ||||
|         $this->destEmail = array_filter($this->destEmail, static fn (string $existing) => $email !== $existing); | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|   | ||||
| @@ -199,9 +199,7 @@ class CSVListFormatter implements FormatterInterface | ||||
|  | ||||
|         foreach ($keys as $key) { | ||||
|             // get an array with all values for this key if possible | ||||
|             $values = array_map(static function ($v) use ($key) { | ||||
|                 return $v[$key]; | ||||
|             }, $this->result); | ||||
|             $values = array_map(static fn ($v) => $v[$key], $this->result); | ||||
|             // store the label in the labelsCache property | ||||
|             $this->labelsCache[$key] = $export->getLabels($key, $values, $this->exportData); | ||||
|         } | ||||
|   | ||||
| @@ -187,9 +187,7 @@ class CSVPivotedListFormatter implements FormatterInterface | ||||
|  | ||||
|         foreach ($keys as $key) { | ||||
|             // get an array with all values for this key if possible | ||||
|             $values = array_map(static function ($v) use ($key) { | ||||
|                 return $v[$key]; | ||||
|             }, $this->result); | ||||
|             $values = array_map(static fn ($v) => $v[$key], $this->result); | ||||
|             // store the label in the labelsCache property | ||||
|             $this->labelsCache[$key] = $export->getLabels($key, $values, $this->exportData); | ||||
|         } | ||||
|   | ||||
| @@ -445,7 +445,7 @@ class SpreadSheetFormatter implements FormatterInterface | ||||
|             $this->initializeCache($key); | ||||
|         } | ||||
|  | ||||
|         $value = $value ?? ''; | ||||
|         $value ??= ''; | ||||
|  | ||||
|         return call_user_func($this->cacheDisplayableResult[$key], $value); | ||||
|     } | ||||
|   | ||||
| @@ -249,7 +249,7 @@ class ExportAddressHelper | ||||
|             if (($params & $bitmask) === $bitmask) { | ||||
|                 if ('geographical_units' === $key) { | ||||
|                     // geographical unit generate keys dynamically, depending on layers | ||||
|                     $prefixes = array_merge($prefixes, array_keys($this->generateKeysForUnitsNames($prefix)), array_keys($this->generateKeysForUnitsRefs($prefix))); | ||||
|                     $prefixes = [...$prefixes, ...array_keys($this->generateKeysForUnitsNames($prefix)), ...array_keys($this->generateKeysForUnitsRefs($prefix))]; | ||||
|  | ||||
|                     continue; | ||||
|                 } | ||||
| @@ -257,9 +257,7 @@ class ExportAddressHelper | ||||
|                 $prefixes = array_merge( | ||||
|                     $prefixes, | ||||
|                     array_map( | ||||
|                         static function ($item) use ($prefix) { | ||||
|                             return $prefix . $item; | ||||
|                         }, | ||||
|                         static fn ($item) => $prefix . $item, | ||||
|                         self::COLUMN_MAPPING[$key] | ||||
|                     ) | ||||
|                 ); | ||||
|   | ||||
| @@ -48,9 +48,7 @@ class PostalCodeChoiceLoader implements ChoiceLoaderInterface | ||||
|     { | ||||
|         return new \Symfony\Component\Form\ChoiceList\ArrayChoiceList( | ||||
|             $this->lazyLoadedPostalCodes, | ||||
|             static function (?PostalCode $pc = null) use ($value) { | ||||
|                 return call_user_func($value, $pc); | ||||
|             } | ||||
|             static fn (?PostalCode $pc = null) => call_user_func($value, $pc) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -37,9 +37,7 @@ class ExportPickCenterDataMapper implements DataMapperInterface | ||||
|  | ||||
|         foreach ($this->regroupmentRepository->findAll() as $regroupment) { | ||||
|             /** @phpstan-ignore-next-line  */ | ||||
|             [$contained, $notContained] = $regroupment->getCenters()->partition(static function (Center $center): bool { | ||||
|                 return false; | ||||
|             }); | ||||
|             [$contained, $notContained] = $regroupment->getCenters()->partition(static fn (Center $center): bool => false); | ||||
|  | ||||
|             if (0 === count($notContained)) { | ||||
|                 $pickedRegroupment[] = $regroupment; | ||||
|   | ||||
| @@ -42,9 +42,7 @@ class IdToEntityDataTransformer implements DataTransformerInterface | ||||
|     { | ||||
|         $this->repository = $repository; | ||||
|         $this->multiple = $multiple; | ||||
|         $this->getId = $getId ?? static function (object $o) { | ||||
|             return $o->getId(); | ||||
|         }; | ||||
|         $this->getId = $getId ?? static fn (object $o) => $o->getId(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -36,15 +36,11 @@ final class LocationFormType extends AbstractType | ||||
|         $builder | ||||
|             ->add('locationType', EntityType::class, [ | ||||
|                 'class' => EntityLocationType::class, | ||||
|                 'choice_attr' => static function (EntityLocationType $entity) { | ||||
|                     return [ | ||||
|                         'data-address' => $entity->getAddressRequired(), | ||||
|                         'data-contact' => $entity->getContactData(), | ||||
|                     ]; | ||||
|                 }, | ||||
|                 'choice_label' => function (EntityLocationType $entity) { | ||||
|                     return $this->translatableStringHelper->localize($entity->getTitle()); | ||||
|                 }, | ||||
|                 'choice_attr' => static fn (EntityLocationType $entity) => [ | ||||
|                     'data-address' => $entity->getAddressRequired(), | ||||
|                     'data-contact' => $entity->getContactData(), | ||||
|                 ], | ||||
|                 'choice_label' => fn (EntityLocationType $entity) => $this->translatableStringHelper->localize($entity->getTitle()), | ||||
|             ]) | ||||
|             ->add('name', TextType::class) | ||||
|             ->add('phonenumber1', ChillPhoneNumberType::class, ['required' => false]) | ||||
|   | ||||
| @@ -24,14 +24,10 @@ class ComposedGroupCenterType extends AbstractType | ||||
|     { | ||||
|         $builder->add('permissionsgroup', EntityType::class, [ | ||||
|             'class' => \Chill\MainBundle\Entity\PermissionsGroup::class, | ||||
|             'choice_label' => static function (PermissionsGroup $group) { | ||||
|                 return $group->getName(); | ||||
|             }, | ||||
|             'choice_label' => static fn (PermissionsGroup $group) => $group->getName(), | ||||
|         ])->add('center', EntityType::class, [ | ||||
|             'class' => \Chill\MainBundle\Entity\Center::class, | ||||
|             'choice_label' => static function (Center $center) { | ||||
|                 return $center->getName(); | ||||
|             }, | ||||
|             'choice_label' => static fn (Center $center) => $center->getName(), | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -82,16 +82,12 @@ class ComposedRoleScopeType extends AbstractType | ||||
|  | ||||
|                     return ['data-has-scope' => '1']; | ||||
|                 }, | ||||
|                 'group_by' => function ($role, $key, $index) { | ||||
|                     return $this->roleProvider->getRoleTitle($role); | ||||
|                 }, | ||||
|                 'group_by' => fn ($role, $key, $index) => $this->roleProvider->getRoleTitle($role), | ||||
|             ]) | ||||
|             ->add('scope', EntityType::class, [ | ||||
|                 'class' => Scope::class, | ||||
|                 'choice_label' => static fn (Scope $scope) => $translatableStringHelper->localize($scope->getName()), | ||||
|                 'placeholder' => 'Choose amongst scopes', | ||||
|                 'choice_label' => static function (Scope $scope) use ($translatableStringHelper) { | ||||
|                     return $translatableStringHelper->localize($scope->getName()); | ||||
|                 }, | ||||
|                 'required' => false, | ||||
|                 'data' => null, | ||||
|             ]); | ||||
|   | ||||
| @@ -51,9 +51,7 @@ class EntityToJsonTransformer implements DataTransformerInterface | ||||
|             } | ||||
|  | ||||
|             return array_map( | ||||
|                 function ($item) { | ||||
|                     return $this->denormalizeOne($item); | ||||
|                 }, | ||||
|                 fn ($item) => $this->denormalizeOne($item), | ||||
|                 $denormalized | ||||
|             ); | ||||
|         } | ||||
|   | ||||
| @@ -67,9 +67,7 @@ final class PickCenterType extends AbstractType | ||||
|             'choices' => $centers, | ||||
|             'multiple' => true, | ||||
|             'expanded' => true, | ||||
|             'choice_label' => static function (Center $c) { | ||||
|                 return $c->getName(); | ||||
|             }, | ||||
|             'choice_label' => static fn (Center $c) => $c->getName(), | ||||
|             'data' => $centers, | ||||
|         ]); | ||||
|  | ||||
| @@ -80,9 +78,7 @@ final class PickCenterType extends AbstractType | ||||
|                 'multiple' => true, | ||||
|                 'expanded' => true, | ||||
|                 'choices' => $this->regroupmentRepository->findAllActive(), | ||||
|                 'choice_label' => static function (Regroupment $r) { | ||||
|                     return $r->getName(); | ||||
|                 }, | ||||
|                 'choice_label' => static fn (Regroupment $r) => $r->getName(), | ||||
|             ]); | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -90,9 +90,7 @@ class PickCenterType extends AbstractType | ||||
|  | ||||
|                     return ['center' => $data]; | ||||
|                 }, | ||||
|                 static function ($data) { | ||||
|                     return $data['center']; | ||||
|                 } | ||||
|                 static fn ($data) => $data['center'] | ||||
|             )); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -34,17 +34,13 @@ class PickCivilityType extends AbstractType | ||||
|             ->setDefault('label', 'Civility') | ||||
|             ->setDefault( | ||||
|                 'choice_label', | ||||
|                 function (Civility $civility): string { | ||||
|                     return $this->translatableStringHelper->localize($civility->getName()); | ||||
|                 } | ||||
|                 fn (Civility $civility): string => $this->translatableStringHelper->localize($civility->getName()) | ||||
|             ) | ||||
|             ->setDefault( | ||||
|                 'query_builder', | ||||
|                 static function (EntityRepository $er): QueryBuilder { | ||||
|                     return $er->createQueryBuilder('c') | ||||
|                         ->where('c.active = true') | ||||
|                         ->orderBy('c.order'); | ||||
|                 }, | ||||
|                 static fn (EntityRepository $er): QueryBuilder => $er->createQueryBuilder('c') | ||||
|                     ->where('c.active = true') | ||||
|                     ->orderBy('c.order'), | ||||
|             ) | ||||
|             ->setDefault('placeholder', 'choose civility') | ||||
|             ->setDefault('class', Civility::class); | ||||
|   | ||||
| @@ -31,9 +31,7 @@ class PickLocationTypeType extends AbstractType | ||||
|         $resolver | ||||
|             ->setDefaults([ | ||||
|                 'class' => LocationType::class, | ||||
|                 'choice_label' => function (LocationType $type) { | ||||
|                     return $this->translatableStringHelper->localize($type->getTitle()); | ||||
|                 }, | ||||
|                 'choice_label' => fn (LocationType $type) => $this->translatableStringHelper->localize($type->getTitle()), | ||||
|                 'placeholder' => 'Pick a location type', | ||||
|                 'required' => false, | ||||
|                 'attr' => ['class' => 'select2'], | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user