mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-25 22:52:48 +00:00 
			
		
		
		
	[main] Add mainLocation field to User entity
This commit is contained in:
		| @@ -11,6 +11,7 @@ and this project adheres to | |||||||
| ## Unreleased | ## Unreleased | ||||||
|  |  | ||||||
| <!-- write down unreleased development here --> | <!-- write down unreleased development here --> | ||||||
|  | * [main] Add mainLocation field to User entity and add it in user form type | ||||||
| * rewrite page which allow to select activity | * rewrite page which allow to select activity | ||||||
|  |  | ||||||
| ## Test releases | ## Test releases | ||||||
|   | |||||||
| @@ -97,6 +97,11 @@ class User implements AdvancedUserInterface | |||||||
|      */ |      */ | ||||||
|     private ?Center $mainCenter = null; |     private ?Center $mainCenter = null; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @ORM\ManyToOne(targetEntity=Location::class) | ||||||
|  |      */ | ||||||
|  |     private ?Location $mainLocation = null; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @ORM\ManyToOne(targetEntity=Scope::class) |      * @ORM\ManyToOne(targetEntity=Scope::class) | ||||||
|      */ |      */ | ||||||
| @@ -228,6 +233,11 @@ class User implements AdvancedUserInterface | |||||||
|         return $this->mainCenter; |         return $this->mainCenter; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public function getMainLocation(): ?Location | ||||||
|  |     { | ||||||
|  |         return $this->mainLocation; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public function getMainScope(): ?Scope |     public function getMainScope(): ?Scope | ||||||
|     { |     { | ||||||
|         return $this->mainScope; |         return $this->mainScope; | ||||||
| @@ -405,6 +415,13 @@ class User implements AdvancedUserInterface | |||||||
|         return $this; |         return $this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public function setMainLocation(?Location $mainLocation): User | ||||||
|  |     { | ||||||
|  |         $this->mainLocation = $mainLocation; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public function setMainScope(?Scope $mainScope): User |     public function setMainScope(?Scope $mainScope): User | ||||||
|     { |     { | ||||||
|         $this->mainScope = $mainScope; |         $this->mainScope = $mainScope; | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ declare(strict_types=1); | |||||||
| namespace Chill\MainBundle\Form; | namespace Chill\MainBundle\Form; | ||||||
|  |  | ||||||
| use Chill\MainBundle\Entity\Center; | use Chill\MainBundle\Entity\Center; | ||||||
|  | use Chill\MainBundle\Entity\Location; | ||||||
| use Chill\MainBundle\Entity\Scope; | use Chill\MainBundle\Entity\Scope; | ||||||
| use Chill\MainBundle\Entity\UserJob; | use Chill\MainBundle\Entity\UserJob; | ||||||
| use Chill\MainBundle\Templating\TranslatableStringHelper; | use Chill\MainBundle\Templating\TranslatableStringHelper; | ||||||
| @@ -75,6 +76,22 @@ class UserType extends AbstractType | |||||||
|                 'choice_label' => function (UserJob $c) { |                 'choice_label' => function (UserJob $c) { | ||||||
|                     return $this->translatableStringHelper->localize($c->getLabel()); |                     return $this->translatableStringHelper->localize($c->getLabel()); | ||||||
|                 }, |                 }, | ||||||
|  |             ]) | ||||||
|  |             ->add('mainLocation', EntityType::class, [ | ||||||
|  |                 'label' => 'Main location', | ||||||
|  |                 'required' => false, | ||||||
|  |                 'placeholder' => 'choose a location', | ||||||
|  |                 'class' => Location::class, | ||||||
|  |                 'choice_label' => function (Location $l) { | ||||||
|  |                     return $this->translatableStringHelper->localize($l->getLocationType()->getTitle()) . ' - ' . $l->getName(); | ||||||
|  |                 }, | ||||||
|  |                 'query_builder' => static function (EntityRepository $er) { | ||||||
|  |                     $qb = $er->createQueryBuilder('l'); | ||||||
|  |                     $qb->orderBy('l.locationType'); | ||||||
|  |                     $qb->where('l.availableForUsers = TRUE'); | ||||||
|  |  | ||||||
|  |                     return $qb; | ||||||
|  |                 }, | ||||||
|             ]); |             ]); | ||||||
|  |  | ||||||
|         if ($options['is_creation']) { |         if ($options['is_creation']) { | ||||||
|   | |||||||
| @@ -58,7 +58,7 @@ class UserNormalizer implements ContextAwareNormalizerInterface, NormalizerAware | |||||||
|         ); |         ); | ||||||
|         $locationContext = array_merge( |         $locationContext = array_merge( | ||||||
|             $context, |             $context, | ||||||
|             ['docgen:expects' => Location::class, 'groups' => 'dogen:read'] |             ['docgen:expects' => Location::class, 'groups' => 'docgen:read'] | ||||||
|         ); |         ); | ||||||
|  |  | ||||||
|         if (null === $user && 'docgen' === $format) { |         if (null === $user && 'docgen' === $format) { | ||||||
| @@ -67,6 +67,7 @@ class UserNormalizer implements ContextAwareNormalizerInterface, NormalizerAware | |||||||
|                 'main_center' => $this->normalizer->normalize(null, $format, $centerContext), |                 'main_center' => $this->normalizer->normalize(null, $format, $centerContext), | ||||||
|                 'main_scope' => $this->normalizer->normalize(null, $format, $scopeContext), |                 'main_scope' => $this->normalizer->normalize(null, $format, $scopeContext), | ||||||
|                 'current_location' => $this->normalizer->normalize(null, $format, $locationContext), |                 'current_location' => $this->normalizer->normalize(null, $format, $locationContext), | ||||||
|  |                 'main_location' => $this->normalizer->normalize(null, $format, $locationContext), | ||||||
|             ]); |             ]); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -84,6 +85,7 @@ class UserNormalizer implements ContextAwareNormalizerInterface, NormalizerAware | |||||||
|  |  | ||||||
|         if ('docgen' === $format) { |         if ('docgen' === $format) { | ||||||
|             $data['current_location'] = $this->normalizer->normalize($user->getCurrentLocation(), $format, $locationContext); |             $data['current_location'] = $this->normalizer->normalize($user->getCurrentLocation(), $format, $locationContext); | ||||||
|  |             $data['main_location'] = $this->normalizer->normalize($user->getMainLocation(), $format, $locationContext); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return $data; |         return $data; | ||||||
|   | |||||||
| @@ -0,0 +1,40 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Chill is a software for social workers | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view | ||||||
|  |  * the LICENSE file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | declare(strict_types=1); | ||||||
|  |  | ||||||
|  | namespace Chill\Migrations\Main; | ||||||
|  |  | ||||||
|  | use Doctrine\DBAL\Schema\Schema; | ||||||
|  | use Doctrine\Migrations\AbstractMigration; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Add mainLocation to User. | ||||||
|  |  */ | ||||||
|  | final class Version20220112161136 extends AbstractMigration | ||||||
|  | { | ||||||
|  |     public function down(Schema $schema): void | ||||||
|  |     { | ||||||
|  |         $this->addSql('ALTER TABLE users DROP CONSTRAINT FK_1483A5E9DB622A42'); | ||||||
|  |         $this->addSql('DROP INDEX IDX_1483A5E9DB622A42'); | ||||||
|  |         $this->addSql('ALTER TABLE users DROP mainLocation_id'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function getDescription(): string | ||||||
|  |     { | ||||||
|  |         return 'Add mainLocation to User'; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function up(Schema $schema): void | ||||||
|  |     { | ||||||
|  |         $this->addSql('ALTER TABLE users ADD mainLocation_id INT DEFAULT NULL'); | ||||||
|  |         $this->addSql('ALTER TABLE users ADD CONSTRAINT FK_1483A5E9DB622A42 FOREIGN KEY (mainLocation_id) REFERENCES chill_main_location (id) NOT DEFERRABLE INITIALLY IMMEDIATE'); | ||||||
|  |         $this->addSql('CREATE INDEX IDX_1483A5E9DB622A42 ON users (mainLocation_id)'); | ||||||
|  |     } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user