mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-25 14:42:48 +00:00 
			
		
		
		
	Create gender admin entity and add configuration to use it
entity, migration, controller, repository, templates, form added
This commit is contained in:
		
							
								
								
									
										17
									
								
								src/Bundle/ChillMainBundle/Controller/GenderController.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/Bundle/ChillMainBundle/Controller/GenderController.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Chill\MainBundle\Controller; | ||||
|  | ||||
| use Chill\MainBundle\CRUD\Controller\CRUDController; | ||||
| use Chill\MainBundle\Pagination\PaginatorInterface; | ||||
| use Symfony\Component\HttpFoundation\Request; | ||||
|  | ||||
| class GenderController extends CRUDController | ||||
| { | ||||
|     protected function orderQuery(string $action, $query, Request $request, PaginatorInterface $paginator) | ||||
|     { | ||||
|         $query->addOrderBy('e.order', 'ASC'); | ||||
|  | ||||
|         return parent::orderQuery($action, $query, $request, $paginator); | ||||
|     } | ||||
| } | ||||
| @@ -17,6 +17,7 @@ use Chill\MainBundle\Controller\CivilityApiController; | ||||
| use Chill\MainBundle\Controller\CivilityController; | ||||
| use Chill\MainBundle\Controller\CountryApiController; | ||||
| use Chill\MainBundle\Controller\CountryController; | ||||
| use Chill\MainBundle\Controller\GenderController; | ||||
| use Chill\MainBundle\Controller\GeographicalUnitApiController; | ||||
| use Chill\MainBundle\Controller\LanguageController; | ||||
| use Chill\MainBundle\Controller\LocationController; | ||||
| @@ -52,6 +53,7 @@ use Chill\MainBundle\Doctrine\Type\PointType; | ||||
| use Chill\MainBundle\Entity\Center; | ||||
| use Chill\MainBundle\Entity\Civility; | ||||
| use Chill\MainBundle\Entity\Country; | ||||
| use Chill\MainBundle\Entity\Gender; | ||||
| use Chill\MainBundle\Entity\GeographicalUnitLayer; | ||||
| use Chill\MainBundle\Entity\Language; | ||||
| use Chill\MainBundle\Entity\Location; | ||||
| @@ -63,6 +65,7 @@ use Chill\MainBundle\Entity\UserJob; | ||||
| use Chill\MainBundle\Form\CenterType; | ||||
| use Chill\MainBundle\Form\CivilityType; | ||||
| use Chill\MainBundle\Form\CountryType; | ||||
| use Chill\MainBundle\Form\GenderType; | ||||
| use Chill\MainBundle\Form\LanguageType; | ||||
| use Chill\MainBundle\Form\LocationFormType; | ||||
| use Chill\MainBundle\Form\LocationTypeType; | ||||
| @@ -485,6 +488,28 @@ class ChillMainExtension extends Extension implements | ||||
|                         ], | ||||
|                     ], | ||||
|                 ], | ||||
|                 [ | ||||
|                     'class' => Gender::class, | ||||
|                     'name' => 'main_gender', | ||||
|                     'base_path' => '/admin/main/gender', | ||||
|                     'base_role' => 'ROLE_ADMIN', | ||||
|                     'form_class' => GenderType::class, | ||||
|                     'controller' => GenderController::class, | ||||
|                     'actions' => [ | ||||
|                         'index' => [ | ||||
|                             'role' => 'ROLE_ADMIN', | ||||
|                             'template' => '@ChillMain/Gender/index.html.twig', | ||||
|                         ], | ||||
|                         'new' => [ | ||||
|                             'role' => 'ROLE_ADMIN', | ||||
|                             'template' => '@ChillMain/Gender/new.html.twig', | ||||
|                         ], | ||||
|                         'edit' => [ | ||||
|                             'role' => 'ROLE_ADMIN', | ||||
|                             'template' => '@ChillMain/Gender/edit.html.twig', | ||||
|                         ], | ||||
|                     ], | ||||
|                 ], | ||||
|                 [ | ||||
|                     'class' => Language::class, | ||||
|                     'name' => 'main_language', | ||||
|   | ||||
							
								
								
									
										93
									
								
								src/Bundle/ChillMainBundle/Entity/Gender.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								src/Bundle/ChillMainBundle/Entity/Gender.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Chill\MainBundle\Entity; | ||||
|  | ||||
| use Chill\MainBundle\Repository\GenderRepository; | ||||
| use Doctrine\ORM\Mapping as ORM; | ||||
| use Symfony\Component\Serializer\Annotation as Serializer; | ||||
|  | ||||
|  | ||||
| #[ORM\Entity(repositoryClass: GenderRepository::class)] | ||||
| #[ORM\Table(name: 'chill_main_gender')] | ||||
| class Gender | ||||
| { | ||||
|     #[Serializer\Groups(['read'])] | ||||
|     #[ORM\Id] | ||||
|     #[ORM\GeneratedValue] | ||||
|     #[ORM\Column(type: \Doctrine\DBAL\Types\Types::INTEGER)] | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     #[Serializer\Groups(['read'])] | ||||
|     #[ORM\Column(type: \Doctrine\DBAL\Types\Types::JSON)] | ||||
|     private array $label = []; | ||||
|  | ||||
|     #[Serializer\Groups(['read'])] | ||||
|     #[ORM\Column(type: \Doctrine\DBAL\Types\Types::BOOLEAN)] | ||||
|     private bool $active = true; | ||||
|  | ||||
|     #[Serializer\Groups(['read'])] | ||||
|     #[ORM\Column(type: \Doctrine\DBAL\Types\Types::BOOLEAN)] | ||||
|     private bool $isGrammatical = true; | ||||
|  | ||||
|     #[Serializer\Groups(['read'])] | ||||
|     #[ORM\Column(type: \Doctrine\DBAL\Types\Types::STRING, length: 255)] | ||||
|     private string $icon = ''; | ||||
|  | ||||
|     #[ORM\Column(type: \Doctrine\DBAL\Types\Types::FLOAT, name: 'ordering', nullable: true, options: ['default' => '0.0'])] | ||||
|     private float $order = 0; | ||||
|  | ||||
|     public function getId(): int | ||||
|     { | ||||
|         return $this->id; | ||||
|     } | ||||
|  | ||||
|     public function getLabel(): array | ||||
|     { | ||||
|         return $this->label; | ||||
|     } | ||||
|  | ||||
|     public function setLabel(array $label): void | ||||
|     { | ||||
|         $this->label = $label; | ||||
|     } | ||||
|  | ||||
|     public function isActive(): bool | ||||
|     { | ||||
|         return $this->active; | ||||
|     } | ||||
|  | ||||
|     public function setActive(bool $active): void | ||||
|     { | ||||
|         $this->active = $active; | ||||
|     } | ||||
|  | ||||
|     public function isGrammatical(): bool | ||||
|     { | ||||
|         return $this->isGrammatical; | ||||
|     } | ||||
|  | ||||
|     public function setIsGrammatical(bool $isGrammatical): void | ||||
|     { | ||||
|         $this->isGrammatical = $isGrammatical; | ||||
|     } | ||||
|  | ||||
|     public function getIcon(): string | ||||
|     { | ||||
|         return $this->icon; | ||||
|     } | ||||
|  | ||||
|     public function setIcon(string $icon): void | ||||
|     { | ||||
|         $this->icon = $icon; | ||||
|     } | ||||
|  | ||||
|     public function getOrder(): float | ||||
|     { | ||||
|         return $this->order; | ||||
|     } | ||||
|  | ||||
|     public function setOrder(float $order): void | ||||
|     { | ||||
|         $this->order = $order; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										44
									
								
								src/Bundle/ChillMainBundle/Form/GenderType.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								src/Bundle/ChillMainBundle/Form/GenderType.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Chill\MainBundle\Form; | ||||
|  | ||||
| use Chill\MainBundle\Entity\Gender; | ||||
| use Chill\MainBundle\Form\Type\TranslatableStringFormType; | ||||
| use Symfony\Component\Form\AbstractType; | ||||
| use Symfony\Component\Form\Extension\Core\Type\ChoiceType; | ||||
| use Symfony\Component\Form\Extension\Core\Type\IntegerType; | ||||
| use Symfony\Component\Form\Extension\Core\Type\TextType; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
| use Symfony\Component\OptionsResolver\OptionsResolver; | ||||
|  | ||||
| class GenderType extends AbstractType | ||||
| { | ||||
|     public function buildForm(FormBuilderInterface $builder, array $options): void | ||||
|     { | ||||
|         $builder | ||||
|             ->add('label', TranslatableStringFormType::class, [ | ||||
|                 'required' => true, | ||||
|             ]) | ||||
|             ->add('icon', TextType::class) | ||||
|             ->add('isGrammatical', ChoiceType::class, [ | ||||
|                 'choices' => [ | ||||
|                     'Grammatical' => true, | ||||
|                     'Not grammatical' => false, | ||||
|                 ], | ||||
|             ]) | ||||
|             ->add('active', ChoiceType::class, [ | ||||
|                 'choices' => [ | ||||
|                     'Active' => true, | ||||
|                     'Inactive' => false, | ||||
|                 ], | ||||
|             ]) | ||||
|             ->add('order', IntegerType::class); | ||||
|     } | ||||
|  | ||||
|     public function configureOptions(OptionsResolver $resolver): void | ||||
|     { | ||||
|         $resolver->setDefaults([ | ||||
|             'data_class' => Gender::class, | ||||
|         ]); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,7 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Chill\MainBundle\Repository; | ||||
|  | ||||
| use Doctrine\ORM\EntityRepository; | ||||
|  | ||||
| class GenderRepository extends EntityRepository {} | ||||
| @@ -0,0 +1,11 @@ | ||||
| {% extends '@ChillMain/CRUD/Admin/index.html.twig' %} | ||||
|  | ||||
| {% block title %} | ||||
|     {% include('@ChillMain/CRUD/_edit_title.html.twig') %} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block admin_content %} | ||||
|     {% embed '@ChillMain/CRUD/_edit_content.html.twig' %} | ||||
|         {% block content_form_actions_save_and_show %}{% endblock %} | ||||
|     {% endembed %} | ||||
| {% endblock admin_content %} | ||||
| @@ -0,0 +1,53 @@ | ||||
| {% extends '@ChillMain/CRUD/Admin/index.html.twig' %} | ||||
|  | ||||
| {% block admin_content %} | ||||
|     {% embed '@ChillMain/CRUD/_index.html.twig' %} | ||||
|         {% block table_entities_thead_tr %} | ||||
|             <th>id</th> | ||||
|             <th>{{ 'gender.label'|trans }}</th> | ||||
|             <th>{{ 'gender.icon'|trans }}</th> | ||||
|             <th>{{ 'gender.isGrammatical'|trans }}</th> | ||||
|             <th>{{ 'gender.active'|trans }}</th> | ||||
|             <th>{{ 'gender.ordering'|trans }}</th> | ||||
|             <th></th> | ||||
|         {% endblock %} | ||||
|         {% block table_entities_tbody %} | ||||
|             {% for entity in entities %} | ||||
|                 <tr> | ||||
|                     <td>{{ entity.id }}</td> | ||||
|                     <td>{{ entity.label|localize_translatable_string }}</td> | ||||
| {#                    todo: decide which icon source to use#} | ||||
|                     <td><i class="{{ entity.icon }}"></i></td> | ||||
|                     <td style="text-align:center;"> | ||||
|                         {%- if entity.isGrammatical -%} | ||||
|                             <i class="fa fa-check-square-o"></i> | ||||
|                         {%- else -%} | ||||
|                             <i class="fa fa-square-o"></i> | ||||
|                         {%- endif -%} | ||||
|                     </td> | ||||
|                     <td style="text-align:center;"> | ||||
| 						{%- if entity.active -%} | ||||
| 							<i class="fa fa-check-square-o"></i> | ||||
| 						{%- else -%} | ||||
| 							<i class="fa fa-square-o"></i> | ||||
| 						{%- endif -%} | ||||
| 					</td> | ||||
|                     <td>{{ entity.order }}</td> | ||||
|                     <td> | ||||
|                         <ul class="record_actions"> | ||||
|                             <li> | ||||
|                                 <a href="{{ chill_path_add_return_path('chill_crud_main_gender_edit', { 'id': entity.id}) }}" class="btn btn-sm btn-edit btn-mini"></a> | ||||
|                             </li> | ||||
|                         </ul> | ||||
|                     </td> | ||||
|                 </tr> | ||||
|             {% endfor %} | ||||
|         {% endblock %} | ||||
|  | ||||
|         {% block actions_before %} | ||||
|             <li class='cancel'> | ||||
|                 <a href="{{ path('chill_main_admin_central') }}" class="btn btn-cancel">{{'Back to the admin'|trans}}</a> | ||||
|             </li> | ||||
|         {% endblock %} | ||||
|     {% endembed %} | ||||
| {% endblock %} | ||||
| @@ -0,0 +1,11 @@ | ||||
| {% extends '@ChillMain/CRUD/Admin/index.html.twig' %} | ||||
|  | ||||
| {% block title %} | ||||
|     {% include('@ChillMain/CRUD/_new_title.html.twig') %} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block admin_content %} | ||||
|     {% embed '@ChillMain/CRUD/_new_content.html.twig' %} | ||||
|         {% block content_form_actions_save_and_show %}{% endblock %} | ||||
|     {% endembed %} | ||||
| {% endblock admin_content %} | ||||
| @@ -0,0 +1,28 @@ | ||||
| <?php | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\Migrations\Main; | ||||
|  | ||||
| use Doctrine\DBAL\Schema\Schema; | ||||
| use Doctrine\Migrations\AbstractMigration; | ||||
|  | ||||
| final class Version20240925133053 extends AbstractMigration | ||||
| { | ||||
|     public function getDescription(): string | ||||
|     { | ||||
|         return 'Add gender entity'; | ||||
|     } | ||||
|  | ||||
|     public function up(Schema $schema): void | ||||
|     { | ||||
|         $this->addSql('CREATE SEQUENCE chill_main_gender_id_seq INCREMENT BY 1 MINVALUE 1 START 1'); | ||||
|         $this->addSql('CREATE TABLE chill_main_gender (id INT NOT NULL, label JSON NOT NULL, active BOOLEAN NOT NULL, isGrammatical BOOLEAN NOT NULL, icon VARCHAR(255) NOT NULL, ordering DOUBLE PRECISION DEFAULT \'0.0\', PRIMARY KEY(id))'); | ||||
|     } | ||||
|  | ||||
|     public function down(Schema $schema): void | ||||
|     { | ||||
|         $this->addSql('DROP SEQUENCE chill_main_gender_id_seq CASCADE'); | ||||
|         $this->addSql('DROP TABLE chill_main_gender'); | ||||
|     } | ||||
| } | ||||
| @@ -45,13 +45,17 @@ class AdminPersonMenuBuilder implements LocalMenuBuilderInterface | ||||
|             'route' => 'chill_crud_main_civility_index', | ||||
|         ])->setExtras(['order' => 2010]); | ||||
|  | ||||
|         $menu->addChild('Gender', [ | ||||
|             'route' => 'chill_crud_main_gender_index', | ||||
|         ])->setExtras(['order' => 2020]); | ||||
|  | ||||
|         $menu->addChild('Marital status', [ | ||||
|             'route' => 'chill_crud_person_marital-status_index', | ||||
|         ])->setExtras(['order' => 2020]); | ||||
|         ])->setExtras(['order' => 2030]); | ||||
|  | ||||
|         $menu->addChild('person_admin.person_resource_kind', [ | ||||
|             'route' => 'chill_crud_person_resource-kind_index', | ||||
|         ])->setExtras(['order' => 2030]); | ||||
|         ])->setExtras(['order' => 2040]); | ||||
|     } | ||||
|  | ||||
|     public static function getMenuIds(): array | ||||
|   | ||||
		Reference in New Issue
	
	Block a user