mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-25 14:42:48 +00:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			v4.0.0
			...
			add_user_f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 714d0ed991 | |||
| ed96017c49 | 
							
								
								
									
										6
									
								
								.changes/unreleased/DX-20230607-130344.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.changes/unreleased/DX-20230607-130344.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| kind: DX | ||||
| body: Add methods to RegroupmentRepository and fullfill Center / Regroupment Doctrine | ||||
|   mapping | ||||
| time: 2023-06-07T13:03:44.177864269+02:00 | ||||
| custom: | ||||
|   Issue: "" | ||||
							
								
								
									
										6
									
								
								.changes/unreleased/Feature-20230607-194040.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.changes/unreleased/Feature-20230607-194040.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| kind: Feature | ||||
| body: Add the possibility to filter tasks on the basis of the person involved. Expansion | ||||
|   of FilterOrderHelper. | ||||
| time: 2023-06-07T19:40:40.506964817+02:00 | ||||
| custom: | ||||
|   Issue: "" | ||||
							
								
								
									
										7
									
								
								.changes/unreleased/Security-20230607-174702.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								.changes/unreleased/Security-20230607-174702.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| kind: Security | ||||
| body: Rights are checked for display of 'accompanying period' tab in household menu. | ||||
|   Rights are also checked for creation of 'accompanying period' from within household | ||||
|   context | ||||
| time: 2023-06-07T17:47:02.488819553+02:00 | ||||
| custom: | ||||
|   Issue: "105" | ||||
| @@ -1,17 +0,0 @@ | ||||
| ## v2.1.0 - 2023-06-12 | ||||
|  | ||||
| ### Feature | ||||
|  | ||||
| * [docgen] allow to pick a third party when generating a document in context Activity, AccompanyingPeriod | ||||
|  | ||||
| ### Fixed | ||||
|  | ||||
| * ([#111](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/111)) List of "my accompanying periods": separate the active and closed periods in two different lists, and show the inactive_long and inactive_short periods | ||||
|  | ||||
| ### Security | ||||
|  | ||||
| * ([#105](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/105)) Rights are checked for display of 'accompanying period' tab in household menu. Rights are also checked for creation of 'accompanying period' from within household context | ||||
|  | ||||
| ### DX | ||||
|  | ||||
| * Add methods to RegroupmentRepository and fullfill Center / Regroupment Doctrine mapping | ||||
| @@ -1,20 +0,0 @@ | ||||
| ## v2.10.0 - 2023-10-24 | ||||
| ### Feature | ||||
| * ([#172](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/172)) [export] Add a filter "grouping accompanying period by opening date" and "grouping accompanying period by closing date" | ||||
| * ([#172](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/172)) [export] add a filter and aggregator on accompanying period work: group/filter by handling third party | ||||
| * ([#172](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/172)) [export] add a filter and aggregator on activites: group/filter activities by people participating to the activities | ||||
| * ([#172](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/172)) [export] add a grouping on accompanying period export: group by activity type associated to at least one activity within the accompanying period | ||||
| * [export] sort filters and aggregators by title | ||||
| * ([#179](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/179)) [export] create a parameter that will force to skip the filtering by center (ACL) when generating an export | ||||
| ### Fixed | ||||
| * ([#177](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/177)) [export] fix date range selection on filter and grouping "by status of the course at date", on accompanying periods | ||||
|  | ||||
| ### Résumé francophone des changements | ||||
|  | ||||
| - Ajout d'un regroupement sur les parcours: par date de cloture et d'ouverture; | ||||
| - Ajouter d'un filtre et regroupement par tiers traitant sur les actions d'accompagnement; | ||||
| - ajout d'un filtre et regroupement par usager participant sur les échanges | ||||
| - ajout d'un regroupement: par type d'activité associé au parcours; | ||||
| - trie les filtre et regroupements par ordre alphabétique dans els exports | ||||
| - ajout d'un paramètre qui permet de désactiver le filtre par centre dans les exports | ||||
| - correction de l'interface de date dans les filtres et regroupements "par statut du parcours à la date" | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.10.1 - 2023-10-24 | ||||
| ### Fixed | ||||
| * Fix export controller when generating an export without any data in session  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.10.2 - 2023-10-26 | ||||
| ### Fixed | ||||
| * ([#175](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/175)) Use injection of translator instead of ->get().  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.10.3 - 2023-10-26 | ||||
| ### Fixed | ||||
| * ([#175](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/175)) Replace old method of getting translator with injection of translatorInterface  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.10.4 - 2023-10-26 | ||||
| ### Fixed | ||||
| * Fix null value constraint errors when merging relationships in doubles  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v2.10.5 - 2023-11-05 | ||||
| ### Fixed | ||||
| * ([#183](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/183)) Fix "problem during download" on some filters, which used a wrong data type  | ||||
| * ([#184](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/184)) Fix filter "activity by date"  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v2.10.6 - 2023-11-07 | ||||
| ### Fixed | ||||
| * ([#182](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/182)) Fix merging of double person files. Adjustement relationship sql statement  | ||||
| * ([#185](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/185)) Export: fix aggregator by geographical unit on person: avoid inconsistencies  | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v2.11.0 - 2023-11-07 | ||||
| ### Feature | ||||
| * ([#194](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/194)) Export: add a filter "filter activity by creator job"  | ||||
| ### Fixed | ||||
| * ([#185](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/185)) Export: fix "group accompanying period by geographical unit": take into account the accompanying periods when the period is not located within an unit  | ||||
| * Fix "group activity by creator job" aggregator  | ||||
| @@ -1,26 +0,0 @@ | ||||
| ## v2.12.0 - 2023-11-15 | ||||
| ### Feature | ||||
| * ([#199](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/199)) Export: add an aggregator "group activities by presence" | ||||
| * ([#199](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/199)) Export: add a filter "filter activity by activity presence" | ||||
| * ([#199](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/199)) Export: add an aggregator "group activities by person" (only for the activities saved in a person context) | ||||
| * ([#199](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/199)) Export: add a new aggregator "group peoples by postal code" | ||||
| * ([#200](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/200)) Export: split export about person on accompanying period work: one with the people associated with the work, another one with the people associated with the accompanying period | ||||
| * ([#204](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/204)) Add 3 new filters and 3 new aggregators for work action creator (with jobs and scopes) | ||||
|  | ||||
| * ([#202](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/202)) Create export for the average duration of social work actions | ||||
| * ([#206](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/206)) Export: add a export which count persons on accompanying period work | ||||
| * ([#206](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/206)) Export: add an export which count persons on activity | ||||
| * ([#203](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/203)) Export: add clauses on the social work start date and end date within the filter "Filter accompanying period by accompanying period work" | ||||
| ### Fixed | ||||
| * Export: fix typo in filter "filter accompanying period work on end date" | ||||
| * ([#189](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/189)) Export: Fix failure in export linked to household | ||||
| * ([#205](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/205)) Fix loading of accompanying period work referrers | ||||
| ### Traduction francophone des principaux changements | ||||
| * export: ajout d'un regroupement "grouper les échanges par présence de l'usager"; | ||||
| * export: ajout d'un filtre "filtre les échanges par présence de l'usager"; | ||||
| * export: ajout d'un regroupement "regrouper les échanges par personne" (seulement pour les échanges enregistrés dans le contexte de l'usager); | ||||
| * export: ajout d'un regroupement "grouper les usagers par codes postaux" | ||||
| * export: séparation des exports sur les actions: dans l'un, les filtres des usagers portent sur les usagers concernés par l'action, dans l'autre, les filtres portent sur les usagers concernés par le parcours de l'action; | ||||
| * export: ajout de 3 nouveaux filtres et regroupements sur le créateur de l'action, son métier et son service; | ||||
| * export: correction de l'export sur les ménages liés aux parcours; | ||||
| * correction du chargement des actions d'accompagnement | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.12.1 - 2023-11-16 | ||||
| ### Fixed | ||||
| * ([#208](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/208)) Export: fix loading of form for "filter action by type, goal and result"  | ||||
| @@ -1,9 +0,0 @@ | ||||
| ## v2.13.0 - 2023-11-21 | ||||
| ### Feature | ||||
| * ([#173](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/173)) Allow user to add a phonenumber to their profile which will be included in automatically generated documents | ||||
| ### Fixed | ||||
| * ([#211](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/211)) Export: fix loading of "Group activity by type" | ||||
| * ([#190](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/190)) Export: fix loading of "group activity by reasons" | ||||
| * ([#213](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/213)) Export: fix usage of some Collection returned instead of array in export filters | ||||
| * ([#215](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/215)) Use only the string 'both' for gender (with a database migration) | ||||
| * ([#212](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/212)) Clean the database to make working the "Group people by gender" aggregator | ||||
| @@ -1,8 +0,0 @@ | ||||
| ## v2.14.0 - 2023-11-24 | ||||
| ### Feature | ||||
| * ([#161](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/161)) Export: in filter "Filter accompanying period work (social action) by type, goal and result", order the items alphabetically or with the defined order  | ||||
| ### Fixed | ||||
| * ([#141](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/141)) Export: on filter "action by type goals, and results", restore the fields when editing a saved export  | ||||
| * ([#219](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/219)) Export: fix the list of accompanying period work, when the "calc date" is null  | ||||
| * ([#222](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/222)) Fix rendering of custom fields  | ||||
| * Fix various errors in custom fields administration  | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v2.14.1 - 2023-11-29 | ||||
| ### Fixed | ||||
| * Export: fix list person with custom fields  | ||||
| * ([#100](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/100)) Add a paginator to budget elements (resource and charge types) in the admin  | ||||
| * Fix error in ListEvaluation when "handling agents" are alone  | ||||
| @@ -1,11 +0,0 @@ | ||||
| ## v2.15.0 - 2023-12-11 | ||||
| ### Feature | ||||
| * ([#191](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/191)) Add export "number of household associate with an exchange"  | ||||
| * ([#235](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/235)) Export: add dates on the filter "filter course by activity type"  | ||||
| ### Fixed | ||||
| * ([#214](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/214)) Fix error when posting an empty comment on an accompanying period.  | ||||
| * ([#233](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/233)) Fix "filter evaluation by evaluation type" (and add select2 to the list of evaluation types to pick)  | ||||
| * ([#234](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/234)) Fix "filter aside activity by date" | ||||
|   | ||||
| * ([#228](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/228)) Fix export of activity for people created before the introduction of the createdAt column on person (during v1)  | ||||
| * ([#246](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/246)) Do not show activities, evaluations and social work when associated to a confidential accompanying period, except for the users which are allowed to see them  | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v2.15.1 - 2023-12-20 | ||||
| ### Fixed | ||||
| * Fix the household export query to exclude accompanying periods that are in draft state.  | ||||
| ### DX | ||||
| * ([#167](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/167)) Fixed readthedocs compilation by updating readthedocs config file and requirements for Sphinx  | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v2.15.2 - 2024-01-11 | ||||
| ### Fixed | ||||
| * Fix the id_seq used when creating a new accompanying period participation during fusion of two person files  | ||||
| ### DX | ||||
| * Set placeholder to False for expanded EntityType form fields where required is set to False.  | ||||
| @@ -1,15 +0,0 @@ | ||||
| ## v2.16.0 - 2024-02-08 | ||||
| ### Feature | ||||
| * ([#231](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/231)) Create new filter for persons having a participation in an accompanying period during a certain time span  | ||||
| * ([#241](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/241)) [Export][List of accompanyign period] Add two columns: the list of persons participating to the period, and their ids  | ||||
| * ([#244](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/244)) Add capability to generate export about change of steps of accompanying period, and generate exports for this  | ||||
| * ([#253](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/253)) Export: group accompanying period by person participating  | ||||
| * ([#243](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/243)) Export: add filter for courses not linked to a reference address  | ||||
| * ([#229](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/229)) Allow to group activities linked with accompanying period by reason  | ||||
| * ([#115](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/115)) Prevent social work to be saved when another user edited conccurently the social work  | ||||
| * Modernize the event bundle, with some new fields and multiple improvements  | ||||
| ### Fixed | ||||
| * ([#220](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/220)) Fix error in logs about wrong typing of eventArgs in onEditNotificationComment method  | ||||
| * ([#256](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/256)) Fix the conditions upon which social actions should be optional or required in relation to social issues within the activity creation form  | ||||
| ### UX | ||||
| * ([#260](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/260)) Order list of centers alphabetically in dropdown 'user' section admin.  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.16.1 - 2024-02-09 | ||||
| ### Fixed | ||||
| * Force bootstrap version to avoid error in builds with newer version  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.16.2 - 2024-02-21 | ||||
| ### Fixed | ||||
| * Check for null values in closing motive of parcours d'accompagnement for correct rendering of template  | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v2.16.3 - 2024-02-26 | ||||
| ### Fixed | ||||
| * ([#236](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/236)) Fix translation of user job -> 'service' must be 'métier'  | ||||
| ### UX | ||||
| * ([#232](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/232)) Order user jobs and services alphabetically in export filters  | ||||
| @@ -1,9 +0,0 @@ | ||||
| ## v2.17.0 - 2024-03-19 | ||||
| ### Feature | ||||
| * ([#237](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/237)) New export filter for social actions with an evaluation created between two dates  | ||||
| * ([#258](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/258)) In the list of accompangying period, add the list of person's centers and the duration of the course  | ||||
| * ([#238](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/238)) Allow to customize list person with new fields  | ||||
| * ([#159](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/159)) Admin can publish news on the homepage | ||||
| ### Fixed | ||||
| * ([#264](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/264)) Fix languages: load the languages in all availables languages configured for Chill  | ||||
| * ([#259](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/259)) Keep a consistent behaviour between the filtering of activities within the document generation (model "accompanying period with activities"), and the same filter in the list of activities for an accompanying period  | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v2.18.0 - 2024-03-26 | ||||
| ### Feature | ||||
| * ([#268](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/268)) Improve admin UX to configure document templates for document generation  | ||||
| ### Fixed | ||||
| * ([#267](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/267)) Fix the join between job and user in the user list (admin): show only the current user job  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.18.1 - 2024-03-26 | ||||
| ### Fixed | ||||
| * Fix layout issue in document generation for admin (minor)  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.18.2 - 2024-04-12 | ||||
| ### Fixed | ||||
| * ([#250](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/250)) Postal codes import : fix the source URL and the keys to handle each record  | ||||
| @@ -1,20 +0,0 @@ | ||||
| ## v2.19.0 - 2024-05-14 | ||||
| ### Feature | ||||
| * ([#197](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/197)) Make the script which subscribe to microsoft calendars changes more tolerant to errors or missing configuration on the microsoft side | ||||
| * ([#276](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/276)) Take closing date into account when computing the geographical unit on accompanying period. When a person moved after an accompanying period is closed, the date of closing accompanying period is took into account if it is earlier than the date given by the user. | ||||
| ### Fixed | ||||
| * ([#270](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/270)) Fix broken link in homepage when a evaluation from a closed acc period was present in the homepage widget | ||||
| * ([#275](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/275)) Allow the filter "filter accompanying period by geographical unit" to take period's location on address into account | ||||
| ### UX | ||||
| * Form for document generation moved to the top of document list page | ||||
| * ([#266](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/266)) Event bundle: adjust certain graphical issues for better user experience | ||||
|  | ||||
|  | ||||
| ### Traduction francophone des principaux changements | ||||
|  | ||||
| - script de synchronisation des agendas de microsoft Outlook: le script est plus tolérant aux erreurs de configuration côté serveur (manque de droit d'accès); | ||||
| - dans les statistiques sur les parcours d'accompagnements, regroupement et filtre par unité géographique: lorsque la date de prise en compte de l'adresse est postérieure à la fermeture du parcours, c'est la date de fermeture du parcours qui est prise en compte (cela permet de tenir compte de la localisation de l'usager au moment de la fermeture dans le cas où celui-ci aurait déménagé par la suite); | ||||
| - sur la page d'accueil, il n'y a plus de rappel pour les évaluations pour les parcours cloturés; | ||||
| - correction du filtre "filtrer par zone géographique" | ||||
| - répétition du bouton pour générer un document en haut de la page "liste des documents", quand il y a plus de cinq documents; | ||||
| - module événement: améliorerations graphiques | ||||
| @@ -1,12 +0,0 @@ | ||||
| ## v2.2.0 - 2023-06-18 | ||||
| ### Feature | ||||
| * When navigating from a workflow regarding to an evaluation's document to an accompanying course, scroll directly to the document, and blink to highlight this document | ||||
| * Add notification to accompanying period work and work's evaluation's documents | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113))[Export] Filter accompanying period by step at date: allow to pick multiple steps | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113))[export] add a filter on accompanying period: filter by step between two dates | ||||
| ### Fixed | ||||
| * use the correct annotation for the association between PersonCurrentCenter and Person | ||||
| * ([#58](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/58))Fix birthdate timezone in PersonRenderBox | ||||
| * ([#55](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/55))Fix the notification counter | ||||
| ### DX | ||||
| * DQL function OVERLAPSI: simplify expression in postgresql | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.2.1 - 2023-06-19 | ||||
| ### Fixed | ||||
| * ([#114](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/114)) [notification on document evaluation] fix entityId and return path when adding a notification on a document in an evaluation | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v2.2.2 - 2023-06-26 | ||||
| ### Fixed | ||||
| * [Accompanying period comments]: order comments from the most recent to the oldest, in the list | ||||
| * Api: filter social action to keep only the currently activated | ||||
| * ([#82](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/82)) Fix deletion and re-creation of filiation relationship | ||||
| @@ -1,21 +0,0 @@ | ||||
| ## v2.20.0 - 2024-06-05 | ||||
| ### Fixed | ||||
| * ([#170](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/170)) Display agents traitants instead of accompanying period referrer in export list social actions. | ||||
| * Added translations for choices of durations (> 5 hours) | ||||
| ### Feature | ||||
| * ([#145](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/145)) Allow to open documents in LibreOffice locally (need configuration within security); | ||||
|  | ||||
|   This endpoint should be added to make the endpoint works properly: | ||||
|  | ||||
|   ```yaml | ||||
|   security: | ||||
|       firewalls: | ||||
|           dav: | ||||
|                pattern: ^/dav | ||||
|                provider: chain_provider | ||||
|                stateless: true | ||||
|                guard: | ||||
|                    authenticators: | ||||
|                        - Chill\DocStoreBundle\Security\Guard\JWTOnDavUrlAuthenticator | ||||
|  | ||||
|   ``` | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.20.1 - 2024-06-05 | ||||
| ### Fixed | ||||
| * Do not allow StoredObjectCreated for edit and convert buttons  | ||||
| @@ -1,31 +0,0 @@ | ||||
| ## v2.21.0 - 2024-06-18 | ||||
| ### Feature | ||||
| * Add flash menu buttons in search results, to open directly a new calendar, or a new activity in an accompanying period | ||||
| * ([#122](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/122)) Improve the list of calendar in the search results: make all calendar clicable, and display a list of calendars | ||||
| * ([#282](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/282)) [export] add start date and end date on filters "filter course by referrer job" and "filter course by referrer scope" | ||||
| * ([#282](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/282)) [export] the aggregator "Group by referrer" now accept a date range. | ||||
| * ([#282](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/282)) [export] add date range on "group course by referrer's scope" | ||||
| * ([#282](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/282)) [export] add date range on "group course by referrer's jobs" | ||||
| * ([#168](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/168) In the UX, display user job and service at the time when he performs an action: | ||||
|   now, the job and service is shown: | ||||
|   * at the activity's date, | ||||
|   * at the appointment's date, | ||||
|   * when the user is marked as referrer for an accompanying period work, | ||||
|   * when the user apply a transition in a workflow, | ||||
|   * when the user updates or creates "something" ("created/updated by ... at ..."), | ||||
|   * or when he wrote a comment, | ||||
|   * … | ||||
|  | ||||
| ### Traduction francophone | ||||
| * Ajout d'un menu "flash" dans les résultats de recherche, pour créer un rendez-vous ou un échange dans un parcours depuis les résultats de recherche; | ||||
| * Améliore la liste des rendez-vous dans les résultats de recherche: les rendez-vous sont cliquables; | ||||
| * [exports] Ajout d'intervalles de dates pour des filtres et regroupements des parcours par référent, métier du référent, service du référent; | ||||
| * Affiche le métier et le service des utilisateurs à la date à laquelle il a exécuté une action. Le métier et le service est affiché: | ||||
|   * à la date d'un échange, | ||||
|   * au jour d'un rendez-vous, | ||||
|   * quand l'utilisateur est devenu référent d'un parcours d'accompagnement, | ||||
|   * quand il a appliqué une transition sur un workflow, | ||||
|   * quand il a mise à jour ou créé une fiche, dans les mentions "créé / mise à jour par ..., le ...", | ||||
|   * quand il a mis à jour un commentaire, | ||||
|   * … | ||||
|  | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v2.22.0 - 2024-06-25 | ||||
| ### Feature | ||||
| * ([#216](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/216)) [event bundle] exports  added for the event module | ||||
|  | ||||
| ### Traduction francophone | ||||
| * Exports sont ajoutés pour la module événement. | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v2.22.1 - 2024-07-01 | ||||
| ### Fixed | ||||
| * Remove debug word  | ||||
| ### DX | ||||
| * Add a command for reading official address DB from Luxembourg and update chill addresses  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.22.2 - 2024-07-03 | ||||
| ### Fixed | ||||
| * Remove scope required for event participation stats  | ||||
| @@ -1,30 +0,0 @@ | ||||
| ## v2.23.0 - 2024-07-23 & 2024-07-19 | ||||
| ### Feature | ||||
| * ([#221](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/221)) [DX] move async-upload-bundle features into chill-bundles | ||||
| * Add job bundle (module emploi) | ||||
| * Upgrade import of address list to the last version of compiled addresses of belgian-best-address | ||||
|  | ||||
| * Upgrade CKEditor and refactor configuration with use of typescript | ||||
|  | ||||
| * ([#123](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/123)) Add a button to duplicate calendar ranges from a week to another one | ||||
| * [admin] filter users by active / inactive in the admin user's list | ||||
| * ([#273](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/273)) Add the possibility to mark all notifications as read | ||||
|  | ||||
|  | ||||
| * Handle duplicate reference id in the import of reference addresses | ||||
| * Do not update the "createdAt" column when importing postal code which does not change | ||||
| * Display filename on file upload within the UI interface | ||||
| ### Fixed | ||||
| * Fix resolving of centers for an household, which will fix in turn the access control | ||||
| * Resolved type hinting error in activity list export | ||||
| * ([#271](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/271)) Take into account the acp closing date in the acp works date filter | ||||
|  | ||||
| ### Traduction française des principaux changements | ||||
| - Ajout d'un bouton pour dupliquer les périodes de disponibilités d'une semaine à une autre; | ||||
| - dans l'interface d'administration, filtre sur les utilisateurs actifs. Par défaut, seul les utilisateurs | ||||
|   actifs sont affichés; | ||||
| - Nouveau bouton pour indiquer toutes les notifications comme lues; | ||||
| - Améliorations sur l'import des adresses et des codes postaux; | ||||
| - Affiche le nom du fichier déposé quand on téléverse un fichier depuis le poste de travail local; | ||||
| - Agrandit l'icône du type de fichier dans l'interface de dépôt de fichier; | ||||
| - correction: tient compte de la date de fermeture du parcours dans les filtres sur les actions d'accompagnement. | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.24.0 - 2024-09-11 | ||||
| ### Feature | ||||
| * ([#306](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/306)) When a document is converted or downloaded in the browser, this document is removed from the browser memory after 45s. Future click on the button re-download the document.  | ||||
| @@ -1,42 +0,0 @@ | ||||
| ## v2.3.0 - 2023-06-27 | ||||
| ### Feature | ||||
| * ([#110](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/110)) Edit saved exports options: the saved exports options (forms, filters, aggregators) are now editable. | ||||
| * ([#103](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/103)) Get an unified list of document in person and accompanying period context | ||||
| * [export] Set the default date of calculation of the accompanying period's list as "today" | ||||
| * Force accompanying period user history to be unique for the same period and stardate/enddate [:warning: may encounter migration issue] | ||||
|  | ||||
|   If some issue is encountered during migration, use this SQL to find the line which are in conflict, examine the problem and delete some of the concerning line | ||||
| * | ||||
|   ```sql | ||||
|   -- to see the line which are in conflict with another one | ||||
|   SELECT o.* | ||||
|   FROM chill_person_accompanying_period_user_history o | ||||
|   JOIN chill_person_accompanying_period_user_history c ON o.id < c.id AND o.accompanyingperiod_id = c.accompanyingperiod_id | ||||
|   WHERE tsrange(o.startdate, o.enddate, '[)') && tsrange(c.startdate, c.enddate, '[)') | ||||
|   ORDER BY accompanyingperiod_id; | ||||
|   -- to examine line in conflict for a given accompanyingperiod_id (given by the previous query) | ||||
|   SELECT * FROM chill_person_accompanying_period_user_history WHERE accompanyingperiod_id = IIIIDDDD order by startdate, enddate; | ||||
|   ``` | ||||
| * Rename label of filter in French: "parcours actif" => "parcours ouvert", and "filtrer les parcours ouverts" => "Filtrer les parcours dont la date d'ouverture" | ||||
|  | ||||
| ### Traduction francophone des principaux changements | ||||
|  | ||||
| * Les exports enregistrés sont éditables par l'utilisateur; | ||||
| * L'onglet "Document" dans les parcours et les dossiers d'usager affiche désormais les documents ajoutés à différents endroits. | ||||
|  | ||||
|   Pour les parcours, il s'agit de: | ||||
|  | ||||
|   - documents ajoutés directement dans le parcours; | ||||
|   - documents des échanges; | ||||
|   - documents des rendez-vous; | ||||
|   - documents des évaluations; | ||||
|   - documents directement ajoutés dans le dossier des usagers concernés par le parcours; | ||||
|  | ||||
|   Pour les usagers, il s'agit de: | ||||
|  | ||||
|   - documents des échanges; | ||||
|   - documents des parcours; | ||||
|   - documents des rendez-vous; | ||||
|   - documents des actions, des échanges, des rendez-vous, des évaluations ajoutés dans les parcours. | ||||
| * Dans la liste des parcours, la date de calcul des éléments associés est "aujourd'hui" par défaut. | ||||
| * Dans les exports, renommage des libellés des filtres: "parcours actif" => "parcours ouvert", et "filtrer les parcours ouverts" => "Filtrer les parcours dont la date d'ouverture" | ||||
| @@ -1,36 +0,0 @@ | ||||
| ## v2.4.0 - 2023-07-07 | ||||
|  | ||||
| ### Feature | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113)) [export] on "filter by user working" on accompanying period, add two dates to filters intervention within a period | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113)) [export] Add an aggregator by user's job working on a course | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113)) [export] add an aggregator by user's scope working on a course | ||||
| * [export] on aggregator "user working on a course" | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113)) [export] add a center aggregator for Person | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113)) [export] add a filter on "job working on a course" | ||||
| * ([#113](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/113)) [export] Add a filter on "scope working on a course" | ||||
| * ([#121](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/121)) Create a role "See Confidential Periods", separated from the "Reassign courses" role | ||||
| * ([#124](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/124)) Sync user absence / presence through microsoft outlook / graph api. | ||||
|  | ||||
| ### Fixed | ||||
| * ([#116](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/116)) On the accompanying course page, open the action on view mode if the user does not have right to update them (i.e. if the accompanying period is closed) | ||||
| * [export] Rename label for CurrentActionFilter (on accompanying period work) to make precision between "ouvert" and "sans date de fin" | ||||
| * Force the db to have either a person_location or a address_location, and avoid to have both also internally in the entity | ||||
| * [export] set rolling date on person age aggregator | ||||
| * [export] fix list when a person locating a course is without address | ||||
| * [export] remove unused condition on course about duration participation | ||||
| * Command to subscribe on MS Graph users calendars: improve the loop to be more efficient | ||||
|  | ||||
| ### DX | ||||
| * Rolling Date: can receive a null parameter | ||||
|  | ||||
| ### Traduction francophone des principaux changements | ||||
|  | ||||
| - sur le "filtre par intervenant", ajoute deux dates pour limiter la période d'intervention; | ||||
| - ajout d'un regroupement par métier des intervenants sur un parcours; | ||||
| - ajout d'un regroupement par service des intervenants sur un parcours; | ||||
| - ajout d'un regroupement par utilisateur intervenant sur un parcours | ||||
| - ajout d'un regroupement "par centre de l'usager"; | ||||
| - ajout d'un filtre "par métier intervenant sur un parcours"; | ||||
| - ajout d'un filtre "par service intervenant sur un parcours"; | ||||
| - création d'un rôle spécifique pour voir les parcours confidentiels (et séparer de celui de la liste qui permet de ré-assigner les parcours en lot); | ||||
| - synchronisation de l'absence des utilisateurs par microsoft graph api | ||||
| @@ -1,39 +0,0 @@ | ||||
| ## v2.5.0 - 2023-07-14 | ||||
| ### Feature | ||||
| * Allow filtering on the basis of a user within general tasks lists | ||||
| * ([#120](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/120)) Adding OrderFilter to the list of social actions. | ||||
| * ([#125](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/125)) [export] Add a list for people with their associated course | ||||
| * [export] Add ordering by person's lastname or course opening date in list which concerns accompanying course or peoples | ||||
| * ([#128](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/128)) [Export] allow to group activities by localisation | ||||
| * ([#129](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/129)) [export] Add a filter "filter course having an activity between two dates" | ||||
| * ([#112](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/112)) [addresses] Add a cronjob to re-associate addresses with addresses reference every 6 hours | ||||
| * Improve filtering layout | ||||
|  | ||||
| ### Fixed | ||||
| * reimplement the visualization of all calculator results | ||||
| * ([#117](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/117)) Repair my unread notification list with actions and evaluations documents | ||||
| * ([#126](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/126)) Correct bug in thirdparty API search query: simplify address joins clause for child and parent kind | ||||
|  | ||||
| ### DX | ||||
| * Documentation for database principles | ||||
| * [cronjob] when a cronjob is executed, it may return an array of data that will be passed as argument on the next execution | ||||
|  | ||||
| ### UX | ||||
| * ([#93](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/93)) Better integration of address details button: look, position, title tag | ||||
| * ([#93](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/93)) Show address detail button on person and household banners | ||||
| * Improve residential address position on show onthefly modale | ||||
|  | ||||
| ### Traduction francophone des principaux changements | ||||
|  | ||||
| * Ajout d'un filtre "par utilisateur" aux pages de tâche | ||||
| * Filtre des actions d'accompagnement par date, type, intervenant | ||||
| * export: liste des usagers concernés avec détail de leurs parcours | ||||
| * export: ajout d'un regroupement des échanges par localisation | ||||
| * export: ajout d'un filtre "parcours ayant reçu un échange entre deux dates" | ||||
| * ajout d'une tâche cron pour associer les adresses à une adresse de référence | ||||
| * correction: réparation de la liste des notifications sur la page d'accueil, dans le cas où une notification concerne une action ou un document dans une évaluation | ||||
| * correction: réparation de la recherche des tiers ayant des codes postaux similaires entre les parents et enfants | ||||
| * meilleure intégration du bouton "détail d'une adresse": améliration de la taille et de la position | ||||
| * bouton permettant de visualiser les détails d'une adresse (modale avec carte) dans la bannière "Usager" et "Ménage" | ||||
| * amélioration de la modale permettant de voir les détails d'un usager: les adresses de résidence sont dans la continuité des autres adresses, et non plus dans une colonne séparée | ||||
| * améliore le design et l'expérience utilisateur des filtres | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.5.1 - 2023-07-14 | ||||
| ### Fixed | ||||
| * [collate addresses] block collating addresses to another address reference where the address reference is already the best match  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.5.2 - 2023-07-15 | ||||
| ### Fixed | ||||
| * [Collate Address] when updating address point, do not use the point's address reference if the similarity is below the requirement for associating the address reference and the address (it uses the postcode's center instead)  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.5.3 - 2023-07-20 | ||||
| ### Fixed | ||||
| * ([#132](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/132)) Rendez-vous documents created would appear in all documents lists of all persons with an accompanying period. Or statements are now added to the where clause to filter out documents that come from unrelated accompanying period/ or person rendez-vous.  | ||||
| @@ -1,21 +0,0 @@ | ||||
| ## v2.6.0 - 2023-09-14 | ||||
| ### Feature | ||||
| * ([#133](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/133)) Add locations in Aside Activity. By default, suggest user location, otherwise a select with all locations.  | ||||
| * ([#133](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/133)) Adapt Aside Activity exports: display location, filter by location, group by location  | ||||
| * Use the CRUD controller for center entity + add the isActive property to be able to mask instances of Center that are no longer in use.  | ||||
| ### Fixed | ||||
| * ([#107](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/107)) reinstate the fusion of duplicate persons  | ||||
| * Missing translation in Work Actions exports  | ||||
| * Reimplement the mission type filter on tasks, only for instances that have a config parameter indicating true for this.  | ||||
| * ([#135](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/135)) Corrects a typing error in 2 filters, which caused an  | ||||
| error when trying to reedit a saved export | ||||
|  | ||||
|   | ||||
| * ([#136](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/136)) [household] when moving a person to a sharing position to a not-sharing position on the same household on the same date, remove the previous household membership on the same household. This fix duplicate member.  | ||||
| * Add missing translation for comment field placeholder in repositionning household editor. | ||||
|   | ||||
| * Do not send an email to creator twice when adding a comment to a notification  | ||||
| * ([#107](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/107)) Fix gestion doublon functionality to work with chill bundles v2  | ||||
| ### UX | ||||
| * Uniformize badge-person in household banner (background, size) | ||||
|   | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.6.1 - 2023-09-14 | ||||
| ### Fixed | ||||
| * Filter out active centers in exports, which uses a different PickCenterType.  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.6.2 - 2023-09-18 | ||||
| ### Fixed | ||||
| * Fix doctrine mapping of AbstractTaskPlaceEvent and SingleTaskPlaceEvent: id property moved.  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v2.6.3 - 2023-09-19 | ||||
| ### Fixed | ||||
| * Remove id property from document  | ||||
| mappedsuperclass  | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v2.7.0 - 2023-09-27 | ||||
| ### Feature | ||||
| * ([#155](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/155)) The regulation list load accompanying periods by exact postal code (address associated with postal code), and not by the content of the postal code (postal code with same code's string)  | ||||
| ### Fixed | ||||
| * ([#142](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/142)) Fix the label of filter ActivityTypeFilter to a more obvious one  | ||||
| * ([#140](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/140)) [export] Fix association of filter "filter location by type" which did not appears on "list of activities"  | ||||
| @@ -1,19 +0,0 @@ | ||||
| ## v2.8.0 - 2023-10-05 | ||||
|  | ||||
| ### Feature | ||||
|  | ||||
| * ([#162](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/162)) Reassigning list: when reassigning courses to a new user, the job associated with the course become the one of the new user (if any) | ||||
| * Reassining list: the length of the list is increased to 100 courses | ||||
|  | ||||
| ### Fixed | ||||
|  | ||||
| * ([#143](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/143)) Fix filter "accompanying course by social action" to avoid duplication in list | ||||
| * ([#164](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/164)) View a third party: avoid errors when a contact has a civility | ||||
| * ([#163](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/163)) Fix the filters and aggregators on exports "count peoples" | ||||
| * ([#143](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/143)) From the database, avoid the creation of location history for same period and at same dates | ||||
|  | ||||
| ### Traduction francophone des principaux changements | ||||
|  | ||||
| - Fonctionnalité: Réassigner les parcours en lot: lorsque des parcours sont réassignés "en lot", les parcours sont maintenant associés au métier du nouveau référent; | ||||
| - Correction: certaines causes qui créaient des doublons dans les listes ont été corrigées; | ||||
| - Correction des associations entre l'export "nombre de personnes" et les filtres et regroupements associés | ||||
| @@ -1,23 +0,0 @@ | ||||
| ## v2.9.0 - 2023-10-17 | ||||
| ### Feature | ||||
| * ([#147](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/147)) Add history to scopes and to jobs in administrator section. When user job or main scope of user is changed, automaticaly add a new row in history. | ||||
| * ([#146](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/146)) Allow closing motives to be identified as 'canceling the accompanying period' + don't take canceled accompanying periods into account | ||||
| * [export] add an aggregator for activities: group by job scope's creator aggregator | ||||
| * DX: prepare the code for the upgrade to symfony 5.4 | ||||
|  | ||||
| ### Traductions francophones des principaux changements | ||||
|  | ||||
| - ajout de l'historique des services et métiers pour les utilisateurs. Les exports, filtres et regroupements sont adaptés pour tenir compte du métier et du service | ||||
|   de l'utilisateur au moment de l'échange, de sa désignation comme agent traitant de l'échange ou du moment du rendez-vous ([#147](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/147))) | ||||
| - modification des motifs de cloture des parcours: ajout d'un chanmp "annule le parcours", qui permet d'indiquer que le motif "annule" le parcours. Les parcours annulés n'apparaissent | ||||
|   pas dans les statistiques | ||||
| - ajouter d'un regroupement pour les échanges: grouper par métier et service du créateur de l'échange | ||||
|  | ||||
|  | ||||
| ### Possible BC break in configuration | ||||
|  | ||||
| This release remove the use of deprecated package [symfony/templating](https://symfony.com/components/Templating). | ||||
|  | ||||
| If you use this package in your own bundle (usually `src/` directory, or other dependencies), you should add this dependencies in your local composer.json (`composer require symfony/templating`). | ||||
|  | ||||
| But if you do not need this any more, you must ensure that the configuration key `framework.templating` is removed. This is usually located into `config/packages/framework.yaml`. [See here an example](https://gitea.champs-libres.be/Chill-project/chill-skeleton-basic/commit/cc716beaecc239e6a189f3db62ea95f169a37505#diff-df607fe73ff82c569824a7392edf5e760e998efe) | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.9.1 - 2023-10-17 | ||||
| ### Fixed | ||||
| * Fix the handling of activity form when editing or creating an activity in an accompanying period with multiple centers  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v2.9.2 - 2023-10-17 | ||||
| ### Fixed | ||||
| * Fix possible null values in string's entities  | ||||
| @@ -1,5 +0,0 @@ | ||||
| ## v3.0.0 - 2024-08-26 | ||||
| ### Fixed | ||||
| * Fix delete action for accompanying periods in draft state  | ||||
| * Fix connection to azure when making an calendar event in chill  | ||||
| * CollectionType js fixes for remove button and adding multiple entries  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.1.0 - 2024-08-30 | ||||
| ### Feature | ||||
| * Add export aggregator to aggregate activities by household + filter persons that are not part of an accompanyingperiod during a certain timeframe.  | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v3.1.1 - 2024-10-01 | ||||
| ### Fixed | ||||
| * ([#308](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/308)) Show only the current referrer in the page "show" for an accompanying period workf  | ||||
| * ([#309](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/309)) Correctly compute the grouping by referrer aggregator | ||||
|   | ||||
| * Fixed typing of custom field long choice and custom field group  | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v3.10.0 - 2025-03-17 | ||||
| ### Feature | ||||
| * ([#363](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/363)) Display social actions grouped per social issue within activity form    | ||||
| ### Fixed | ||||
| * ([#362](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/362)) Fix Dependency Injection, which prevented to save the CalendarRange    | ||||
| * ([#368](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/368)) fix search query for user groups    | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.10.1 - 2025-03-17 | ||||
| ### DX | ||||
| * Remove yarn dependency to symfony/ux-translator, to ease the build process | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.10.2 - 2025-03-17 | ||||
| ### Fixed | ||||
| * Replace a ts-expect-error with a ts-ignore    | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.10.3 - 2025-03-18 | ||||
| ### DX | ||||
| * Eslint fixes    | ||||
| @@ -1,19 +0,0 @@ | ||||
| ## v3.11.0 - 2025-04-17 | ||||
| ### Feature | ||||
| * ([#365](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/365)) Add counters of actions and activities, with 2 boxes to (1) show the number of active actions on total actions and (2) show the number of activities in a accompanying period, and pills in menus for showing the number of active actions and the number of activities. | ||||
| * ([#364](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/364)) Added a second phone number "telephone2" to the thirdParty entity. Adapted twig templates and vuejs apps to handle this phone number | ||||
|  | ||||
|   **Schema Change**: Add columns or tables | ||||
| * Signature: add a button to go directly to the signature zone, even if there is only one | ||||
| ### Fixed | ||||
| * Fixed wrong translations in the on-the-fly for creation of thirdParty | ||||
| * Fixed update of phone number in on-the-fly edition of thirdParty | ||||
| * Fixed closing of modal when editing thirdParty in accompanying course works | ||||
| * Shorten the delay between two execution of AccompanyingPeriodStepChangeCronjob, to ensure at least one execution in a day | ||||
| * ([#102](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/102)) Fix display of title in document list | ||||
| * When cleaning the old stored object versions, do not throw an error if the stored object is not found on disk | ||||
| * Add consistent log prefix and key to logs when stale workflows are automatically canceled | ||||
| * ([#380](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/380)) Remove the "not null" validation constraint on recently added properties on HouseholdComposition | ||||
|  | ||||
| ### DX | ||||
| * Add new chill-col style for displaying title and aside in a flex table | ||||
| @@ -1,22 +0,0 @@ | ||||
| ## v3.12.0 - 2025-06-30 | ||||
| ### Feature | ||||
| * ([#377](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/377)) Add the document file name to the document title when a user upload a document, unless there is already a document title.    | ||||
| * Add desactivation date for social action and issue csv export    | ||||
| * Add Emoji and Fullscreen feature to ckeditor configuration    | ||||
| * ([#321](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/321)) Create editor which allow us to toggle between rich and simple text editor    | ||||
| * Do not remove workflow which are automatically canceled after staling for more than 30 days    | ||||
| ### Fixed | ||||
| * ([#376](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/376)) trying to prevent bug of typeerror in doc-history + improved display of document history    | ||||
| * ([#381](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/381)) Display previous participation in acc course work even if the person has left the acc course    | ||||
| * ([#372](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/372)) Fix display of text in calendar events    | ||||
| * Add missing translation for user_group.no_user_groups    | ||||
| * Fix admin entity edit actions for event admin entities and activity reason (category) entities    | ||||
| * ([#392](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/392)) Allow null and cast as string to setContent method for NewsItem | ||||
|     | ||||
| * ([#393](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/393)) Doc Generation: the "dump only" method send the document as an email attachment.    | ||||
| ### DX | ||||
| * ([#352](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/352)) Remove dead code for wopi-link module    | ||||
| * Replace library node-sass by sass, and upgrade bootstrap to version 5.3 (yarn upgrade / install is required)    | ||||
| ### UX | ||||
| * ([#374](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/374)) Remove default filter in_progress for the page 'my tasks'; Allows for new tasks to be displayed upon opening of the page    | ||||
| * Improve labeling of fields in person resource creation form    | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.12.1 - 2025-06-30 | ||||
| ### Fixed | ||||
| * Fix loading of the list of documents    | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.2.0 - 2024-10-30 | ||||
| ### Feature | ||||
| * Introduce a gender entity  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v3.2.1 - 2024-10-31 | ||||
| ### Fixed | ||||
| * Add the possibility of unknown to the gender entity  | ||||
| * Fix the fusion of person doubles by excluding accompanyingPeriod work entities to be deleted. They are moved instead.  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.2.2 - 2024-10-31 | ||||
| ### Fixed | ||||
| * Fix gender translation for unknown  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v3.2.3 - 2024-11-05 | ||||
| ### Fixed | ||||
| * ([#315](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/315)) Fix display of accompanying period work referrers. Only current referrers should be displayed. | ||||
| Fix color of Chill footer  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.2.4 - 2024-11-06 | ||||
| ### Fixed | ||||
| * Fix compilation of chill assets  | ||||
| @@ -1,13 +0,0 @@ | ||||
| ## v3.3.0 - 2024-11-20 | ||||
| ### Feature | ||||
| * Electronic signature | ||||
|  | ||||
| Implementation of the electronic signature for documents within chill.  | ||||
| * ([#286](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/286)) The behavoir of the voters for stored objects is adjusted so as to limit edit and delete possibilities to users related to the activity, social action or workflow entity.  | ||||
| * ([#288](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/288)) Metadata form added for person signatures  | ||||
| * Add a signature step in workflow, which allow to apply an electronic signature on documents  | ||||
| * Keep an history of each version of a stored object.  | ||||
| * Add a "send external" step in workflow, which allow to send stored objects and other elements to remote people, by sending them a public url  | ||||
| ### Fixed | ||||
| * Adjust household list export to include households even if their address is NULL  | ||||
| * Remove validation of date string on deathDate  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v3.4.0 - 2024-11-20 | ||||
| ### Feature | ||||
| * ([#314](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/314)) Admin: improve document type admin form with a select field for related class. | ||||
| Admin: Allow administrator to assign multiple group centers in one go to a user.  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.4.1 - 2024-11-22 | ||||
| ### Fixed | ||||
| * Set the workflow's title to notification content and subject  | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v3.4.2 - 2024-12-05 | ||||
| ### Fixed | ||||
| * ([#329](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/329)) Fix the serialization of gender for the generation of documents  | ||||
| * ([#337](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/337)) Enforce unique contraint on activity storedobject  | ||||
| ### DX | ||||
| * ([#310](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/310)) Clean migrations, to reduce the number of bloated migration when running diff on schema  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v3.4.3 - 2024-12-05 | ||||
| ### Fixed | ||||
| * Remove the "not null" constraint on person supplementary phones | ||||
| * Remove doctrine annotation that prevent from adding documents to activities | ||||
| @@ -1,6 +0,0 @@ | ||||
| ## v3.5.0 - 2024-12-09 | ||||
| ### Feature | ||||
| * ([#318](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/318)) Show all the pages of the documents in the signature app  | ||||
| ### Fixed | ||||
| * Wrap the signature's change state into a transaction, to avoid race conditions  | ||||
| * Fix display of gender label  | ||||
| @@ -1,4 +0,0 @@ | ||||
| ## v3.5.1 - 2024-12-16 | ||||
| ### Fixed | ||||
| * Filiation: fix the display of the gender label in the graph  | ||||
| * Wrap handling of PdfSignedMessage into transactions  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.5.2 - 2024-12-19 | ||||
| ### Fixed | ||||
| * ([#345](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/345)) Export: activity filtering of users that were associated to an activity between certain dates. Results contained activities that were not within the specified date range"  | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.5.3 - 2025-01-07 | ||||
| ### Fixed | ||||
| * Fix the EntityToJsonTransformer to return an empty array if the value is ""  | ||||
| @@ -1,9 +0,0 @@ | ||||
| ## v3.6.0 - 2025-01-16 | ||||
| ### Feature | ||||
| * Importer for addresses does not fails when the postal code is not found with some addresses, and compute a recap list of all addresses that could not be imported. This recap list can be send by email.  | ||||
| * ([#346](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/346)) Create a driver for storing documents on disk (instead of openstack object store) | ||||
|   | ||||
| * Add address importer from french Base d'Adresse Nationale (BAN)  | ||||
| * ([#343](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/343)) Add csv export for social issues and social actions  | ||||
| ### Fixed | ||||
| * Export: fix missing alias in activity between certain dates filter. Condition added for alias.  | ||||
| @@ -1,62 +0,0 @@ | ||||
| ## v3.7.0 - 2025-01-21 | ||||
| ### Feature | ||||
| * Use the Notifier component from Symfony to sens short messages (SMS). This allow to use more provider. | ||||
| ### Fixed | ||||
| * ([#348](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/348)) [export] Fix aggregation of referrer's scope and job: fix the date range comparison | ||||
|  | ||||
| ### Warning on configuration of Notifier component | ||||
|  | ||||
| If installed in an symfony app where the recipes are activated, this configuration should be added automatically: | ||||
|  | ||||
| ```yaml | ||||
| framework: | ||||
|     notifier: | ||||
|         chatter_transports: | ||||
|         texter_transports: | ||||
|             ovhcloud: '%env(OVHCLOUD_DSN)%' | ||||
|         channel_policy: | ||||
|             # use chat/slack, chat/telegram, sms/twilio or sms/nexmo | ||||
|             urgent: ['email'] | ||||
|             high: ['email'] | ||||
|             medium: ['email'] | ||||
|             low: ['email'] | ||||
|         admin_recipients: | ||||
|             - { email: admin@example.com } | ||||
| ``` | ||||
|  | ||||
| Actually, you should either: | ||||
|  | ||||
| - remove the configuration of ovhcloud added by the recipe | ||||
| - or remove the previous configuration of chill, to avoid keeping legacy configuration | ||||
|  | ||||
| #### Remove the added configuration and keep the legacy configuration | ||||
|  | ||||
| To remove the configuration: | ||||
|  | ||||
| ```diff | ||||
| framework: | ||||
|     notifier: | ||||
|         chatter_transports: | ||||
|         texter_transports: | ||||
| -            ovhcloud: '%env(OVHCLOUD_DSN)%' | ||||
| ``` | ||||
|  | ||||
| In that case, the previous configuration, which was stored under the `chill_main.short_messages.dsn` will be reconfigured into the Notifier component's configuration. | ||||
|  | ||||
| #### Properly configure SMS | ||||
|  | ||||
| You can also properly configure it, as [described in the OVH cloud provider repository](https://github.com/symfony/ovh-cloud-notifier/tree/5.4?tab=readme-ov-file#dsn-example) (where the scheme is `ovhcloud`): | ||||
|  | ||||
| **NOTE**: You have access to all notifier available with the [Notifier component](https://symfony.com/doc/current/notifier.html#notifier-sms-channel). You are not restricted to use OVH as a provider. | ||||
|  | ||||
| ```diff | ||||
| framework: | ||||
|     notifier: | ||||
|         chatter_transports: | ||||
|         texter_transports: | ||||
| +            ovhcloud: '%env(OVHCLOUD_DSN)%' # this value should be located in a variable, and have `ovhcloud://` as a scheme | ||||
|  | ||||
| chill_main: | ||||
| -    short_messages: | ||||
| -        dsn: '%env(string:SHORT_MESSAGE_DSN)%' | ||||
| ``` | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.7.1 - 2025-01-21 | ||||
| ### Fixed | ||||
| * Fix legacy configuration processor for notifier component    | ||||
| @@ -1,11 +0,0 @@ | ||||
| ## v3.8.0 - 2025-02-03 | ||||
| ### Feature | ||||
| * Improve the UX of the news item admin form to prevent wrong usage | ||||
| * ([#319](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/319)) Notification list: display the concerned person's badges in the list | ||||
| * ([#320](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/320)) Show the first 3 persons directly in the accompanying period's banner | ||||
| * ([#334](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/334)) Suggest current user when creating an activity | ||||
| * ([#331](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/331)) Add attachments to workflows | ||||
| ### Fixed | ||||
| * ([#350](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/350)) Add validation error to manual selection of person in PersonDuplicateController | ||||
| * ([#354](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/354)) Fix document category creation | ||||
| * ([#351](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/351)) Add definitive whitespace between span elements in vue PersonText component | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.8.1 - 2025-02-05 | ||||
| ### Fixed | ||||
| * Fix household link in the parcours banner    | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.8.2 - 2025-02-10 | ||||
| ### Fixed | ||||
| * ([#358](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/358)) Remove "filter" button on list of documents in the workflow's "add attachement" modal    | ||||
| @@ -1,10 +0,0 @@ | ||||
| ## v3.9.0 - 2025-02-27 | ||||
| ### Feature | ||||
| * ([#349](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/349)) Suggest all referrers within actions of the accompanying period when creating an activity    | ||||
| * ([#343](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/343)) Add possibility to export a csv with all social issues and social actions    | ||||
| * ([#360](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/360)) Restore document to previous kept version when a workflow is canceled    | ||||
| * ([#341](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/341)) Add a list of third parties from within the admin (csv download)    | ||||
| ### Fixed | ||||
| * fix generation of document with accompanying period context, and list of activities and works    | ||||
| ### DX | ||||
| * ([#333](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/333)) Create an unique source of trust for translations    | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.9.1 - 2025-02-27 | ||||
| ### Fixed | ||||
| * Fix post/patch request with missing 'type' property for gender    | ||||
| @@ -1,3 +0,0 @@ | ||||
| ## v3.9.2 - 2025-02-27 | ||||
| ### Fixed | ||||
| * Use fetchResults method to fetch all social issues instead of only the first page    | ||||
| @@ -1,74 +0,0 @@ | ||||
| ## v4.0.0 - 2025-07-08 | ||||
| ### Feature | ||||
| * ([#359](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/359)) Allow the merge of two accompanying period works | ||||
| ### Fixed | ||||
| * ([#390](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/390)) Display the list of participant in the results, even if there is only one participant and that the search result display the requestor | ||||
| * Fix admin entity edit actions for event admin entities and activity reason (category) entities | ||||
| * Fix translations for social action fields in admin form: results, goals, evaluations | ||||
| ### DX | ||||
| * Rewrite exports to run them asynchronously | ||||
|  | ||||
|   **Schema Change**: Add columns or tables | ||||
| * Allow TranslatableMessage in flash messages | ||||
| ### UX | ||||
| * Improve labeling of fields in person resource creation form | ||||
|  | ||||
|  | ||||
| **Release notes** | ||||
|  | ||||
| - Add new methods to serialize data using the rector rule | ||||
| - Remove all references to the Request in filters, aggregators, filters. Actually, the most frequent occurence is `$security->getUser()`. | ||||
| - Refactor manually the initializeQuery method | ||||
| - Remove the injection of ExportManager into the constructor of each export element: | ||||
|  | ||||
|   ```diff | ||||
|  | ||||
|   - class MyFormatter implements FormatterInterface | ||||
|   + class MyFormatter implements FormatterInterface, \Chill\MainBundle\Export\ExportManagerAwareInterface | ||||
|   { | ||||
|   +    use \Chill\MainBundle\Export\Helper\ExportManagerAwareTrait; | ||||
|  | ||||
|   -    public function __construct(private ExportManager $exportmanager) {} | ||||
|  | ||||
|        public function MyMethod(): void | ||||
|        { | ||||
|   -          $this->exportManager->getFilter('alias'); | ||||
|   +          $this->getExportManager()->getFilter('alias'); | ||||
|        } | ||||
|   } | ||||
|   ``` | ||||
| - configure messenger to handle export in a queue: | ||||
|  | ||||
| ```diff | ||||
| # config/packages/messenger.yaml | ||||
| framework: | ||||
|     messenger: | ||||
|         routing: | ||||
| +            'Chill\MainBundle\Export\Messenger\ExportRequestGenerationMessage': priority | ||||
| ``` | ||||
|  | ||||
| - add missing methods to exports, aggregators, filters, formatter: | ||||
|  | ||||
|   ```php | ||||
|   public function normalizeFormData(array $formData): array; | ||||
|  | ||||
|   public function denormalizeFormData(array $formData, int $fromVersion): array; | ||||
|   ``` | ||||
|  | ||||
|   There are rector rules to generate those methods: | ||||
|  | ||||
|   - `Chill\Utils\Rector\Rector\ChillBundleAddNormalizationMethodsOnExportRector` | ||||
|  | ||||
|   See: | ||||
|  | ||||
|   ```php | ||||
|   // upgrade chill exports | ||||
|   $rectorConfig->rules([\Chill\Utils\Rector\Rector\ChillBundleAddNormalizationMethodsOnExportRector::class]); | ||||
|   ``` | ||||
|  | ||||
|   This rule will create most of the work necessary, but some manuals changes are still necessary: | ||||
|  | ||||
|   - we must set manually the correct repository for method `denormalizeDoctrineEntity`; | ||||
|   - when the form data contains some entities, and the form type is not one of EntityType::class, PickUserDynamicType::class, PickUserLocationType::class, PickThirdpartyDynamicType::class, Select2CountryType::class, then we must handle the normalization manually (using the `\Chill\MainBundle\Export\ExportDataNormalizerTrait`) | ||||
|  | ||||
|  | ||||
| @@ -5,31 +5,14 @@ changelogPath: CHANGELOG.md | ||||
| versionExt: md | ||||
| versionFormat: '## {{.Version}} - {{.Time.Format "2006-01-02"}}' | ||||
| kindFormat: '### {{.Kind}}' | ||||
| # Note: it is possible to add a `.custom.Long` text manually into the yaml file produced by `changie new`. This will add a long description. | ||||
| changeFormat: >- | ||||
|     * {{ if not (eq .Custom.Issue "") }}([#{{ .Custom.Issue }}](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/{{ .Custom.Issue }})) {{ end }}{{ .Body }}   {{ if and .Custom.SchemaChange (ne .Custom.SchemaChange "No schema change") }} | ||||
|  | ||||
|       **Schema Change**: {{ .Custom.SchemaChange }} | ||||
|       {{- end -}} | ||||
|  | ||||
|     {{ if and (.Custom.Long) (not (eq .Custom.Long "")) }}{{ .Custom.Long }}{{ end }} | ||||
|  | ||||
|     * {{ if not (eq .Custom.Issue "") }}([#{{ .Custom.Issue }}](https://gitlab.com/Chill-Projet/chill-bundles/-/issues/{{ .Custom.Issue }})) {{- end }}{{.Body}} | ||||
| custom: | ||||
|     - key: SchemaChange | ||||
|       label: Is a schema change required? | ||||
|       optional: false | ||||
|       type: enum | ||||
|       enumOptions: | ||||
|           - "No schema change" | ||||
|           - "Add columns or tables" | ||||
|           - "Drop or rename table or columns, or enforce new constraint that must be manually fixed" | ||||
|  | ||||
|     -   key: Issue | ||||
|         label: Issue number (on chill-bundles repository) (optional) | ||||
|         optional: true | ||||
|         type: int | ||||
|         minInt: 1 | ||||
|  | ||||
| body: | ||||
|     # allow multiline messages | ||||
|     block: true | ||||
| @@ -44,8 +27,6 @@ kinds: | ||||
|         auto: patch | ||||
|     -   label: DX | ||||
|         auto: patch | ||||
|     -   label: UX | ||||
|         auto: patch | ||||
| newlines: | ||||
|     afterChangelogHeader: 1 | ||||
|     beforeChangelogVersion: 1 | ||||
|   | ||||
| @@ -23,7 +23,3 @@ max_line_length = 0 | ||||
| indent_size = 2 | ||||
| indent_style = space | ||||
|  | ||||
| [.rst] | ||||
| ident_size = 3 | ||||
| ident_style = space | ||||
|  | ||||
|   | ||||
							
								
								
									
										94
									
								
								.env
									
									
									
									
									
								
							
							
						
						
									
										94
									
								
								.env
									
									
									
									
									
								
							| @@ -1,94 +0,0 @@ | ||||
| #  * .env                contains default values for the environment variables needed by the app | ||||
| #  * .env.local          uncommitted file with local overrides | ||||
| #  * .env.$APP_ENV       committed environment-specific defaults | ||||
| #  * .env.$APP_ENV.local uncommitted environment-specific overrides | ||||
| # | ||||
| # Real environment variables win over .env files. | ||||
| # | ||||
| # DO NOT DEFINE PRODUCTION SECRETS IN THIS FILE NOR IN ANY OTHER COMMITTED FILES. | ||||
| # https://symfony.com/doc/current/configuration/secrets.html | ||||
| # | ||||
| # Run "composer dump-env prod" to compile .env files for production use (requires symfony/flex >=1.2). | ||||
| # https://symfony.com/doc/current/best_practices.html#use-environment-variables-for-infrastructure-configuration | ||||
|  | ||||
| ###> symfony/framework-bundle ### | ||||
| APP_ENV=prod | ||||
| APP_SECRET=!ChangeMeInAppEnv! | ||||
| ###< symfony/framework-bundle ### | ||||
|  | ||||
| ## Wopi server for editing documents online | ||||
| EDITOR_SERVER=http://collabora:9980 | ||||
|  | ||||
| # must be manually set in .env.local | ||||
| # ADMIN_PASSWORD= | ||||
|  | ||||
| ###> symfony/mailer ### | ||||
| # MAILER_DSN=null://null | ||||
| ###< symfony/mailer ### | ||||
|  | ||||
|  | ||||
| ###> symfony/messenger ### | ||||
| # Choose one of the transports below | ||||
| # MESSENGER_TRANSPORT_DSN=amqp://guest:guest@localhost:5672/%2f/messages | ||||
| # MESSENGER_TRANSPORT_DSN=redis://localhost:6379/messages | ||||
| # MESSENGER_TRANSPORT_DSN=sync:// | ||||
| # MESSENGER_TRANSPORT_DSN=doctrine://default?auto_setup=0 | ||||
| MESSENGER_TRANSPORT_DSN=${RABBITMQ_URL}/%2f | ||||
| ###< symfony/messenger ### | ||||
|  | ||||
| ###> doctrine/doctrine-bundle ### | ||||
| # Format described at https://www.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/configuration.html#connecting-using-a-url | ||||
| # IMPORTANT: You MUST configure your server version, either here or in config/packages/doctrine.yaml | ||||
| # | ||||
| DATABASE_URL="postgresql://postgres:postgres@db:5432/postgres?serverVersion=14&charset=utf8" | ||||
| ###< doctrine/doctrine-bundle ### | ||||
|  | ||||
| ###> lexik/jwt-authentication-bundle ### | ||||
| JWT_SECRET_KEY=%kernel.project_dir%/config/jwt/private.pem | ||||
| JWT_PUBLIC_KEY=%kernel.project_dir%/config/jwt/public.pem | ||||
| JWT_PASSPHRASE=2a30f6ba26521a2613821da35f28386e | ||||
| ###< lexik/jwt-authentication-bundle ### | ||||
|  | ||||
| ###> chill-project/chill-bundles ### | ||||
| # Generate a password using `symfony console security:hash-password --empty-salt <password> 'Symfony\Component\Security\Core\User\User'` and paste it into .env.local file | ||||
| # ADMIN_PASSWORD= | ||||
| # Add a configuration for sending SMS (before calendar appointments, aka "Rendez-vous"). See https://symfony.com/doc/current/notifier.html#sms-channel | ||||
| # Configuration for using ovh custom notifier | ||||
| # SHORT_MESSAGE_DSN="ovh://user:password@ovh-eu?consumer_key=123456&sender=%2B32475123456&service_name=sms-xx123456-1" | ||||
| SHORT_MESSAGE_DSN=null://null | ||||
| # Default locale for the project | ||||
| LOCALE=fr | ||||
| # Those keys are required to configure the access to store documents | ||||
| ASYNC_UPLOAD_TEMP_URL_KEY= | ||||
| ASYNC_UPLOAD_TEMP_URL_BASE_PATH= | ||||
| ASYNC_UPLOAD_TEMP_URL_CONTAINER= | ||||
| # Twilio configuration, to check for the existence of phonenumber in a directory (may be deprecated in a near future) | ||||
| TWILIO_SID= | ||||
| TWILIO_SECRET= | ||||
| # Default carrier code will replace all leading zero by an international code. Set here the country as two letters | ||||
| DEFAULT_CARRIER_CODE=FR | ||||
| # Configuration for the notification emails | ||||
| NOTIFICATION_FROM_EMAIL=chill@instance.com | ||||
| NOTIFICATION_FROM_NAME=Chill | ||||
| # Will set the default host when sending email from command or services (see https://symfony.com/doc/5.x/routing.html#generating-urls-in-commands) | ||||
| NOTIFICATION_HOST=my.chill.social | ||||
| # Variables for relatorio host, which generates documents | ||||
| RELATORIO_HOST= | ||||
| RELATORIO_PORT= | ||||
| # Address for your collabora server | ||||
| #EDITOR_SERVER=https://code.example.com | ||||
| EDITOR_SERVER=https://collabora.champs-libres.be | ||||
| # center address widget when empty | ||||
| ADD_ADDRESS_DEFAULT_COUNTRY=BE | ||||
| ADD_ADDRESS_MAP_CENTER_X=50.8443 | ||||
| ADD_ADDRESS_MAP_CENTER_Y=4.3523 | ||||
| ADD_ADDRESS_MAP_CENTER_Z=15 | ||||
| ## Redis Cache & redis database | ||||
| REDIS_HOST=redis | ||||
| REDIS_PORT=6379 | ||||
| REDIS_URL=redis://${REDIS_HOST}:${REDIS_PORT} | ||||
| ###< chill-project/chill-bundles ### | ||||
|  | ||||
| ###> symfony/ovh-cloud-notifier ### | ||||
| # OVHCLOUD_DSN=ovhcloud://APPLICATION_KEY:APPLICATION_SECRET@default?consumer_key=CONSUMER_KEY&service_name=SERVICE_NAME | ||||
| ###< symfony/ovh-cloud-notifier ### | ||||
							
								
								
									
										34
									
								
								.env.test
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								.env.test
									
									
									
									
									
								
							| @@ -3,37 +3,3 @@ | ||||
| # Run tests from root to adapt your own environment | ||||
| KERNEL_CLASS='App\Kernel' | ||||
| APP_SECRET='$ecretf0rt3st' | ||||
|  | ||||
| ADMIN_PASSWORD=password | ||||
|  | ||||
| JWT_SECRET_KEY=%kernel.project_dir%/config/jwt/private.pem | ||||
| JWT_PUBLIC_KEY=%kernel.project_dir%/config/jwt/public.pem | ||||
| JWT_PASSPHRASE=2a30f6ba26521a2613821da35f28386e | ||||
|  | ||||
| TWILIO_SID=~ | ||||
| TWILIO_SECRET=~ | ||||
| DEFAULT_CARRIER_CODE=BE | ||||
|  | ||||
| ADD_ADDRESS_DEFAULT_COUNTRY=BE | ||||
| ADD_ADDRESS_MAP_CENTER_X=50.8443 | ||||
| ADD_ADDRESS_MAP_CENTER_Y=4.3523 | ||||
| ADD_ADDRESS_MAP_CENTER_Z=15 | ||||
|  | ||||
| SHORT_MESSAGE_DSN=null://null | ||||
| MESSENGER_TRANSPORT_DSN=sync:// | ||||
|  | ||||
| ###> doctrine/doctrine-bundle ### | ||||
| # Format described at https://www.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/configuration.html#connecting-using-a-url | ||||
| # IMPORTANT: You MUST configure your server version, either here or in config/packages/doctrine.yaml | ||||
| # | ||||
| DATABASE_URL="postgresql://app:!ChangeMe!@127.0.0.1:5454/test?serverVersion=14&charset=utf8" | ||||
| ###< doctrine/doctrine-bundle ### | ||||
|  | ||||
| ASYNC_UPLOAD_TEMP_URL_KEY= | ||||
| ASYNC_UPLOAD_TEMP_URL_BASE_PATH= | ||||
| ASYNC_UPLOAD_TEMP_URL_CONTAINER= | ||||
|  | ||||
| MAILER_DSN=null://null | ||||
|  | ||||
| REDIS_HOST=127.0.0.1 | ||||
| REDIS_PORT=6363 | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										37
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										37
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -3,20 +3,9 @@ composer | ||||
| composer.phar | ||||
| composer.lock | ||||
| docs/build/ | ||||
| node_modules/* | ||||
| .php_cs.cache | ||||
| .cache/* | ||||
| yarn.lock | ||||
|  | ||||
| docker/db/data | ||||
| docker/rabbitmq/data | ||||
|  | ||||
| # in this development bundle, we want to ignore directories related to a real app | ||||
| assets/* | ||||
| !assets/translator.ts | ||||
| !assets/ux-translator | ||||
| migrations/* | ||||
| templates/* | ||||
| translations/* | ||||
|  | ||||
| ###> symfony/framework-bundle ### | ||||
| /.env.local | ||||
| @@ -26,6 +15,7 @@ translations/* | ||||
| /public/bundles/ | ||||
| /var/ | ||||
| /vendor/ | ||||
| /bin/ | ||||
| ###< symfony/framework-bundle ### | ||||
|  | ||||
| ###> phpunit/phpunit ### | ||||
| @@ -37,25 +27,4 @@ translations/* | ||||
| /.idea/ | ||||
| /.psalm/ | ||||
|  | ||||
| ###> phpstan/phpstan ### | ||||
| phpstan.neon | ||||
| ###< phpstan/phpstan ### | ||||
|  | ||||
| ###> lexik/jwt-authentication-bundle ### | ||||
| /config/jwt/*.pem | ||||
| ###< lexik/jwt-authentication-bundle ### | ||||
|  | ||||
| ###> symfony/phpunit-bridge ### | ||||
| ###< symfony/phpunit-bridge ### | ||||
|  | ||||
| ###> symfony/webpack-encore-bundle ### | ||||
| /node_modules/ | ||||
| /public/build/ | ||||
| npm-debug.log | ||||
| yarn-error.log | ||||
| ###< symfony/webpack-encore-bundle ### | ||||
|  | ||||
| ###> friendsofphp/php-cs-fixer ### | ||||
| /.php-cs-fixer.php | ||||
| /.php-cs-fixer.cache | ||||
| ###< friendsofphp/php-cs-fixer ### | ||||
| node_modules/* | ||||
|   | ||||
							
								
								
									
										107
									
								
								.gitlab-ci.yml
									
									
									
									
									
								
							
							
						
						
									
										107
									
								
								.gitlab-ci.yml
									
									
									
									
									
								
							| @@ -3,50 +3,41 @@ | ||||
| # Select what we should cache between builds | ||||
| cache: | ||||
|     paths: | ||||
|         - /vendor/ | ||||
|         - tests/app/vendor/ | ||||
|         - .cache | ||||
|         - node_modules/ | ||||
|  | ||||
| # Bring in any services we need http://docs.gitlab.com/ee/ci/docker/using_docker_images.html#what-is-a-service | ||||
| # See http://docs.gitlab.com/ee/ci/services/README.html for examples. | ||||
| services: | ||||
|     - name: postgis/postgis:17-3.5-alpine | ||||
|     - name: postgis/postgis:14-3.3-alpine | ||||
|       alias: db | ||||
|       command: | ||||
|           - postgres | ||||
|           - "-c" | ||||
|           - max_connections=1000 | ||||
|     - name: redis | ||||
|       alias: redis | ||||
|  | ||||
| # Set any variables we need | ||||
| variables: | ||||
|     APP_ENV: test | ||||
|     GIT_DEPTH: 1 | ||||
|     # Configure postgres environment variables (https://hub.docker.com/r/_/postgres/) | ||||
|     POSTGRES_USER: postgres | ||||
|     POSTGRES_PASSWORD: postgres | ||||
|     # configure database access | ||||
|     DATABASE_URL: postgresql://postgres:postgres@db:5432/postgres?serverVersion=17&charset=utf8 | ||||
|     DATABASE_URL: postgresql://postgres:postgres@db:5432/postgres?serverVersion=14&charset=utf8 | ||||
|     # fetch the chill-app using git submodules | ||||
|     # GIT_SUBMODULE_STRATEGY: recursive | ||||
|     GIT_SUBMODULE_STRATEGY: recursive | ||||
|     REDIS_HOST: redis | ||||
|     REDIS_PORT: 6379 | ||||
|     REDIS_URL: redis://redis:6379 | ||||
|     # change vendor dir to make the app install into tests/apps | ||||
|     COMPOSER_VENDOR_DIR: tests/app/vendor | ||||
|     DEFAULT_CARRIER_CODE: BE | ||||
|     # force a timezone | ||||
|     TZ: Europe/Brussels | ||||
|     # avoid direct deprecations (using symfony phpunit bridge: https://symfony.com/doc/4.x/components/phpunit_bridge.html#internal-deprecations | ||||
|     SYMFONY_DEPRECATIONS_HELPER: max[total]=99999999&max[self]=0&max[direct]=45&verbose=0 | ||||
|  | ||||
| stages: | ||||
|     - Composer install | ||||
|     - Tests | ||||
|     - Deploy | ||||
|  | ||||
| build: | ||||
|     stage: Composer install | ||||
|     image: chill/base-image:8.3-edge | ||||
|     image: gitea.champs-libres.be/chill-project/chill-skeleton-basic/base-image:php82 | ||||
|     before_script: | ||||
|         - composer config -g cache-dir "$(pwd)/.cache" | ||||
|     script: | ||||
| @@ -55,68 +46,52 @@ build: | ||||
|         paths: | ||||
|             - .cache/ | ||||
|     artifacts: | ||||
|         expire_in: 1 day | ||||
|         expire_in: 30 min | ||||
|         paths: | ||||
|             - vendor/ | ||||
|             - bin | ||||
|             - tests/app/vendor/ | ||||
|  | ||||
| code_style: | ||||
|     stage: Tests | ||||
|     image: chill/base-image:8.3-edge | ||||
|     image: gitea.champs-libres.be/chill-project/chill-skeleton-basic/base-image:php82 | ||||
|     script: | ||||
|         - php-cs-fixer fix --dry-run -v --show-progress=none | ||||
|     cache: | ||||
|         paths: | ||||
|             - .cache/ | ||||
|     artifacts: | ||||
|         expire_in: 1 day | ||||
|         expire_in: 30 min | ||||
|         paths: | ||||
|             - vendor/ | ||||
|             - bin | ||||
|             - tests/app/vendor/ | ||||
|  | ||||
| phpstan_tests: | ||||
|     stage: Tests | ||||
|     image: chill/base-image:8.3-edge | ||||
|     variables: | ||||
|         COMPOSER_MEMORY_LIMIT: 3G | ||||
|     before_script: | ||||
|         - bin/console cache:clear --env=dev | ||||
|     image: gitea.champs-libres.be/chill-project/chill-skeleton-basic/base-image:php82 | ||||
|     script: | ||||
|         - composer exec phpstan -- analyze --memory-limit=3G | ||||
|         - bin/phpstan analyze --memory-limit=2G | ||||
|     cache: | ||||
|         paths: | ||||
|             - .cache/ | ||||
|     artifacts: | ||||
|         expire_in: 1 day | ||||
|         expire_in: 30 min | ||||
|         paths: | ||||
|             - vendor/ | ||||
|             - bin | ||||
|             - tests/app/vendor/ | ||||
|  | ||||
| rector_tests: | ||||
|     stage: Tests | ||||
|     image: chill/base-image:8.3-edge | ||||
|     before_script: | ||||
|         - bin/console cache:clear --env=dev | ||||
|     image: gitea.champs-libres.be/chill-project/chill-skeleton-basic/base-image:php82 | ||||
|     script: | ||||
|         - composer exec rector -- process --dry-run | ||||
|         - bin/rector --dry-run | ||||
|     cache: | ||||
|         paths: | ||||
|             - .cache/ | ||||
|     artifacts: | ||||
|         expire_in: 1 day | ||||
|         expire_in: 30 min | ||||
|         paths: | ||||
|             - vendor/ | ||||
|  | ||||
| lint: | ||||
|     stage: Tests | ||||
|     image: node:20-alpine | ||||
|     before_script: | ||||
|         - apk add --no-cache python3 make g++ py3-setuptools | ||||
|         - export PYTHON="$(which python3)" | ||||
|         - export PATH="./node_modules/.bin:$PATH" | ||||
|     script: | ||||
|         - yarn install --ignore-optional | ||||
|         - npx eslint-baseline "src/**/*.{js,ts,vue}" | ||||
|     cache: | ||||
|         paths: | ||||
|             - node_modules/ | ||||
|             - bin | ||||
|             - tests/app/vendor/ | ||||
|  | ||||
| # psalm_tests: | ||||
| #     stage: Tests | ||||
| @@ -132,29 +107,17 @@ lint: | ||||
|  | ||||
| unit_tests: | ||||
|     stage: Tests | ||||
|     image: chill/base-image:8.3-edge | ||||
|     variables: | ||||
|         COMPOSER_MEMORY_LIMIT: 3G | ||||
|     before_script: | ||||
|         - php bin/console doctrine:database:create -n --env=test | ||||
|         - php bin/console doctrine:migrations:migrate -n --env=test | ||||
|         - php bin/console chill:db:sync-views --env=test | ||||
|         - php bin/console cache:clear --env=test | ||||
|         - php bin/console doctrine:fixtures:load -n --env=test | ||||
|     image: gitea.champs-libres.be/chill-project/chill-skeleton-basic/base-image:php82 | ||||
|     # until we fix testes | ||||
|     allow_failure: true | ||||
|     script: | ||||
|         - composer exec phpunit -- --colors=never --exclude-group dbIntensive,openstack-integration | ||||
|         - php tests/app/bin/console doctrine:migrations:migrate -n | ||||
|         - php -d memory_limit=2G tests/app/bin/console cache:clear --env=dev | ||||
|         - php -d memory_limit=3G tests/app/bin/console doctrine:fixtures:load -n | ||||
|         - php -d memory_limit=2G tests/app/bin/console cache:clear --env=test | ||||
|         - php -d memory_limit=4G bin/phpunit --colors=never | ||||
|     artifacts: | ||||
|         expire_in: 1 day | ||||
|         expire_in: 30 min | ||||
|         paths: | ||||
|             - vendor/ | ||||
|  | ||||
| release: | ||||
|     stage: Deploy | ||||
|     image: registry.gitlab.com/gitlab-org/release-cli:latest | ||||
|     rules: | ||||
|         - if: $CI_COMMIT_TAG | ||||
|     script: | ||||
|         - echo "running release_job" | ||||
|     release: | ||||
|         tag_name: '$CI_COMMIT_TAG' | ||||
|         description: "./.changes/$CI_COMMIT_TAG.md" | ||||
|             - bin | ||||
|             - tests/app/vendor/ | ||||
|   | ||||
							
								
								
									
										3
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,6 @@ | ||||
| [submodule "_exts/sphinx-php"] | ||||
| 	path = _exts/sphinx-php | ||||
| 	url = https://github.com/fabpot/sphinx-php.git | ||||
| [submodule "tests/app"] | ||||
| 	path = tests/app | ||||
| 	url = https://gitlab.com/Chill-projet/chill-app.git | ||||
|   | ||||
| @@ -1,348 +0,0 @@ | ||||
| # Project Guidelines for Junie | ||||
|  | ||||
| ## Project Overview | ||||
|  | ||||
| Chill is a comprehensive web application built as a set of Symfony bundles. It is a case management system, for social work. The project consists of multiple specialized bundles that provide different functionalities: | ||||
|  | ||||
| - **ChillMainBundle**: Core bundles that provide the foundation of the application | ||||
| - **ChillPersonBundle**: Core bundles that provide the foundation of the bundles associated to person (which is the case for all other bundles) | ||||
| - **ChillCalendarBundle**: Calendar and scheduling functionality | ||||
| - **ChillDocStoreBundle** and **ChillDocGeneratorBundle**: Document management and generation | ||||
| - **ChillActivityBundle**, **ChillEventBundle**, **ChillTaskBundle**: Activity and task tracking | ||||
| - **ChillBudgetBundle**: Financial management | ||||
| - **ChillThirdPartyBundle**: Integration with external systems | ||||
| - **ChillCustomFieldsBundle**: Extensibility through custom fields | ||||
| - **ChillReportBundle**: Save arbitrary reports about persons | ||||
| - **ChillTicketBundle**: Record and track issues about persons | ||||
|  | ||||
| - And several other specialized bundles | ||||
|  | ||||
| ## Technology Stack | ||||
|  | ||||
| - **Backend**: PHP 8.3+, Symfony 5.4 | ||||
| - **Frontend**: JavaScript/TypeScript, Vue.js 3, Bootstrap 5 | ||||
| - **Build Tools**: Webpack Encore, Yarn | ||||
| - **Database**: PostgreSQL with materialized views. We do not support other databases. | ||||
| - **Other Services**: Redis, AMQP (RabbitMQ), SMTP | ||||
|  | ||||
| ## Project Structure | ||||
|  | ||||
| Note: This is a project which exists from a long time ago, and we found multiple structure inside each bundle. When having the choice, the developers should choose the new structure. | ||||
|  | ||||
| The project follows a standard Symfony bundle structure: | ||||
| - `/src/Bundle/`: Contains all the Chill bundles. The code is either at the root of the bundle directory, or within a `src/` directory (preferred). See psr4 mapping at the root's `composer.json`. | ||||
| - each bundle come with his own tests, either in the `Tests` directory (when the code is directly within the bundle directory (for instance `src/Bundle/ChillMainBundle/Tests`, `src/Bundle/ChillPersonBundle/Tests`)), or inside the `tests` directory, alongside to the `src/` sub-directory (example: `src/Bundle/ChillWopiBundle/tests`) (this is the preferred way). | ||||
| - `/docs/`: Contains project documentation | ||||
|  | ||||
| Each bundle typically has the following structure: | ||||
|  | ||||
| - `Controller/`: Contains controllers | ||||
| - `Entity/`: Contains Doctrine entities | ||||
| - `Repository/`: Contains Doctrine repositories | ||||
| - `Resources/`: Contains views, translations, and public assets | ||||
| - `DependencyInjection/`: Contains service configuration | ||||
| - `Export/`: Contains services related to exports | ||||
| - `Security/`: Contains services related to security. Most of the time, those are new voters, and so on. | ||||
|  | ||||
| ### A special word about TicketBundle | ||||
|  | ||||
| The ticket bundle is developed using a kind of "Command" pattern. The controller fill a "Command", and a "CommandHandler" handle this command. They are savec in the `src/Bundle/ChillTicketBundle/src/Action` directory. | ||||
|  | ||||
| ## Development Guidelines | ||||
|  | ||||
| ### Building and Configuration Instructions | ||||
|  | ||||
| All the command should be run through the `symfony` command, which will configure the required variables. | ||||
|  | ||||
| For assets, we must ensure that we use node at version `^20.0.0`. This is done using `nvm use 20`. | ||||
|  | ||||
| #### Initial Setup | ||||
|  | ||||
| 1. **Clone the Repository**: | ||||
|    ```bash | ||||
|    git clone <repository-url> | ||||
|    cd chill-bundles | ||||
|    ``` | ||||
|  | ||||
| 2. **Install PHP Dependencies**: | ||||
|    ```bash | ||||
|    composer install | ||||
|    ``` | ||||
|  | ||||
| 3. **Install JavaScript Dependencies**: | ||||
|    ```bash | ||||
|    nvm use 20 | ||||
|    yarn install | ||||
|    ``` | ||||
|  | ||||
| 4. **Configure Environment Variables**: | ||||
|  | ||||
|    - Create a `.env.local` file with minimal configuration | ||||
|    ```bash | ||||
|    echo "APP_ENV=dev" >> .env.local | ||||
|    ``` | ||||
|  | ||||
| 5. Start the associated services (database, and so on): | ||||
|    ```bash | ||||
|    docker compose up -d | ||||
|    ``` | ||||
|  | ||||
| 5. **Set Up the Database**: | ||||
|    ```bash | ||||
|    # Create the database | ||||
|    symfony console doctrine:database:create | ||||
|  | ||||
|    # Run migrations | ||||
|    symfony console doctrine:migrations:migrate | ||||
|  | ||||
|    # Load fixtures (optional) | ||||
|    symfony console doctrine:fixtures:load | ||||
|    ``` | ||||
|  | ||||
| 6. **Build Assets**: | ||||
|    ```bash | ||||
|    nvm use 20 | ||||
|    yarn run encore dev | ||||
|    ``` | ||||
|  | ||||
| 7. **Start the Development Server**: | ||||
|    ```bash | ||||
|    symfony server:start -d | ||||
|    ``` | ||||
|  | ||||
| #### Docker Setup | ||||
|  | ||||
| The project includes Docker configuration for easier development: | ||||
|  | ||||
| 1. **Start Docker Services**: | ||||
|    ```bash | ||||
|    docker-compose up -d | ||||
|    ``` | ||||
|  | ||||
| 2. **Access the Application**: | ||||
|    - The application will be available at `http://localhost:8000` | ||||
|    - PostgreSQL will be available at `localhost:5432` | ||||
|    - Redis will be available at `localhost:6379` | ||||
|  | ||||
| #### Building Assets | ||||
|  | ||||
| Before submitting any changes, you should build the project to ensure that all assets are properly compiled: | ||||
|  | ||||
| ```bash | ||||
| # For production | ||||
| yarn run encore production | ||||
|  | ||||
| # For development with hot-reloading | ||||
| yarn run encore dev --watch | ||||
|  | ||||
| # for development | ||||
| yarn run encore dev | ||||
| ``` | ||||
|  | ||||
| #### Configuration Files | ||||
|  | ||||
| Key configuration files: | ||||
|  | ||||
| - `config/packages/*.yaml`: Symfony bundle configurations | ||||
| - `webpack.config.js`: Webpack Encore configuration | ||||
| - `composer.json`: PHP dependencies and scripts | ||||
| - `package.json`: JavaScript dependencies and scripts | ||||
| - `.env`: Default environment variables. Must usually not be updated: use `.env.local` instead. | ||||
|  | ||||
| ### Database migrations | ||||
|  | ||||
| Each time a doctrine entity is created, we generate migration to adapt the database. | ||||
|  | ||||
| The migration are created using the command `symfony console doctrine:migrations:diff --no-interaction --namespace <namespace>`, where the namespace is the relevant namespace for migration. As this is a bash script, do not forget to quote the `\` (`\` must become `\\` in your command). | ||||
|  | ||||
| Each bundle has his own namespace for migration (always ask me to confirm that command, with a list of updated / created entities so that I can confirm you that it is ok): | ||||
|  | ||||
| - `Chill\Bundle\ActivityBundle` writes migrations to `Chill\Migrations\Activity`; | ||||
| - `Chill\Bundle\BudgetBundle` writes migrations to `Chill\Migrations\Budget`; | ||||
| - `Chill\Bundle\CustomFieldsBundle` writes migrations to `Chill\Migrations\CustomFields`; | ||||
| - `Chill\Bundle\DocGeneratorBundle` writes migrations to `Chill\Migrations\DocGenerator`; | ||||
| - `Chill\Bundle\DocStoreBundle` writes migrations to `Chill\Migrations\DocStore`; | ||||
| - `Chill\Bundle\EventBundle` writes migrations to `Chill\Migrations\Event`; | ||||
| - `Chill\Bundle\CalendarBundle` writes migrations to `Chill\Migrations\Calendar`; | ||||
| - `Chill\Bundle\FamilyMembersBundle` writes migrations to `Chill\Migrations\FamilyMembers`; | ||||
| - `Chill\Bundle\FranceTravailApiBundle` writes migrations to `Chill\Migrations\FranceTravailApi`; | ||||
| - `Chill\Bundle\JobBundle` writes migrations to `Chill\Migrations\Job`; | ||||
| - `Chill\Bundle\MainBundle` writes migrations to `Chill\Migrations\Main`; | ||||
| - `Chill\Bundle\PersonBundle` writes migrations to `Chill\Migrations\Person`; | ||||
| - `Chill\Bundle\ReportBundle` writes migrations to `Chill\Migrations\Report`; | ||||
| - `Chill\Bundle\TaskBundle` writes migrations to `Chill\Migrations\Task`; | ||||
| - `Chill\Bundle\ThirdPartyBundle` writes migrations to `Chill\Migrations\ThirdParty`; | ||||
| - `Chill\Bundle\TicketBundle` writes migrations to `Chill\Migrations\Ticket`; | ||||
| - `Chill\Bundle\WopiBundle` writes migrations to `Chill\Migrations\Wopi`; | ||||
|  | ||||
| Once created the, comment's classes should be removed and a description of the changes made to the entities should be added to the migrations, using the `getDescription` method. The migration should not be cleaned by any artificial intelligence, as modifying this migration is error prone. | ||||
|  | ||||
| ### Guidelines related to code structure and requirements | ||||
|  | ||||
| #### Usage of clock | ||||
|  | ||||
| When we need to use a DateTime or DateTimeImmutable that need to express "now", we prefer the usage of | ||||
| `Symfony\Component\Clock\ClockInterface`, where possible. This is usually not possible in doctrine entities, | ||||
| where injection does not work when restoring an entity from database, but usually possible in services. | ||||
|  | ||||
| ### Testing Information | ||||
|  | ||||
| The project uses PHPUnit for testing. Each bundle has its own test suite, and there's also a global test suite at the root level. | ||||
|  | ||||
| For creating mock, we prefer using prophecy (library phpspec/prophecy). | ||||
|  | ||||
| #### Running Tests | ||||
|  | ||||
| ```bash | ||||
| # Run all tests | ||||
| vendor/bin/phpunit | ||||
|  | ||||
| # Run tests for a specific bundle | ||||
| vendor/bin/phpunit --testsuite NameBundle | ||||
|  | ||||
| # Run a specific test file | ||||
| vendor/bin/phpunit path/to/TestFile.php | ||||
|  | ||||
| # Run a specific test method | ||||
| vendor/bin/phpunit --filter methodName path/to/TestFile.php | ||||
| ``` | ||||
|  | ||||
| #### Test Structure | ||||
|  | ||||
| Tests are organized by bundle and follow the same structure as the bundle itself: | ||||
|  | ||||
| - Unit tests: Test individual components in isolation | ||||
| - Integration tests: Test components working together | ||||
| - Functional tests: Test the application from the user's perspective | ||||
|  | ||||
| #### Writing Tests | ||||
|  | ||||
| Tests should be placed in the appropriate bundle's test directory. For example, tests for the TicketBundle should be placed in `src/Bundle/ChillTicketBundle/tests/`. | ||||
|  | ||||
| Here's an example of a simple entity test: | ||||
|  | ||||
| ```php | ||||
| <?php | ||||
|  | ||||
| namespace Chill\TicketBundle\Tests\Entity; | ||||
|  | ||||
| use Chill\TicketBundle\Entity\Ticket; | ||||
| use PHPUnit\Framework\TestCase; | ||||
|  | ||||
| class TicketTest extends TestCase | ||||
| { | ||||
|     public function testGetAndSetExternalRef(): void | ||||
|     { | ||||
|         $ticket = new Ticket(); | ||||
|         $externalRef = 'REF-123'; | ||||
|  | ||||
|         // Set the external reference | ||||
|         $ticket->setExternalRef($externalRef); | ||||
|  | ||||
|         // Verify that getExternalRef returns the correct value | ||||
|         self::assertSame($externalRef, $ticket->getExternalRef()); | ||||
|  | ||||
|         // Change the external reference | ||||
|         $newExternalRef = 'REF-456'; | ||||
|         $ticket->setExternalRef($newExternalRef); | ||||
|  | ||||
|         // Verify that getExternalRef returns the updated value | ||||
|         self::assertSame($newExternalRef, $ticket->getExternalRef()); | ||||
|     } | ||||
| } | ||||
| ``` | ||||
|  | ||||
| #### Test Database | ||||
|  | ||||
| For tests that require a database, the project uses postgresql database filled by fixtures (usage of doctrine-fixtures). You can configure a different database for testing in the `.env.test` file. | ||||
|  | ||||
| ### Code Quality Tools | ||||
|  | ||||
| The project uses several tools to maintain code quality: | ||||
|  | ||||
| #### PHP Code Style | ||||
|  | ||||
| The project uses PHP-CS-Fixer for code style. You can run it with: | ||||
|  | ||||
| ```bash | ||||
| # Using the composer script | ||||
| composer php-cs-fixer | ||||
|  | ||||
| # Or directly | ||||
| php-cs-fixer fix --config=./.php-cs-fixer.dist.php | ||||
| ``` | ||||
|  | ||||
| #### Static Analysis | ||||
|  | ||||
| The project uses PHPStan for static analysis. You can run it with: | ||||
|  | ||||
| ```bash | ||||
| # Using the composer script | ||||
| composer phpstan | ||||
|  | ||||
| # Or directly | ||||
| vendor/bin/phpstan analyse | ||||
| ``` | ||||
|  | ||||
| #### Automated Refactoring | ||||
|  | ||||
| The project uses Rector for automated refactoring. You can run it with: | ||||
|  | ||||
| ```bash | ||||
| # Using the composer script | ||||
| composer rector | ||||
|  | ||||
| # Or directly | ||||
| vendor/bin/rector | ||||
| ``` | ||||
|  | ||||
| #### JavaScript/TypeScript Linting | ||||
|  | ||||
| The project uses ESLint for JavaScript/TypeScript code quality. You can run it with: | ||||
|  | ||||
| ```bash | ||||
| yarn run eslint | ||||
| ``` | ||||
|  | ||||
| ## Deployment | ||||
|  | ||||
| The project can be deployed in a production environment following Symfony's deployment guidelines. The documentation provides detailed instructions for setting up a production environment. | ||||
|  | ||||
| ### Production Deployment Checklist | ||||
|  | ||||
| 1. Set environment variables for production | ||||
| 2. Optimize Composer autoloader: `composer install --no-dev --optimize-autoloader` | ||||
| 3. Compile assets for production: `yarn run encore production` | ||||
| 4. Clear and warm up the cache: `php bin/console cache:clear --env=prod` | ||||
| 5. Run database migrations: `php bin/console doctrine:migrations:migrate --env=prod` | ||||
|  | ||||
| ## Documentation | ||||
|  | ||||
| Comprehensive documentation is available in the `/docs/` directory, including installation instructions, configuration guides, and operational procedures. | ||||
|  | ||||
| ## Development Workflow | ||||
|  | ||||
| 1. **Create a Feature Branch**: Always create a new branch for your feature or bugfix | ||||
| 2. **Write Tests**: Write tests for your changes before implementing them | ||||
| 3. **Implement Changes**: Implement your changes following the project's coding standards | ||||
| 4. **Run Tests**: Make sure all tests pass | ||||
| 5. **Run Code Quality Tools**: Make sure your code passes all code quality checks | ||||
| 6. **Submit a Pull Request**: Submit a pull request for review | ||||
|  | ||||
| ## Debugging | ||||
|  | ||||
| The project includes several tools for debugging: | ||||
|  | ||||
| - **Symfony Profiler**: Available in development mode at `/_profiler` | ||||
| - **Xdebug**: Configure your IDE to use Xdebug for step-by-step debugging | ||||
| - **Symfony Debug Toolbar**: Available at the bottom of the page in development mode | ||||
|  | ||||
| ## Conclusion | ||||
|  | ||||
| When working with this project, Junie should: | ||||
|  | ||||
| 1. Understand the modular bundle structure and how the different components interact | ||||
| 2. Build the project before submitting changes to ensure assets are properly compiled | ||||
| 3. Run relevant tests to ensure changes don't break existing functionality | ||||
| 4. Follow the established code style and patterns | ||||
| 5. Use the provided tools for debugging and code quality | ||||
| @@ -13,7 +13,6 @@ $finder = PhpCsFixer\Finder::create(); | ||||
|  | ||||
| $finder | ||||
|     ->in(__DIR__.'/src') | ||||
|     ->in(__DIR__.'/utils') | ||||
|     ->append([__FILE__]) | ||||
|     ->exclude(['docs/', 'tests/app']) | ||||
|     ->notPath('tests/app') | ||||
| @@ -25,9 +24,8 @@ $config = new PhpCsFixer\Config(); | ||||
| $config | ||||
|     ->setFinder($finder) | ||||
|     ->setRiskyAllowed(true) | ||||
|     ->setCacheFile('var/php-cs-fixer.cache') | ||||
|     ->setCacheFile('.cache/php-cs-fixer.cache') | ||||
|     ->setUsingCache(true) | ||||
|     ->setParallelConfig(PhpCsFixer\Runner\Parallel\ParallelConfigFactory::detect()) | ||||
| ; | ||||
|  | ||||
| $rules = $config->getRules(); | ||||
| @@ -92,7 +90,7 @@ $rules = array_merge( | ||||
|     [ | ||||
|         '@PhpCsFixer' => true, | ||||
|         '@PhpCsFixer:risky' => false, | ||||
|         '@Symfony' => true, | ||||
|         '@Symfony' => false, | ||||
|         '@Symfony:risky' => false, | ||||
|         'ordered_class_elements' => [ | ||||
|             'order' => [ | ||||
| @@ -112,14 +110,13 @@ $rules = array_merge( | ||||
|                 'method_private', | ||||
|             ], | ||||
|             'sort_algorithm' => 'alpha', | ||||
|         ], | ||||
|         'single_line_empty_body' => true, | ||||
|         ] | ||||
|     ], | ||||
|     $rules, | ||||
|     $riskyRules, | ||||
|     $untilFullSwitchToPhp8, | ||||
| ); | ||||
|  | ||||
| $rules['header_comment']['header'] = trim(file_get_contents(__DIR__.'/resources/header.txt')); | ||||
| $rules['header_comment']['header'] = trim(file_get_contents(__DIR__ . '/resource/header.txt')); | ||||
|  | ||||
| return $config->setRules($rules); | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user