mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-22 21:22:48 +00:00 
			
		
		
		
	Compare commits
	
		
			11 Commits
		
	
	
		
			issue546_p
			...
			issue309_a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 5e1dfee70f | ||
|  | 73f11ccb1a | ||
|  | d14edd469e | ||
|  | fd40ae0198 | ||
|  | 7d20f842a2 | ||
|  | e82a71b833 | ||
|  | 3b20ac85d9 | ||
|  | 6bae7606dd | ||
|  | 4c4a003977 | ||
|  | 077317c2bf | ||
|  | 3c2ebee12a | 
							
								
								
									
										64
									
								
								.env
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								.env
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | ||||
| ## | ||||
| ##  Manually dump .env files in .env.local.php with | ||||
| ## `$ composer symfony:dump-env prod` | ||||
| ## | ||||
|  | ||||
| ## Project environment | ||||
| APP_ENV=dev | ||||
|  | ||||
| ## Enable debug | ||||
| APP_DEBUG=true | ||||
|  | ||||
| ## Locale | ||||
| LOCALE=fr | ||||
|  | ||||
| ## Framework secret | ||||
| APP_SECRET=ThisTokenIsNotSoSecretChangeIt | ||||
|  | ||||
| ## Symfony/swiftmailer | ||||
| MAILER_TRANSPORT=smtp | ||||
| MAILER_HOST=smtp | ||||
| MAILER_PORT=1025 | ||||
| MAILER_CRYPT= | ||||
| MAILER_AUTH= | ||||
| MAILER_USER= | ||||
| MAILER_PASSWORD= | ||||
| MAILER_URL=${MAILER_TRANSPORT}://${MAILER_HOST}:${MAILER_PORT}?encryption=${MAILER_CRYPT}&auth_mode=${MAILER_AUTH}&username=${MAILER_USER}&password=${MAILER_PASSWORD} | ||||
|  | ||||
| ## Notifications | ||||
| NOTIFICATION_HOST=localhost:8001 | ||||
| NOTIFICATION_FROM_EMAIL=admin@chill.social | ||||
| NOTIFICATION_FROM_NAME=Chill | ||||
|  | ||||
| ## Gelf | ||||
| GELF_HOST=gelf | ||||
| GELF_PORT=12201 | ||||
|  | ||||
| ## OVH OpenStack Storage User/Role | ||||
| OS_USERNAME= | ||||
| OS_PASSWORD= | ||||
| OS_TENANT_ID= | ||||
| OS_REGION_NAME=GRA | ||||
| OS_AUTH_URL=https://auth.cloud.ovh.net/v2.0/ | ||||
|  | ||||
| ## OVH OpenStack Storage Container | ||||
| ASYNC_UPLOAD_TEMP_URL_KEY= | ||||
| ASYNC_UPLOAD_TEMP_URL_BASE_PATH= | ||||
| ASYNC_UPLOAD_TEMP_URL_CONTAINER= | ||||
|  | ||||
| ## Redis Cache | ||||
| REDIS_HOST=redis | ||||
| REDIS_PORT=6379 | ||||
| REDIS_URL=redis://${REDIS_HOST}:${REDIS_PORT} | ||||
|  | ||||
| ## Twilio | ||||
| TWILIO_SID=~ | ||||
| TWILIO_SECRET=~ | ||||
|  | ||||
| ## DOCKER IMAGES REGISTRY | ||||
| #IMAGE_PHP= | ||||
| #IMAGE_NGINX= | ||||
|  | ||||
| ## DOCKER IMAGES VERSION | ||||
| #VERSION=test | ||||
| VERSION=prod | ||||
| @@ -3,3 +3,4 @@ | ||||
| # Run tests from root to adapt your own environment | ||||
| KERNEL_CLASS='App\Kernel' | ||||
| APP_SECRET='$ecretf0rt3st' | ||||
| DATABASE_URL=postgresql://postgres:postgres@db:5432/postgres?serverVersion=12&charset=utf8 | ||||
|   | ||||
| @@ -20,8 +20,6 @@ variables: | ||||
|     # 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=12&charset=utf8 | ||||
|     # fetch the chill-app using git submodules | ||||
|     GIT_SUBMODULE_STRATEGY: recursive | ||||
|     REDIS_HOST: redis | ||||
| @@ -29,7 +27,6 @@ variables: | ||||
|     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 | ||||
|  | ||||
| stages: | ||||
|     - Composer install | ||||
| @@ -79,7 +76,6 @@ psalm_tests: | ||||
|     image: registry.gitlab.com/chill-projet/chill-app/php-base-image:7.4 | ||||
|     script: | ||||
|         - bin/grumphp run --tasks=psalm | ||||
|     allow_failure: true | ||||
|     artifacts: | ||||
|         expire_in: 30 min | ||||
|         paths: | ||||
|   | ||||
							
								
								
									
										254
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										254
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -11,250 +11,6 @@ and this project adheres to | ||||
| ## Unreleased | ||||
|  | ||||
| <!-- write down unreleased development here --> | ||||
| * [person] Accompanying course evaluation documents: disable the WOPI edit link if mimetype not supported and if no keyInfos | ||||
| (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/585) | ||||
|  | ||||
| * [activity] display error messages above the form in creating a new location (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/481) | ||||
| * [activity] show required field in activity edit/new by an asterix in the vuejs fields (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/494) | ||||
| * [ACL] fix allow to see the course, event if the scope'course does not contains the scope's user | ||||
| * [search] enforce limit of results for fetching rsults by search api https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/576 | ||||
| * [activity] Fix delete button for document (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/554) | ||||
| * [activity] Add return path the document generation (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/553) | ||||
| * [person] add person ressource to person docgen normaliser (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/517) | ||||
| * [person] AccompanyingCourseWorkEdit: fix deleting evaluation documents (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/546) | ||||
| * [person] AccompanyingCourseWorkEdit: download existing documents (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/512) | ||||
| * [person] AccompanyingCourseWorkEdit: replace document by a new one (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/511) | ||||
| * [person] AccompanyingPeriodWork: add referrers to work, add doctrine event listener to add logged user to referrers collection and display a referrers list in work list (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/502) | ||||
| * [person] AccompanyingPeriodWorkEvaluation: fix circular reference when serialising (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/495) | ||||
| * [person] order accompanying period by opening date in search persons, person and household period lists (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/493) | ||||
| * [parcours] autosave of the pinned comment for draft accompanying course (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/477) | ||||
| * [main] filter user job in undispatch acc period to assign (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/472) | ||||
| * [main] filter user job in undispatch acc period to assign (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/472) | ||||
| * [person] Add url in accompanying period work evaluations entity and form (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/476) | ||||
| * [person] Add document generation in admin and in person/{id}/document (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/464) | ||||
| * [activity] do not override location if already exist (when validating new activity) (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/470) | ||||
| * [parcours] Toggle emergency/intensity only by referrer (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/442) | ||||
| * [docstore] Add an API entrypoint for StoredObject (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/466) | ||||
| * [person] Add the possibility of uploading existing documents to AccPeriodWorkEvaluationDocument (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/466) | ||||
| * [person] Add title to AccPeriodWorkEvaluationDocument (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/466) | ||||
| * [person] Order social issues by the field "ordering" (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/388) | ||||
| * [Person/Household list] when listing other simultaneous members of an household, exclude the members on person, not on members (avoid to show two membersship with the same person) | ||||
| * [draft periods] add a delete button (if acl granted) on each draft period listed on draft period page (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/463) | ||||
| * [Person] Display suffixText in RenderPerson, PersonText.vue, RenderPersonBox.vue (was made for displaying "enfant confie") (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/441) | ||||
| * [budget]: budget enabled for persons and households (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/469) | ||||
| *  [person] residential address: show residential address or info in PersonRenderBox, refactor Residential Address (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/439) | ||||
| * [thirdparty] Add a contact to a thirdparty from within onTheFly (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/345) | ||||
| * [documents] Improve flex-table item-col placement when long buttons and long metadata | ||||
| * [thirdparty] Fix display of multiple contact badges so they wrap onto next line (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/482) | ||||
| * [confidential] Fix position of toggle button so it does not cover text nor fall outside of box (no issue) | ||||
| * [parcours] Fix edit of both thirdparty and contact name (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/474) | ||||
| * [template] do not list inactive templates (for doc generator) | ||||
| * [household] bugfix if position of member is null, renderbox no longer throws an error (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/480) | ||||
| * [parcours] location cannot be removed if linked to a user (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/478) | ||||
| * [person] email added to twig personRenderbox (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/490) | ||||
| * [person] Add link to current household in person banner (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/484) | ||||
| * [address] person badge in address history changed to open OnTheFly with all person info (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/489) | ||||
| * [person] Change 'personne' with 'usager' and '&' with 'ET' (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/499) | ||||
| * [thirdparty] Add parameter condition to display centers or not (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/500) | ||||
| * [phonenumber] Remove placeholder in phonenumber field (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/496) | ||||
| * [person_resource] separate create page created to avoid confusion (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/504) | ||||
| * [contact] add contact button color changed plus the pipe at the side removed (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/506) | ||||
| * [thirdparty] For contacts show current civility/profession in edit form + fix saving of edited information (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/491) | ||||
| * [household] create-edit household composition placed in separate page to avoid confusion (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/505) | ||||
| * [blur] Improved positioning of toggle icon (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/486) | ||||
| * [thirdparty] add firstname field to thirdparty 'child' or 'contact' types (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/508) | ||||
| * [household] create-edit household composition placed in separate page to avoid confusion (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/505) | ||||
| * [blur] Improved positioning of toggle icon (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/486) | ||||
| * [parcours] List of parcours for a specific user so they can be reassigned in case of absence (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/509) | ||||
| * [thirdparty] Thirdparty view page, english text translated (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/534) | ||||
| * [social_action] Translation changed in evaluation section (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/512) | ||||
| * [filiation] Possible to add person (or create onthefly) to add to filiation graph + add relation (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/519) | ||||
| * [household] Within parcours listing page of household add create button (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/560) | ||||
| * [person_resource] bugfix when adding thirdparty or freetext resource + prevent personOwner themselves to be added. (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/526) | ||||
| * [aside_activity] style correction + sticky-form create button (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/529) | ||||
| * [budget] order within the menu adjusted (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/592) | ||||
| * [onthefly] fix create person. Bug was noticed in filiation (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/591) | ||||
| * [parcours] Create document buttons made sticky (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/532) | ||||
| * [person] Trailing guillemet removed (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/530) | ||||
| * [notification] Display of social action within workflow notification set to display block (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/537) | ||||
| * [onthefly] trim trailing whitespace in email of person and thirdparty (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/542) | ||||
| * [person] fix bug when phonenumber or mobile number is left empty (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/546) | ||||
|  | ||||
| ## Test releases | ||||
|  | ||||
| ### test release 2022-02-21 | ||||
|  | ||||
| * [notifications] Word 'un' changed to number '1' for notifications in user menu (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/483) | ||||
| * [documents] 'gabarit' changed to 'modèle' (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/405) | ||||
| * [person_resources] Menu name and order changed (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/460) | ||||
| * workflow: fix sending notifications | ||||
| * [thirdparty] Extend the thirdparty search to thirdparty children (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/448) | ||||
| * [person]: AddPersons: allow creation of person or thirdparty only (no users) (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/422) | ||||
| * [person]: AddPersons: allow creation of person or thirdparty depending on allowed types (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/422) | ||||
| * [person]: AddPersons: add suggestion of name when creating new person or thirdparty (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/422) | ||||
| * [main] Address: fix small bug: when modifying an address without street (isNoAddress), also check errors if street is an empty string as back-end change null value to empty string for street (and streetNumber) | ||||
| * [main] Address: stronger client-side validation of addresses (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/449) | ||||
| * [person] accompanying course: filter suggested entities by open participations (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/415) | ||||
| [activity] can click through the cross icon for removing person in concerned group (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/476) | ||||
| [activity] correct associated persons by considering only open participations (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/476) | ||||
| * [person_resources]: Renderboxes used to display person/thirdparty info (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/465) | ||||
| * [Household]: Add end date in HouseholdMember form for 'enfant hors menage' (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/434) | ||||
| * [homepage_widget]: If no sender then display as 'notification automatique' (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/435) | ||||
| * [parcours]: Order social activities and only display most recent three in parcours resumé (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/481) | ||||
| * [3party]: 3party: redirect to parent when contact (child) is opened in view page | ||||
| * [parcours / addresses]: launch an event when a person change address (either through changing household or because the household is associated to a new address). If the person is localising a course, the course location go back to a temporarily address. | ||||
| * [thirdparty]: address/phonenumber/email/fonction displayed in thirdpartyrenderbox (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/401) | ||||
| * [thirdparty_contact]: in search results the 'qualité' is displayed (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/465) | ||||
| * [bug]: fix confidential toggle of address in thirdpartyrenderbox (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/460) | ||||
|  | ||||
|  | ||||
| ## Test releases | ||||
| * Creation of PickCivilityType, and implementation in PersonType and ThirdpartyType | ||||
|  | ||||
| ### test release 2022-02-14 | ||||
|  | ||||
| * AddPersons: remove ul-li html tags from AddPersons (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/419) | ||||
| * [doc-generator] do not set required fields for mainPerson, person1, person2 (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement#456) | ||||
| * [doc-generation] add age and obele in the mainPerson, person1 and person2 list + add obele in person renderString if addAge (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/370) | ||||
| * [person] accompanying course work: fix on-the-fly update of thirdParty | ||||
| * fix normalisation of accompanying course requestor api (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/378) | ||||
| * [person] add a returnPath when clicking on some Person or ThirdParty badge (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/427) | ||||
| * [person] accompanying course work: fix on-the-fly update of thirdParty | ||||
| * [on-the-fly] close modal only after validation | ||||
| * [person] correct thirdparty PATCH url + add email and altnames in AddPerson and serializer (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/433) | ||||
| * change order for accompanying course work list | ||||
| * [parcours]: Mes parcours brouillon added to user menu (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/440) | ||||
| * [Documents]: List view adapted to display more information (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/414) | ||||
| * [person]: style fix in parcours listing per person. (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/432) | ||||
| * [parcours]: Only the referrer can toggle the intensity of the parcours (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/442) | ||||
| * [household]: display address of current household (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/415) | ||||
| * ajoute un ordre dans les localisation (api) | ||||
| * [pick entity]: fix translations in modal (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/419) | ||||
| * [homepage_widget]: fix translation on emergency badge (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/440) | ||||
| * [person]: create person and household added to button dropdown (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/454) | ||||
| * display full address in address.text in normalization. Adapt AddressRenderBox | ||||
| * [address]: Correction residential address 'depuis le' (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/459) | ||||
| * [Documents]: List view adapted to display more information (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/414) | ||||
| * [Thirdparty_contact]: address blurred if confidential in view page (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/450) | ||||
|  | ||||
|  | ||||
| ### test release 2021-02-01 | ||||
|  | ||||
| * renommer "dossier numéro" en "parcours numéro" dans les résultats de recherche | ||||
| * renomme date de début en date d'ouverture dans le formulaire parcours | ||||
| * [homepage widget] improve content tables, improve counter pluralization with style on number | ||||
| * [notification lists] add comments counter information | ||||
| * [workflows] fix popover header with previous transition | ||||
| * [parcours]: validation + message for closing parcours adjusted. | ||||
| * [household]: household composition double edit button replaced by a delete action (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/426) | ||||
| [fast_actions] improve fast-actions buttons override mechanism, fix https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/413 | ||||
| [homepage widget] add vue homepage_widget with asynchone loading, give a global view resume of the user concerned actions, notifications, etc. | ||||
| * [person]: Comment on marital status is possible even if marital status is not defined (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/421) | ||||
| * [parcours]: In the list of person results the requestor is not displayed if defined as anonymous (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/424) | ||||
| * [bugfix]: modal closes and newly created person/thirdparty is selected when multiple persons/thirdparties are created through the modal (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/429) | ||||
| * [person_resource]: Onthefly button added to view person/thirdparty and badge differentiation for a contact-thirdparty (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/428) | ||||
| * [workflow][notification] improve how notifications and workflows are 'attached' to entities: contextual list, counter, buttons and vue modal | ||||
| * [AddAddress] disable multiselect search, and rely only on most pertinent Cities and Street computed backend | ||||
| * [fast_actions] improve fast-actions buttons override mechanism, fix https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/413 | ||||
| * [homepage widget] add vue homepage_widget with asynchone loading, give a global view resume of the user concerned actions, notifications, etc. | ||||
| * [thirdparty] Add a contact to a thirdparty from within onTheFly (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/345) | ||||
|  | ||||
|  | ||||
| ## Test releases | ||||
| ======= | ||||
| * [homepage widget] add vue homepage_widget with asynchone loading, give a global view resume of the user concerned actions, notifications, etc. | ||||
| >>>>>>> issue422_and_others_on_AddPersons | ||||
|  | ||||
| ======= | ||||
| * [homepage widget] add vue homepage_widget with asynchone loading, give a global view resume of the user concerned actions, notifications, etc. | ||||
| * [thirdparty] Add a contact to a thirdparty from within onTheFly (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/345) | ||||
|  | ||||
| >>>>>>> b0d50d315c8e00959a967badac9cf5057ab2b4bc | ||||
| ### test release 2021-01-31 | ||||
|  | ||||
| * [person] accompanying course: optimisation: do not fetch some resources for the banner (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/409) | ||||
| * [person] accompanying course: close modal when edit participation (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/420) | ||||
| * [person] accompanying course: treat validation error when editing on-the-fly entities (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/420) | ||||
| * [activity] show activity attendee (présence) in the activity list (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/412) | ||||
| * [activity] admin: change validation rule for social action visible field (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/413) | ||||
| * [parcours]: component added to change the opening date of a parcours (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/411) | ||||
| * [search]: listing of parcours display changed (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/410) | ||||
| * [user]: page with accompanying periods to which is user is referent (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/408) | ||||
| * [person] age added to renderstring + renderbox/ vue component created to display person text (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/389) | ||||
| * [household member editor] allow to push to existing household | ||||
|  | ||||
|  | ||||
| ### test release 2021-01-28 | ||||
|  | ||||
| * [person] improve filiations vis graph: disable physics, use chill colors for persons-households-course, increase label of relations, remove labels on household arrows and other improvements (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/286, https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/362) | ||||
| * [activity] Order activity by date and by id (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/364) | ||||
| * [main] increase length of 4 Address fields (change to TEXT, no size limits) (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/277) | ||||
| * [main] Add confidential option for address, in edit and view (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/165) | ||||
| * [person] name suggestions within create person form when person is created departing from a search input (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/377) | ||||
| * [person] Add residential address entity, form and list for each person | ||||
| * [aside_activity]: dynamicUserPickerType used (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/399) | ||||
| * dispatching list | ||||
|  | ||||
|  | ||||
| ### test release 2021-01-26 | ||||
|  | ||||
| * [parcours] comments truncated if too long + link added (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/406) | ||||
| * [person]: possibility to add person resources (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/382) | ||||
| * [person ressources]: module added | ||||
|  | ||||
|  | ||||
| ### test release 2022-01-24 | ||||
|  | ||||
| * [person] name suggestions within create person form when person is created departing from a search input (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/377) | ||||
| * [notification: formulaire création] descend la box avec la description dans le bas du formulaire | ||||
| * [notification for activity]: fix link to activity | ||||
| * [notification] add "URGENT" before accompanying course with emergency = true | ||||
| * [notification] add a "read more" button on system notification | ||||
| * [notification] add `[Chill]` in the subject of each notification, automatically | ||||
| * [notification] add a counter for notification in activity list and accompanying period list, and search results | ||||
| * [parcours] bugfix if deathdate is not defined (eg. for a thirdparty) parcours is still displayed. Gave error before. | ||||
| * [workflow] add breadcrumb to show steps | ||||
| * [popover] add popover html popup mechanism (used by workflow breadcrumb) | ||||
| * [templates] improve updatedBy macro in item metadatas | ||||
| * [parcours]: bug fix when comment is pinned all other comments remain in the collection (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/385) | ||||
| * [workflow] | ||||
|   * add My workflow section with my opened subscriptions | ||||
|   * apply workflow on documents, accompanyingCourseWork and Evaluations | ||||
| * [wopi-link] a new vue component allow to open wopi link in a fullscreen chill-themed modal | ||||
|  | ||||
| ### test release 2022-01-19 | ||||
| * vuejs: add dead information on all on-the-fly person render boxes, in vis graph and other templates (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/271) | ||||
| * [thirdparty] fix bug in 3rd party view: types was replaced by thirdPartyTypes | ||||
| * [main] location form type: fix unmapped address field (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/246) | ||||
| * [activity] fix wrong import of js assets for adding and viewing documents in activity (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/83 & https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/176) | ||||
| * [person]: space added between deathdate and age in twig renderbox (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/380) | ||||
| * [forms] dynamic picker types for user/person/thirdparty types created (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/386) | ||||
|  | ||||
| ### test release 2022-01-17 | ||||
|  | ||||
| * [main] Add editableByUser field to locationType entity, adapt the admin template and add this condition in the location-type endpoint (see https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/297) | ||||
| * [main] Add mainLocation field to User entity and add it in user form type | ||||
| * rewrite page which allow to select activity | ||||
| * [main] Add mainLocation field to User entity and add it in user form type | ||||
| * [course list in person context] show full username/label for ref | ||||
| * [accompanying period work] remove the possibility to  generate document from an accompanying period work | ||||
| * vuejs: add validation on required fields for AddPerson, Address and Location components | ||||
| * vuejs: treat 422 validation errors in locations and AddPerson components | ||||
| * [person]: space added between deathdate and age in twig renderbox (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/380) | ||||
|  | ||||
| ## Test releases | ||||
| * vuejs: add validation on required fields for AddPerson, Address and Location components | ||||
| * vuejs: treat 422 validation errors in locations and AddPerson components | ||||
| * [person]: space added between deathdate and age in twig renderbox (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/380) | ||||
|  | ||||
| ### test release 2022-01-12 | ||||
|  | ||||
| * fix thirdparty normalizer on telephone field: https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/322 | ||||
|  | ||||
| ### test release 2022-01-11 | ||||
|  | ||||
| * vuejs: translate in French all multiselect widgets | ||||
| * [address] define address lines according postal standards for France and Belgium (default) and change AddressRender, chill_entity_render_box and AddressRenderBox.vue | ||||
| * [household] change translations (champs-libres/departement-de-la-vendee/accent-suivi-developpement#109) | ||||
| * [household] add address i18n in household component (champs-libres/departement-de-la-vendee/accent-suivi-developpement#158) | ||||
| * [household] add on the fly i18n in household component | ||||
| @@ -264,9 +20,6 @@ and this project adheres to | ||||
| * [household] household member editor: remove markNoAddress button (champs-libres/departement-de-la-vendee/accent-suivi-developpement#109) | ||||
| * [person]: ordering fields in add person (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/61) | ||||
| * [person]: Add email and alt names in add person (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/61) | ||||
| * [accompanyingCourse] Add a delete action and delete buttons to delete a accompanying course when step = DRAFT (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/64) | ||||
| * [accompanyingCourse] Add a administrative location in the accompanying course, set the user current location as default, allow to select a location in a select field and do not allow to confirm the accompanying course if location is empty. | ||||
| * [accompanyingCourse] Add the administrative location in the available variables for document generation | ||||
| * AddAddress: optimize loading: wait for the user finish typing; | ||||
| * UserPicker: fix bug with deprecated role | ||||
| * docgen: add base context + tests | ||||
| @@ -282,10 +35,8 @@ and this project adheres to | ||||
| * address reference: add index for refid | ||||
| * [accompanyingCourse_work] fix styles conflicts + fix bug with remove goal (remove goals one at a time) | ||||
| * [accompanyingCourse] improve masonry on resume page, add origin | ||||
| * [notification] new notification interface, can be associated to AccompanyingCourse/Period, Activities. | ||||
|   * List notifications, show, and comment in User section | ||||
|   * Notify button and contextual notification box on associated objects pages | ||||
| * [accompanyingCourse] add a comment for each resource associated. A modal allow to save comment. Comment is displayed in on-the-fly show modal of the accompanyingCourse context (edit page + resume page). | ||||
|  | ||||
| ## Test releases | ||||
|  | ||||
| ### test release 2021-12-14 | ||||
|  | ||||
| @@ -375,7 +126,6 @@ and this project adheres to | ||||
| * add an endpoint for checking permissions. See https://gitlab.com/Chill-Projet/chill-bundles/-/merge_requests/232 | ||||
| * [activity] for a new activity: suggest and create on-the-fly locations based on the accompanying course location + location of the suggested parties | ||||
| * [calendar] for a new rdv: suggest and create on-the-fly locations based on the accompanying course location + location of the suggested parties | ||||
| * [period] Validation added when period is confidential and confirmed -> user cannot be null. | ||||
|  | ||||
|  | ||||
| ## Test releases | ||||
|   | ||||
| @@ -22,7 +22,6 @@ | ||||
|         "league/csv": "^9.7.1", | ||||
|         "nyholm/psr7": "^1.4", | ||||
|         "ocramius/package-versions": "^1.10", | ||||
|         "odolbeau/phone-number-bundle": "^3.6", | ||||
|         "phpoffice/phpspreadsheet": "^1.16", | ||||
|         "ramsey/uuid-doctrine": "^1.7", | ||||
|         "sensio/framework-extra-bundle": "^5.5", | ||||
| @@ -34,8 +33,7 @@ | ||||
|         "symfony/form": "^4.4", | ||||
|         "symfony/framework-bundle": "^4.4", | ||||
|         "symfony/intl": "^4.4", | ||||
|         "symfony/mailer": "^5.4", | ||||
|         "symfony/mime": "^5.4", | ||||
|         "symfony/mime": "^4.4", | ||||
|         "symfony/monolog-bundle": "^3.5", | ||||
|         "symfony/security-bundle": "^4.4", | ||||
|         "symfony/serializer": "^5.3", | ||||
| @@ -49,16 +47,13 @@ | ||||
|         "symfony/yaml": "^4.4", | ||||
|         "twig/extra-bundle": "^3.0", | ||||
|         "twig/intl-extra": "^3.0", | ||||
|         "twig/markdown-extra": "^3.3", | ||||
|         "twig/string-extra": "^3.3", | ||||
|         "twig/twig": "^3.0" | ||||
|         "twig/markdown-extra": "^3.3" | ||||
|     }, | ||||
|     "require-dev": { | ||||
|         "doctrine/doctrine-fixtures-bundle": "^3.3", | ||||
|         "drupol/php-conventions": "^5", | ||||
|         "fakerphp/faker": "^1.13", | ||||
|         "nelmio/alice": "^3.8", | ||||
|         "phpspec/prophecy-phpunit": "^2.0", | ||||
|         "phpstan/phpstan-strict-rules": "^1.0", | ||||
|         "phpunit/phpunit": ">= 7.5", | ||||
|         "symfony/debug-bundle": "^5.1", | ||||
| @@ -75,11 +70,8 @@ | ||||
|     "autoload": { | ||||
|         "psr-4": { | ||||
|             "Chill\\ActivityBundle\\": "src/Bundle/ChillActivityBundle", | ||||
|             "Chill\\AsideActivityBundle\\": "src/Bundle/ChillAsideActivityBundle/src", | ||||
|             "Chill\\BudgetBundle\\": "src/Bundle/ChillBudgetBundle", | ||||
|             "Chill\\CalendarBundle\\": "src/Bundle/ChillCalendarBundle", | ||||
|             "Chill\\CustomFieldsBundle\\": "src/Bundle/ChillCustomFieldsBundle", | ||||
|             "Chill\\DocGeneratorBundle\\": "src/Bundle/ChillDocGeneratorBundle", | ||||
|             "Chill\\DocStoreBundle\\": "src/Bundle/ChillDocStoreBundle", | ||||
|             "Chill\\EventBundle\\": "src/Bundle/ChillEventBundle", | ||||
|             "Chill\\FamilyMemberBundle\\": "src/Bundle/ChillFamilyMemberBundle", | ||||
| @@ -88,6 +80,9 @@ | ||||
|             "Chill\\ReportBundle\\": "src/Bundle/ChillReportBundle", | ||||
|             "Chill\\TaskBundle\\": "src/Bundle/ChillTaskBundle", | ||||
|             "Chill\\ThirdPartyBundle\\": "src/Bundle/ChillThirdPartyBundle", | ||||
|             "Chill\\AsideActivityBundle\\": "src/Bundle/ChillAsideActivityBundle/src", | ||||
|             "Chill\\DocGeneratorBundle\\": "src/Bundle/ChillDocGeneratorBundle", | ||||
|             "Chill\\CalendarBundle\\": "src/Bundle/ChillCalendarBundle", | ||||
|             "Chill\\WopiBundle\\": "src/Bundle/ChillWopiBundle/src" | ||||
|         } | ||||
|     }, | ||||
| @@ -100,10 +95,10 @@ | ||||
|     "config": { | ||||
|         "allow-plugins": { | ||||
|             "composer/package-versions-deprecated": true, | ||||
|             "phpstan/extension-installer": true, | ||||
|             "ergebnis/composer-normalize": true, | ||||
|             "ocramius/package-versions": true, | ||||
|             "phpro/grumphp": true, | ||||
|             "phpstan/extension-installer": true | ||||
|             "ocramius/package-versions": true | ||||
|         }, | ||||
|         "bin-dir": "bin", | ||||
|         "optimize-autoloader": true, | ||||
| @@ -112,8 +107,8 @@ | ||||
|     }, | ||||
|     "scripts": { | ||||
|         "auto-scripts": { | ||||
|             "assets:install %PUBLIC_DIR%": "symfony-cmd", | ||||
|             "cache:clear": "symfony-cmd" | ||||
|             "cache:clear": "symfony-cmd", | ||||
|             "assets:install %PUBLIC_DIR%": "symfony-cmd" | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -32,7 +32,7 @@ Then, render the pagination using the dedicated twig function. | ||||
|  | ||||
|    {% block title 'Item list'|trans %} | ||||
|  | ||||
|    {% block content %} | ||||
|    {% block personcontent %} | ||||
|  | ||||
|    <table> | ||||
|  | ||||
|   | ||||
| @@ -156,7 +156,7 @@ This layout extend `ChillMainBundle::layoutWithVerticalMenu.html.twig` add the p | ||||
|  | ||||
| It proposes 1 new block : | ||||
|  | ||||
| * content | ||||
| * personcontent | ||||
|  | ||||
|   * where to display the information of the person | ||||
|  | ||||
|   | ||||
							
								
								
									
										3
									
								
								package.json.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								package.json.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| add npm/yarn dependency in package.json : | ||||
|  | ||||
| "select2-bootstrap-theme": "0.1.0-beta.10", | ||||
| @@ -80,6 +80,11 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Form/ChoiceLoader/PersonChoiceLoader.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Foreach overwrites \\$action with its value variable\\.$#" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Foreach overwrites \\$action with its value variable\\.$#" | ||||
| 			count: 1 | ||||
|   | ||||
| @@ -25,6 +25,41 @@ parameters: | ||||
|             count: 1 | ||||
|             path: src/Bundle/ChillActivityBundle/Repository/ActivityACLAwareRepository.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Access to an undefined property Chill\\\\PersonBundle\\\\Household\\\\MembersEditorFactory\\:\\:\\$validator\\.$#" | ||||
|             count: 2 | ||||
|             path: src/Bundle/ChillPersonBundle/Household/MembersEditorFactory.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Parameter \\$action of method Chill\\\\PersonBundle\\\\Repository\\\\AccompanyingPeriod\\\\AccompanyingPeriodWorkRepository\\:\\:buildQueryBySocialActionWithDescendants\\(\\) has invalid type Chill\\\\PersonBundle\\\\Repository\\\\AccompanyingPeriod\\\\SocialAction\\.$#" | ||||
|             count: 1 | ||||
|             path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Parameter \\$action of method Chill\\\\PersonBundle\\\\Repository\\\\AccompanyingPeriod\\\\AccompanyingPeriodWorkRepository\\:\\:countBySocialActionWithDescendants\\(\\) has invalid type Chill\\\\PersonBundle\\\\Repository\\\\AccompanyingPeriod\\\\SocialAction\\.$#" | ||||
|             count: 1 | ||||
|             path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Undefined variable\\: \\$action$#" | ||||
|             count: 1 | ||||
|             path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Undefined variable\\: \\$limit$#" | ||||
|             count: 1 | ||||
|             path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Undefined variable\\: \\$offset$#" | ||||
|             count: 1 | ||||
|             path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Undefined variable\\: \\$orderBy$#" | ||||
|             count: 1 | ||||
|             path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
|         - | ||||
|             message: "#^Variable variables are not allowed\\.$#" | ||||
|             count: 4 | ||||
|   | ||||
| @@ -105,6 +105,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Export/Export/ListActivity.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ActivityBundle\\\\Export\\\\Export\\\\ListActivity\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Export/Export/ListActivity.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -132,6 +141,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Export/Export/StatActivityDuration.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ActivityBundle\\\\Export\\\\Filter\\\\ActivityDateFilter\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Export/Filter/ActivityDateFilter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -177,6 +195,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Export/Filter/ActivityTypeFilter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ActivityBundle\\\\Export\\\\Filter\\\\PersonHavingActivityBetweenDateFilter\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Export/Filter/PersonHavingActivityBetweenDateFilter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -186,6 +213,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Export/Filter/PersonHavingActivityBetweenDateFilter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ActivityBundle\\\\Menu\\\\PersonMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Menu/PersonMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -222,6 +258,78 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillActivityBundle/Timeline/TimelineActivityProvider.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\AsideActivityBundle\\\\Menu\\\\UserMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillAsideActivityBundle/src/Menu/UserMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Class Chill\\\\AMLI\\\\BudgetBundle\\\\Controller\\\\AbstractElementController extends deprecated class Symfony\\\\Bundle\\\\FrameworkBundle\\\\Controller\\\\Controller\\: | ||||
| 					since Symfony 4\\.2, use "Symfony\\\\Bundle\\\\FrameworkBundle\\\\Controller\\\\AbstractController" instead\\.$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillBudgetBundle/Controller/AbstractElementController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\AMLI\\\\BudgetBundle\\\\Controller\\\\AbstractElementController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillBudgetBundle/Controller/AbstractElementController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Class Chill\\\\AMLI\\\\BudgetBundle\\\\Controller\\\\ElementController extends deprecated class Symfony\\\\Bundle\\\\FrameworkBundle\\\\Controller\\\\Controller\\: | ||||
| 					since Symfony 4\\.2, use "Symfony\\\\Bundle\\\\FrameworkBundle\\\\Controller\\\\AbstractController" instead\\.$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillBudgetBundle/Controller/ElementController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\AMLI\\\\BudgetBundle\\\\Controller\\\\ElementController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillBudgetBundle/Controller/ElementController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\AMLI\\\\BudgetBundle\\\\Menu\\\\UserMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillBudgetBundle/Menu/UserMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Instantiation of deprecated class Symfony\\\\Component\\\\Security\\\\Core\\\\Role\\\\Role\\: | ||||
| 					since Symfony 4\\.3, to be removed in 5\\.0\\. Use strings as roles instead\\.$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillBudgetBundle/Security/Authorization/BudgetElementVoter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\CalendarBundle\\\\Menu\\\\UserMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillCalendarBundle/Menu/UserMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -291,6 +399,33 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillCustomFieldsBundle/Entity/CustomFieldsGroup.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\CustomFieldsBundle\\\\Form\\\\CustomFieldsGroupType\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillCustomFieldsBundle/Form/CustomFieldsGroupType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Call to deprecated method getReachableScopes\\(\\) of class Chill\\\\MainBundle\\\\Security\\\\Authorization\\\\AuthorizationHelper\\: | ||||
| 					Use getReachableCircles$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillDocStoreBundle/Controller/DocumentPersonController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\DocStoreBundle\\\\Controller\\\\DocumentPersonController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillDocStoreBundle/Controller/DocumentPersonController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -300,6 +435,15 @@ parameters: | ||||
| 			count: 6 | ||||
| 			path: src/Bundle/ChillEventBundle/Controller/EventController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\EventBundle\\\\Controller\\\\EventController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillEventBundle/Controller/EventController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -318,6 +462,42 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillEventBundle/Form/Type/PickEventType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\EventBundle\\\\Form\\\\Type\\\\PickEventType\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillEventBundle/Form/Type/PickEventType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\EventBundle\\\\Form\\\\Type\\\\PickRoleType\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillEventBundle/Form/Type/PickRoleType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\EventBundle\\\\Form\\\\Type\\\\PickStatusType\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillEventBundle/Form/Type/PickStatusType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\EventBundle\\\\Menu\\\\PersonMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillEventBundle/Menu/PersonMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -327,6 +507,24 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillEventBundle/Search/EventSearch.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\AMLI\\\\FamilyMembersBundle\\\\Controller\\\\FamilyMemberController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillFamilyMembersBundle/Controller/FamilyMemberController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\AMLI\\\\FamilyMembersBundle\\\\Menu\\\\UserMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillFamilyMembersBundle/Menu/UserMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -336,6 +534,24 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillFamilyMembersBundle/Security/Voter/FamilyMemberVoter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Fetching class constant class of deprecated class Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/CRUD/Controller/AbstractCRUDController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Fetching class constant class of deprecated class Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/CRUD/Controller/CRUDController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -345,6 +561,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/CRUD/Controller/CRUDController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Return type of method Chill\\\\MainBundle\\\\CRUD\\\\Controller\\\\CRUDController\\:\\:getTranslator\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/CRUD/Controller/CRUDController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -363,6 +588,24 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Command/LoadCountriesCommand.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\MainBundle\\\\Controller\\\\ExportController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Controller/ExportController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\MainBundle\\\\Controller\\\\PasswordController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Controller/PasswordController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -435,6 +678,42 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Export/ExportManager.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translatorInterface of method Chill\\\\MainBundle\\\\Export\\\\Formatter\\\\CSVListFormatter\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Export/Formatter/CSVListFormatter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translatorInterface of method Chill\\\\MainBundle\\\\Export\\\\Formatter\\\\CSVPivotedListFormatter\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Export/Formatter/CSVPivotedListFormatter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translatorInterface of method Chill\\\\MainBundle\\\\Export\\\\Formatter\\\\SpreadSheetFormatter\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Export/Formatter/SpreadSheetFormatter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translatorInterface of method Chill\\\\MainBundle\\\\Export\\\\Formatter\\\\SpreadsheetListFormatter\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Export/Formatter/SpreadsheetListFormatter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -453,6 +732,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Form/Event/CustomizeFormEvent.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\MainBundle\\\\Form\\\\Type\\\\PostalCodeType\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Form/Type/PostalCodeType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -476,11 +764,38 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Form/UserType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\MainBundle\\\\Notification\\\\Mailer\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Notification/Mailer.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Only booleans are allowed in an if condition, mixed given\\.$#" | ||||
| 			count: 2 | ||||
| 			path: src/Bundle/ChillMainBundle/Repository/NotificationRepository.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\MainBundle\\\\Routing\\\\MenuBuilder\\\\SectionMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Routing/MenuBuilder/SectionMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\MainBundle\\\\Routing\\\\MenuComposer\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Routing/MenuComposer.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -567,6 +882,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Templating/Events/DelegatedBlockRenderingEvent.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\MainBundle\\\\Validation\\\\Validator\\\\RoleScopeScopePresence\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Validation/Validator/RoleScopeScopePresence.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -603,6 +927,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/AccompanyingCourseController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$trans of method Chill\\\\PersonBundle\\\\Controller\\\\AccompanyingCourseWorkController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/AccompanyingCourseWorkController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -612,6 +945,33 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/AccompanyingPeriodController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Controller\\\\HouseholdController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/HouseholdController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Controller\\\\HouseholdMemberController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/HouseholdMemberController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Controller\\\\PersonController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/PersonController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -621,6 +981,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/PersonDuplicateController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Controller\\\\PersonDuplicateController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Controller/PersonDuplicateController.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Access to deprecated property \\$proxyAccompanyingPeriodOpenState of class Chill\\\\PersonBundle\\\\Entity\\\\Person\\.$#" | ||||
| 			count: 2 | ||||
| @@ -635,6 +1004,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Aggregator/AgeAggregator.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Export\\\\Aggregator\\\\CountryOfBirthAggregator\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Aggregator/CountryOfBirthAggregator.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -644,6 +1022,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Aggregator/CountryOfBirthAggregator.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Export\\\\Aggregator\\\\GenderAggregator\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Aggregator/GenderAggregator.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -653,6 +1040,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Aggregator/GenderAggregator.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Export\\\\Aggregator\\\\NationalityAggregator\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Aggregator/NationalityAggregator.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -689,6 +1085,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Export/ListPerson.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Export\\\\Export\\\\ListPerson\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Export/ListPerson.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -716,6 +1121,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Export/ListPersonDuplicate.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Export\\\\Export\\\\ListPersonDuplicate\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Export/ListPersonDuplicate.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -761,6 +1175,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Filter/BirthdateFilter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Export\\\\Filter\\\\GenderFilter\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Export/Filter/GenderFilter.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -802,6 +1225,24 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Form/Type/PickPersonType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Form\\\\Type\\\\PickPersonType\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Form/Type/PickPersonType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\PersonBundle\\\\Menu\\\\SectionMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Menu/SectionMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -865,6 +1306,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillReportBundle/Export/Export/ReportList.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ReportBundle\\\\Export\\\\Export\\\\ReportList\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillReportBundle/Export/Export/ReportList.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -874,6 +1324,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillReportBundle/Export/Export/ReportList.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ReportBundle\\\\Export\\\\Export\\\\ReportListProvider\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillReportBundle/Export/Export/ReportListProvider.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -955,6 +1414,15 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillTaskBundle/Controller/SingleTaskController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\TaskBundle\\\\Controller\\\\TaskController\\:\\:applyTransitionAction\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillTaskBundle/Controller/TaskController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -1000,6 +1468,33 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillTaskBundle/Form/SingleTaskType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\TaskBundle\\\\Menu\\\\MenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillTaskBundle/Menu/MenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\TaskBundle\\\\Menu\\\\SectionMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillTaskBundle/Menu/SectionMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\TaskBundle\\\\Menu\\\\UserMenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillTaskBundle/Menu/UserMenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| @@ -1036,6 +1531,33 @@ parameters: | ||||
| 			count: 3 | ||||
| 			path: src/Bundle/ChillTaskBundle/Timeline/TaskLifeCycleEventTimelineProvider.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ThirdPartyBundle\\\\Controller\\\\ThirdPartyController\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillThirdPartyBundle/Controller/ThirdPartyController.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ThirdPartyBundle\\\\Form\\\\Type\\\\PickThirdPartyType\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillThirdPartyBundle/Form/Type/PickThirdPartyType.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
| 					#^Parameter \\$translator of method Chill\\\\ThirdPartyBundle\\\\Menu\\\\MenuBuilder\\:\\:__construct\\(\\) has typehint with deprecated interface Symfony\\\\Component\\\\Translation\\\\TranslatorInterface\\: | ||||
| 					since Symfony 4\\.2, use Symfony\\\\Contracts\\\\Translation\\\\TranslatorInterface instead$# | ||||
| 				""" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillThirdPartyBundle/Menu/MenuBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: | ||||
| 				""" | ||||
|   | ||||
| @@ -250,6 +250,11 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Entity/Address.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Entity/Embeddable/CommentEmbeddable.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 1 | ||||
| @@ -290,6 +295,11 @@ parameters: | ||||
| 			count: 3 | ||||
| 			path: src/Bundle/ChillMainBundle/Form/Type/DataTransformer/DateIntervalTransformer.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Only booleans are allowed in a negated boolean, mixed given\\.$#" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Form/Type/DataTransformer/ObjectToIdTransformer.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 2 | ||||
| @@ -305,6 +315,11 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Security/PasswordRecover/TokenManager.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 3 | ||||
| 			path: src/Bundle/ChillMainBundle/Templating/Entity/AddressRender.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 1 | ||||
| @@ -315,6 +330,11 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Timeline/TimelineBuilder.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillMainBundle/Validation/Validator/ValidPhonenumber.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 1 | ||||
| @@ -345,6 +365,11 @@ parameters: | ||||
| 			count: 6 | ||||
| 			path: src/Bundle/ChillPersonBundle/Command/ImportPeopleFromCSVCommand.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 2 | ||||
| 			path: src/Bundle/ChillPersonBundle/Entity/PersonPhone.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 1 | ||||
| @@ -380,6 +405,11 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Form/Type/PersonPhoneType.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Method Chill\\\\PersonBundle\\\\Repository\\\\AccompanyingPeriod\\\\AccompanyingPeriodWorkRepository\\:\\:buildQueryBySocialActionWithDescendants\\(\\) has invalid return type Chill\\\\PersonBundle\\\\Repository\\\\AccompanyingPeriod\\\\QueryBuilder\\.$#" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 3 | ||||
| @@ -460,3 +490,8 @@ parameters: | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillThirdPartyBundle/Search/ThirdPartySearch.php | ||||
|  | ||||
| 		- | ||||
| 			message: "#^Construct empty\\(\\) is not allowed\\. Use more strict comparison\\.$#" | ||||
| 			count: 1 | ||||
| 			path: src/Bundle/ChillThirdPartyBundle/Templating/Entity/ThirdPartyRender.php | ||||
|  | ||||
|   | ||||
| @@ -6,6 +6,7 @@ | ||||
|          backupGlobals="false" | ||||
|          colors="true" | ||||
|          bootstrap="tests/app/tests/bootstrap.php" | ||||
|          stopOnFailure="true" | ||||
| > | ||||
|     <php> | ||||
|         <ini name="error_reporting" value="-1" /> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <files psalm-version="4.18.0.0"> | ||||
| <files psalm-version="v4.15.0@a1b5e489e6fcebe40cb804793d964e99fc347820"> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Controller/ActivityReasonCategoryController.php"> | ||||
|     <UndefinedClass occurrences="4"> | ||||
|       <code>'ChillActivityBundle:ActivityReasonCategory'</code> | ||||
| @@ -47,11 +47,6 @@ | ||||
|       <code>Activity[]|array</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Resources/test/Fixtures/App/app/AppKernel.php"> | ||||
|     <DuplicateClass occurrences="1"> | ||||
|       <code>AppKernel</code> | ||||
|     </DuplicateClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Resources/test/Fixtures/App/app/autoload.php"> | ||||
|     <MissingFile occurrences="1"> | ||||
|       <code>require __DIR__ . '/../../../../../vendor/autoload.php'</code> | ||||
| @@ -169,18 +164,72 @@ | ||||
|       <code>type</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Aggregator/ActivityReasonAggregatorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Aggregator/ActivityTypeAggregatorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Aggregator/ActivityUserAggregatorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Export/CountActivityTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Export/ListActivityTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Export/StatActivityDurationSumTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Filter/ActivityReasonFilterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Export/Filter/PersonHavingActivityBetweenDateFilterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>\Chill\PersonBundle\Export\Filter\PersonHavingActivityBetweenDateFilter</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Form/ActivityTypeTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Form/Type/TranslatableActivityReasonTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <TooFewArguments occurrences="2"/> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>Prophecy\Prophet</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Form/Type/TranslatableActivityTypeTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillActivityBundle/Tests/Security/Authorization/ActivityVoterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>type</code> | ||||
|     </UndefinedDocblockClass> | ||||
| @@ -205,6 +254,11 @@ | ||||
|       <code>$asideActivityCategory</code> | ||||
|     </ParamNameMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillAsideActivityBundle/src/Tests/Controller/AsideActivityControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillBudgetBundle/Calculator/CalculatorManager.php"> | ||||
|     <InvalidStaticInvocation occurrences="3"> | ||||
|       <code>$calculator::getAlias()</code> | ||||
| @@ -234,6 +288,11 @@ | ||||
|       <code>'ChillCalendarBundle:Calendar'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCalendarBundle/Tests/Controller/CalendarControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Command/CreateFieldsOnGroupCommand.php"> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillCustomFieldsBundle:CustomFieldsGroup'</code> | ||||
| @@ -338,6 +397,10 @@ | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/CustomFields/CustomFieldsChoiceTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="4"> | ||||
|       <code>type</code> | ||||
|       <code>type</code> | ||||
| @@ -345,6 +408,61 @@ | ||||
|       <code>type</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/CustomFields/CustomFieldsNumberTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/CustomFields/CustomFieldsTextTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/Form/Extension/PostTextIntegerExtensionTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/Form/Extension/PostTextNumberExtensionTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/Service/CustomFieldsHelperTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/Templating/Twig/CustomFieldRenderingTwigTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillCustomFieldsBundle/Tests/Templating/Twig/CustomFieldsGroupRenderingTwigTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillDocGeneratorBundle/tests/Serializer/Encoder/DocGenEncoderTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillDocGeneratorBundle/tests/Serializer/Normalizer/DocGenObjectNormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillDocGeneratorBundle/tests/Service/Context/BaseContextDataTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillDocStoreBundle/Controller/DocumentAccompanyingCourseController.php"> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillDocStoreBundle:AccompanyingCourseDocument'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillDocStoreBundle/Controller/DocumentCategoryController.php"> | ||||
|     <UndefinedClass occurrences="3"> | ||||
|       <code>'ChillDocStoreBundle:DocumentCategory'</code> | ||||
| @@ -352,6 +470,11 @@ | ||||
|       <code>'ChillDocStoreBundle:DocumentCategory'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillDocStoreBundle/Controller/DocumentPersonController.php"> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillDocStoreBundle:PersonDocument'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillDocStoreBundle/Entity/Document.php"> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>\Chill\PersonBundle\Entity\user</code> | ||||
| @@ -447,6 +570,9 @@ | ||||
|     <InvalidParamDefault occurrences="1"> | ||||
|       <code>type</code> | ||||
|     </InvalidParamDefault> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="8"> | ||||
|       <code>'ChillEventBundle:Event'</code> | ||||
|       <code>'ChillEventBundle:Event'</code> | ||||
| @@ -462,6 +588,10 @@ | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillEventBundle/Tests/Search/EventSearchTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillMainBundle:Scope'</code> | ||||
|     </UndefinedClass> | ||||
| @@ -761,6 +891,11 @@ | ||||
|       <code>OptionsResolverInterface</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Notification/Mailer.php"> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>\Symfony\Component\Mailer\Exception\TransportExceptionInterface</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Pagination/PageGenerator.php"> | ||||
|     <UndefinedVariable occurrences="1"> | ||||
|       <code>$current</code> | ||||
| @@ -789,6 +924,11 @@ | ||||
|       <code>$onlyEnabled</code> | ||||
|     </ParamNameMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Resources/test/Fixtures/App/app/AppKernel.php"> | ||||
|     <DuplicateClass occurrences="1"> | ||||
|       <code>AppKernel</code> | ||||
|     </DuplicateClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Resources/test/Fixtures/App/app/autoload.php"> | ||||
|     <MissingFile occurrences="1"> | ||||
|       <code>require __DIR__ . '/../../../../../vendor/autoload.php'</code> | ||||
| @@ -916,15 +1056,158 @@ | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Test/Export/AbstractFilterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>type</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Authorization/ParentRoleHelperTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Controller/AddressControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Controller/UserControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>protected function tearDown()</code> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Export/ExportManagerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="40"> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>$this->prophet</code> | ||||
|       <code>Prophecy\Prophet</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Form/Type/PickCenterTypeTest.php"> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>CenterType</code> | ||||
|     </UndefinedClass> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>CenterType</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Pagination/PageTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Pagination/PaginatorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Routing/Loader/RouteLoaderTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Search/AbstractSearchTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Search/SearchProviderTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>unknown</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Security/Authorization/AuthorizationHelperTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Security/PasswordRecover/TokenManagerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Security/Resolver/CenterResolverDispatcherTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Security/Resolver/DefaultScopeResolverTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Security/Resolver/ScopeResolverDispatcherTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Serializer/Normalizer/DateNormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Serializer/Normalizer/DoctrineExistingEntityNormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Services/MenuComposerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Tests/Templating/Entity/AddressRenderTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillMainBundle/Timeline/TimelineBuilder.php"> | ||||
|     <UndefinedDocblockClass occurrences="1"> | ||||
|       <code>unknown</code> | ||||
| @@ -1129,6 +1412,20 @@ | ||||
|       <code>OptionsResolverInterface</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Repository/AccompanyingPeriod/AccompanyingPeriodWorkRepository.php"> | ||||
|     <UndefinedClass occurrences="6"> | ||||
|       <code>$qb</code> | ||||
|       <code>$qb</code> | ||||
|       <code>$qb</code> | ||||
|       <code>QueryBuilder</code> | ||||
|       <code>SocialAction</code> | ||||
|       <code>SocialAction</code> | ||||
|     </UndefinedClass> | ||||
|     <UndefinedVariable occurrences="2"> | ||||
|       <code>$action</code> | ||||
|       <code>$orderBy</code> | ||||
|     </UndefinedVariable> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Resources/test/Fixtures/App/app/AppKernel.php"> | ||||
|     <DuplicateClass occurrences="1"> | ||||
|       <code>AppKernel</code> | ||||
| @@ -1208,13 +1505,33 @@ | ||||
|     </ParamNameMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/AccompanyingPeriod/AccompanyingPeriodConfidentialTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public static function setUpBeforeClass()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="2"> | ||||
|       <code>AccompanyingPeriodRepository</code> | ||||
|       <code>stdClass</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/AccompanyingCourseApiControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public static function setUpBeforeClass()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/AccompanyingCourseControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/AccompanyingPeriodControllerTest.php"> | ||||
|     <InvalidThrow occurrences="1"/> | ||||
|     <MethodSignatureMismatch occurrences="3"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|       <code>public static function setUpBeforeClass()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="3"> | ||||
|       <code>'ChillMainBundle:Center'</code> | ||||
|       <code>'ChillPersonBundle:AccompanyingPeriod\ClosingMotive'</code> | ||||
| @@ -1226,19 +1543,40 @@ | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/HouseholdApiControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>User</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/HouseholdControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/PersonAddressControllerTest.php"> | ||||
|     <InvalidScope occurrences="1"> | ||||
|       <code>$this</code> | ||||
|     </InvalidScope> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public static function setUpBeforeClass()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillPersonBundle:Person'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/PersonControllerCreateTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public static function tearDownAfterClass()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/PersonControllerUpdateTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="2"> | ||||
|       <code>'ChillMainBundle:Country'</code> | ||||
|       <code>'ChillPersonBundle:Person'</code> | ||||
| @@ -1248,25 +1586,140 @@ | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/PersonControllerUpdateWithHiddenFieldsTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="2"> | ||||
|       <code>'ChillMainBundle:Country'</code> | ||||
|       <code>'ChillPersonBundle:Person'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/PersonControllerViewTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillPersonBundle:Person'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/PersonControllerViewWithHiddenFieldsTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillPersonBundle:Person'</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/PersonDuplicateControllerViewTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/RelationshipApiControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Controller/SocialIssueApiControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Entity/AccompanyingPeriodTest.php"> | ||||
|     <AssignmentToVoid occurrences="1"> | ||||
|       <code>$participationL</code> | ||||
|     </AssignmentToVoid> | ||||
|     <NullReference occurrences="1"> | ||||
|       <code>getEndDate</code> | ||||
|     </NullReference> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Aggregator/AgeAggregatorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Aggregator/GenderAggregatorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Aggregator/NationalityAggregatorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Export/CountPersonTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Export/ListPersonTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Filter/AccompanyingPeriodFilterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Filter/BirthdayFilterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Export/Filter/GenderFilterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Form/Type/PickPersonTypeTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Household/MembersEditorTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Security/Authorization/PersonVoterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Serializer/Normalizer/AccompanyingPeriodWorkDocGenNormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Serializer/Normalizer/HouseholdNormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Serializer/Normalizer/PersonDocGenNormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Serializer/Normalizer/PersonJsonNormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Validator/Person/PersonValidationTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Tests/Workflows/AccompanyingPeriodLifecycle.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillPersonBundle/Timeline/AbstractTimelineAccompanyingPeriod.php"> | ||||
|     <UndefinedClass occurrences="1"> | ||||
| @@ -1367,13 +1820,20 @@ | ||||
|       <code>require __DIR__ . '/../../../../../vendor/autoload.php'</code> | ||||
|     </MissingFile> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillReportBundle/Tests/Controller/ReportControllerNextTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>public function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillReportBundle/Tests/Controller/ReportControllerTest.php"> | ||||
|     <InvalidParamDefault occurrences="1"> | ||||
|       <code>type</code> | ||||
|     </InvalidParamDefault> | ||||
|     <UndefinedDocblockClass occurrences="31"> | ||||
|       <code>$client</code> | ||||
|       <code>$client</code> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public static function setUpBeforeClass()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="29"> | ||||
|       <code>$client</code> | ||||
|       <code>$client</code> | ||||
|       <code>$client</code> | ||||
| @@ -1405,7 +1865,16 @@ | ||||
|       <code>type</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillReportBundle/Tests/DependencyInjection/ChillReportExtensionTest.php"> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>Exception</code> | ||||
|     </UndefinedClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillReportBundle/Tests/Security/Authorization/ReportVoterTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public static function setUpBeforeClass()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedDocblockClass occurrences="3"> | ||||
|       <code>type</code> | ||||
|       <code>type</code> | ||||
| @@ -1413,6 +1882,10 @@ | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillReportBundle/Tests/Timeline/TimelineProviderTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="2"> | ||||
|       <code>public function setUp()</code> | ||||
|       <code>public function tearDown()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>'ChillCustomFieldsBundle:CustomFieldsGroup'</code> | ||||
|     </UndefinedClass> | ||||
| @@ -1485,6 +1958,11 @@ | ||||
|       <code>CacheItempPoolInterface</code> | ||||
|     </UndefinedDocblockClass> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillTaskBundle/Tests/Controller/SingleTaskControllerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillThirdPartyBundle/DependencyInjection/CompilerPass/ThirdPartyTypeCompilerPass.php"> | ||||
|     <UndefinedClass occurrences="1"> | ||||
|       <code>$taggedService->getClass()::getKey()</code> | ||||
| @@ -1510,6 +1988,11 @@ | ||||
|       <code>$thirdParty</code> | ||||
|     </ParamNameMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillThirdPartyBundle/Tests/Serializer/Normalizer/ThirdPartyJsonDenormalizerTest.php"> | ||||
|     <MethodSignatureMismatch occurrences="1"> | ||||
|       <code>protected function setUp()</code> | ||||
|     </MethodSignatureMismatch> | ||||
|   </file> | ||||
|   <file src="src/Bundle/ChillWopiBundle/src/Service/Wopi/ChillDocumentManager.php"> | ||||
|     <UndefinedDocblockClass occurrences="6"> | ||||
|       <code>$object</code> | ||||
|   | ||||
| @@ -31,17 +31,15 @@ use DateTime; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| use InvalidArgumentException; | ||||
| use Psr\Log\LoggerInterface; | ||||
| use RuntimeException; | ||||
| use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; | ||||
| use Symfony\Component\EventDispatcher\EventDispatcherInterface; | ||||
| use Symfony\Component\Form\Extension\Core\Type\HiddenType; | ||||
| use Symfony\Component\Form\Extension\Core\Type\SubmitType; | ||||
| use Symfony\Component\Form\FormInterface; | ||||
| use Symfony\Component\HttpFoundation\Request; | ||||
| use Symfony\Component\HttpFoundation\Response; | ||||
| use Symfony\Component\Security\Core\Role\Role; | ||||
|  | ||||
| use Symfony\Component\Serializer\SerializerInterface; | ||||
|  | ||||
| use function array_key_exists; | ||||
|  | ||||
| final class ActivityController extends AbstractController | ||||
| @@ -179,15 +177,14 @@ final class ActivityController extends AbstractController | ||||
|     { | ||||
|         $view = null; | ||||
|  | ||||
|         [$person, $accompanyingPeriod] = $this->getEntity($request); | ||||
|  | ||||
|         $entity = $this->activityRepository->find($id); | ||||
|  | ||||
|         if (null === $entity) { | ||||
|             throw $this->createNotFoundException('Unable to find Activity entity.'); | ||||
|         } | ||||
|  | ||||
|         $accompanyingPeriod = $entity->getAccompanyingPeriod(); | ||||
|         $person = $entity->getPerson(); | ||||
|  | ||||
|         if ($entity->getAccompanyingPeriod() instanceof AccompanyingPeriod) { | ||||
|             $view = 'ChillActivityBundle:Activity:editAccompanyingCourse.html.twig'; | ||||
|             $accompanyingPeriod = $entity->getAccompanyingPeriod(); | ||||
| @@ -202,42 +199,17 @@ final class ActivityController extends AbstractController | ||||
|             'role' => new Role('CHILL_ACTIVITY_UPDATE'), | ||||
|             'activityType' => $entity->getActivityType(), | ||||
|             'accompanyingPeriod' => $accompanyingPeriod, | ||||
|         ]); | ||||
|  | ||||
|         if ($form->has('documents')) { | ||||
|             $form->add('gendocTemplateId', HiddenType::class, [ | ||||
|                 'mapped' => false, | ||||
|                 'data' => null, | ||||
|                 'attr' => [ | ||||
|                     // required for js | ||||
|                     'data-template-id' => 'data-template-id', | ||||
|                 ], | ||||
|             ]); | ||||
|         } | ||||
|  | ||||
|         $form->handleRequest($request); | ||||
|         ])->handleRequest($request); | ||||
|  | ||||
|         if ($form->isSubmitted() && $form->isValid()) { | ||||
|             $this->entityManager->persist($entity); | ||||
|             $this->entityManager->flush(); | ||||
|  | ||||
|             $this->addFlash('success', $this->get('translator')->trans('Success : activity updated!')); | ||||
|  | ||||
|             $params = $this->buildParamsToUrl($person, $accompanyingPeriod); | ||||
|             $params['id'] = $entity->getId(); | ||||
|  | ||||
|             if ($form->has('gendocTemplateId') && null !== $form['gendocTemplateId']->getData()) { | ||||
|                 return $this->redirectToRoute( | ||||
|                     'chill_docgenerator_generate_from_template', | ||||
|                     [ | ||||
|                         'template' => $form->get('gendocTemplateId')->getData(), | ||||
|                         'entityClassName' => Activity::class, | ||||
|                         'entityId' => $entity->getId(), | ||||
|                         'returnPath' => $this->generateUrl('chill_activity_activity_edit', $params), | ||||
|                     ] | ||||
|                 ); | ||||
|             } | ||||
|  | ||||
|             $this->addFlash('success', $this->get('translator')->trans('Success : activity updated!')); | ||||
|  | ||||
|             return $this->redirectToRoute('chill_activity_activity_show', $params); | ||||
|         } | ||||
|  | ||||
| @@ -283,7 +255,7 @@ final class ActivityController extends AbstractController | ||||
|         if ($person instanceof Person) { | ||||
|             $this->denyAccessUnlessGranted(ActivityVoter::SEE, $person); | ||||
|             $activities = $this->activityACLAwareRepository | ||||
|                 ->findByPerson($person, ActivityVoter::SEE, 0, null, ['date' => 'DESC', 'id' => 'DESC']); | ||||
|                 ->findByPerson($person, ActivityVoter::SEE, 0, null); | ||||
|  | ||||
|             $event = new PrivacyEvent($person, [ | ||||
|                 'element_class' => Activity::class, | ||||
| @@ -296,7 +268,7 @@ final class ActivityController extends AbstractController | ||||
|             $this->denyAccessUnlessGranted(ActivityVoter::SEE, $accompanyingPeriod); | ||||
|  | ||||
|             $activities = $this->activityACLAwareRepository | ||||
|                 ->findByAccompanyingPeriod($accompanyingPeriod, ActivityVoter::SEE, 0, null, ['date' => 'DESC', 'id' => 'DESC']); | ||||
|                 ->findByAccompanyingPeriod($accompanyingPeriod, ActivityVoter::SEE); | ||||
|  | ||||
|             $view = 'ChillActivityBundle:Activity:listAccompanyingCourse.html.twig'; | ||||
|         } | ||||
| @@ -420,39 +392,12 @@ final class ActivityController extends AbstractController | ||||
|             'role' => new Role('CHILL_ACTIVITY_CREATE'), | ||||
|             'activityType' => $entity->getActivityType(), | ||||
|             'accompanyingPeriod' => $accompanyingPeriod, | ||||
|         ]); | ||||
|  | ||||
|         if ($form->has('documents')) { | ||||
|             $form->add('gendocTemplateId', HiddenType::class, [ | ||||
|                 'mapped' => false, | ||||
|                 'data' => null, | ||||
|                 'attr' => [ | ||||
|                     // required for js | ||||
|                     'data-template-id' => 'data-template-id', | ||||
|                 ], | ||||
|             ]); | ||||
|         } | ||||
|  | ||||
|         $form->handleRequest($request); | ||||
|         ])->handleRequest($request); | ||||
|  | ||||
|         if ($form->isSubmitted() && $form->isValid()) { | ||||
|             $this->entityManager->persist($entity); | ||||
|             $this->entityManager->flush(); | ||||
|  | ||||
|             if ($form->has('gendocTemplateId') && null !== $form['gendocTemplateId']->getData()) { | ||||
|                 return $this->redirectToRoute( | ||||
|                     'chill_docgenerator_generate_from_template', | ||||
|                     [ | ||||
|                         'template' => $form->get('gendocTemplateId')->getData(), | ||||
|                         'entityClassName' => Activity::class, | ||||
|                         'entityId' => $entity->getId(), | ||||
|                         'returnPath' => $this->generateUrl('chill_activity_activity_edit', [ | ||||
|                             'id' => $entity->getId(), | ||||
|                         ]), | ||||
|                     ] | ||||
|                 ); | ||||
|             } | ||||
|  | ||||
|             $this->addFlash('success', $this->get('translator')->trans('Success : activity created!')); | ||||
|  | ||||
|             $params = $this->buildParamsToUrl($person, $accompanyingPeriod); | ||||
| @@ -526,21 +471,20 @@ final class ActivityController extends AbstractController | ||||
|  | ||||
|     public function showAction(Request $request, int $id): Response | ||||
|     { | ||||
|         $entity = $this->activityRepository->find($id); | ||||
|         $view = null; | ||||
|  | ||||
|         if (null === $entity) { | ||||
|             throw $this->createNotFoundException('Unable to find Activity entity.'); | ||||
|         } | ||||
|  | ||||
|         $accompanyingPeriod = $entity->getAccompanyingPeriod(); | ||||
|         $person = $entity->getPerson(); | ||||
|         [$person, $accompanyingPeriod] = $this->getEntity($request); | ||||
|  | ||||
|         if ($accompanyingPeriod instanceof AccompanyingPeriod) { | ||||
|             $view = 'ChillActivityBundle:Activity:showAccompanyingCourse.html.twig'; | ||||
|         } elseif ($person instanceof Person) { | ||||
|             $view = 'ChillActivityBundle:Activity:showPerson.html.twig'; | ||||
|         } else { | ||||
|             throw new RuntimeException('the activity should be linked with a period or person'); | ||||
|         } | ||||
|  | ||||
|         $entity = $this->activityRepository->find($id); | ||||
|  | ||||
|         if (null === $entity) { | ||||
|             throw $this->createNotFoundException('Unable to find Activity entity.'); | ||||
|         } | ||||
|  | ||||
|         if (null !== $accompanyingPeriod) { | ||||
| @@ -549,7 +493,8 @@ final class ActivityController extends AbstractController | ||||
|             $entity->personsNotAssociated = $entity->getPersonsNotAssociated(); | ||||
|         } | ||||
|  | ||||
|         $this->denyAccessUnlessGranted(ActivityVoter::SEE, $entity); | ||||
|         // TODO revoir le Voter de Activity pour tenir compte qu'une activité peut appartenir a une période | ||||
|         // $this->denyAccessUnlessGranted('CHILL_ACTIVITY_SEE', $entity); | ||||
|  | ||||
|         $deleteForm = $this->createDeleteForm($entity->getId(), $person, $accompanyingPeriod); | ||||
|  | ||||
|   | ||||
| @@ -12,7 +12,7 @@ declare(strict_types=1); | ||||
| namespace Chill\ActivityBundle\Entity; | ||||
|  | ||||
| use Chill\ActivityBundle\Validator\Constraints as ActivityValidator; | ||||
| use Chill\DocStoreBundle\Entity\StoredObject; | ||||
| use Chill\DocStoreBundle\Entity\Document; | ||||
| use Chill\MainBundle\Entity\Center; | ||||
| use Chill\MainBundle\Entity\Embeddable\CommentEmbeddable; | ||||
| use Chill\MainBundle\Entity\HasCenterInterface; | ||||
| @@ -67,7 +67,7 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\ActivityBundle\Entity\ActivityType") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      * @SerializedName("activityType") | ||||
|      * @ORM\JoinColumn(name="type_id") | ||||
|      */ | ||||
| @@ -75,19 +75,16 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\ActivityBundle\Entity\ActivityPresence") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private ?ActivityPresence $attendee = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Embedded(class="Chill\MainBundle\Entity\Embeddable\CommentEmbeddable", columnPrefix="comment_") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private CommentEmbeddable $comment; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="datetime") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private DateTime $date; | ||||
|  | ||||
| @@ -103,7 +100,6 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="boolean", options={"default": false}) | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private bool $emergency = false; | ||||
|  | ||||
| @@ -111,13 +107,13 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|      * @ORM\Id | ||||
|      * @ORM\Column(name="id", type="integer") | ||||
|      * @ORM\GeneratedValue(strategy="AUTO") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      */ | ||||
|     private ?int $id = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\MainBundle\Entity\Location") | ||||
|      * @groups({"read", "docgen:read"}) | ||||
|      * @groups({"read"}) | ||||
|      */ | ||||
|     private ?Location $location = null; | ||||
|  | ||||
| @@ -128,45 +124,42 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToMany(targetEntity="Chill\PersonBundle\Entity\Person") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      */ | ||||
|     private ?Collection $persons = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToMany(targetEntity="Chill\ActivityBundle\Entity\ActivityReason") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private Collection $reasons; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\MainBundle\Entity\Scope") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private ?Scope $scope = null; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="string", options={"default": ""}) | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private string $sentReceived = ''; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToMany(targetEntity="Chill\PersonBundle\Entity\SocialWork\SocialAction") | ||||
|      * @ORM\JoinTable(name="chill_activity_activity_chill_person_socialaction") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      */ | ||||
|     private Collection $socialActions; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToMany(targetEntity="Chill\PersonBundle\Entity\SocialWork\SocialIssue") | ||||
|      * @ORM\JoinTable(name="chill_activity_activity_chill_person_socialissue") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      */ | ||||
|     private Collection $socialIssues; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToMany(targetEntity="Chill\ThirdPartyBundle\Entity\ThirdParty") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      */ | ||||
|     private ?Collection $thirdParties = null; | ||||
|  | ||||
| @@ -177,13 +170,12 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne(targetEntity="Chill\MainBundle\Entity\User") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private User $user; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToMany(targetEntity="Chill\MainBundle\Entity\User") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      */ | ||||
|     private ?Collection $users = null; | ||||
|  | ||||
| @@ -199,7 +191,7 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|         $this->socialActions = new ArrayCollection(); | ||||
|     } | ||||
|  | ||||
|     public function addDocument(StoredObject $document): self | ||||
|     public function addDocument(Document $document): self | ||||
|     { | ||||
|         $this->documents[] = $document; | ||||
|  | ||||
| @@ -310,18 +302,6 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|         return $this->documents; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     public function getDurationMinute(): int | ||||
|     { | ||||
|         if (null === $this->durationTime) { | ||||
|             return 0; | ||||
|         } | ||||
|  | ||||
|         return (int) round(($this->durationTime->getTimestamp() + $this->durationTime->getOffset()) / 60.0, 0); | ||||
|     } | ||||
|  | ||||
|     public function getDurationTime(): ?DateTime | ||||
|     { | ||||
|         return $this->durationTime; | ||||
| @@ -357,7 +337,7 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|         if (null !== $this->accompanyingPeriod) { | ||||
|             $personsAssociated = []; | ||||
|  | ||||
|             foreach ($this->accompanyingPeriod->getOpenParticipations() as $participation) { | ||||
|             foreach ($this->accompanyingPeriod->getParticipations() as $participation) { | ||||
|                 if ($this->persons->contains($participation->getPerson())) { | ||||
|                     $personsAssociated[] = $participation->getPerson(); | ||||
|                 } | ||||
| @@ -422,18 +402,6 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|         return $this->travelTime; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     public function getTravelTimeMinute(): int | ||||
|     { | ||||
|         if (null === $this->travelTime) { | ||||
|             return 0; | ||||
|         } | ||||
|  | ||||
|         return (int) round(($this->travelTime->getTimestamp() + $this->travelTime->getOffset()) / 60.0, 0); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @deprecated | ||||
|      */ | ||||
| @@ -457,7 +425,7 @@ class Activity implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterfac | ||||
|         return $this->getEmergency(); | ||||
|     } | ||||
|  | ||||
|     public function removeDocument(StoredObject $document): void | ||||
|     public function removeDocument(Document $document): void | ||||
|     { | ||||
|         $this->documents->removeElement($document); | ||||
|     } | ||||
|   | ||||
| @@ -12,7 +12,6 @@ declare(strict_types=1); | ||||
| namespace Chill\ActivityBundle\Entity; | ||||
|  | ||||
| use Doctrine\ORM\Mapping as ORM; | ||||
| use Symfony\Component\Serializer\Annotation as Serializer; | ||||
|  | ||||
| /** | ||||
|  * Class ActivityPresence. | ||||
| @@ -32,14 +31,11 @@ class ActivityPresence | ||||
|      * @ORM\Id | ||||
|      * @ORM\Column(name="id", type="integer") | ||||
|      * @ORM\GeneratedValue(strategy="AUTO") | ||||
|      * @Serializer\Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private ?int $id; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="json") | ||||
|      * @Serializer\Groups({"docgen:read"}) | ||||
|      * @Serializer\Context({"is-translatable": true}, groups={"docgen:read"}) | ||||
|      */ | ||||
|     private array $name = []; | ||||
|  | ||||
|   | ||||
| @@ -13,10 +13,8 @@ namespace Chill\ActivityBundle\Entity; | ||||
|  | ||||
| use Doctrine\ORM\Mapping as ORM; | ||||
| use InvalidArgumentException; | ||||
| use Symfony\Component\Serializer\Annotation as Serializer; | ||||
| use Symfony\Component\Serializer\Annotation\Groups; | ||||
| use Symfony\Component\Validator\Constraints as Assert; | ||||
| use Symfony\Component\Validator\Context\ExecutionContextInterface; | ||||
|  | ||||
| /** | ||||
|  * Class ActivityType. | ||||
| @@ -120,7 +118,6 @@ class ActivityType | ||||
|      * @ORM\Id | ||||
|      * @ORM\Column(name="id", type="integer") | ||||
|      * @ORM\GeneratedValue(strategy="AUTO") | ||||
|      * @Groups({"docgen:read"}) | ||||
|      */ | ||||
|     private ?int $id; | ||||
|  | ||||
| @@ -136,8 +133,7 @@ class ActivityType | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="json") | ||||
|      * @Groups({"read", "docgen:read"}) | ||||
|      * @Serializer\Context({"is-translatable": true}, groups={"docgen:read"}) | ||||
|      * @Groups({"read"}) | ||||
|      */ | ||||
|     private array $name = []; | ||||
|  | ||||
| @@ -194,6 +190,7 @@ class ActivityType | ||||
|  | ||||
|     /** | ||||
|      * @ORM\Column(type="smallint", nullable=false, options={"default": 1}) | ||||
|      * @Assert\EqualTo(propertyPath="socialIssuesVisible", message="This parameter must be equal to social issue parameter") | ||||
|      */ | ||||
|     private int $socialActionsVisible = self::FIELD_INVISIBLE; | ||||
|  | ||||
| @@ -263,23 +260,6 @@ class ActivityType | ||||
|      */ | ||||
|     private int $userVisible = self::FIELD_REQUIRED; | ||||
|  | ||||
|     /** | ||||
|      * @Assert\Callback | ||||
|      * | ||||
|      * @param mixed $payload | ||||
|      */ | ||||
|     public function checkSocialActionsVisibility(ExecutionContextInterface $context, $payload) | ||||
|     { | ||||
|         if ($this->socialIssuesVisible !== $this->socialActionsVisible) { | ||||
|             if (!(2 === $this->socialIssuesVisible && 1 === $this->socialActionsVisible)) { | ||||
|                 $context | ||||
|                     ->buildViolation('The socialActionsVisible value is not compatible with the socialIssuesVisible value') | ||||
|                     ->atPath('socialActionsVisible') | ||||
|                     ->addViolation(); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get active | ||||
|      * return true if the type is active. | ||||
|   | ||||
| @@ -24,9 +24,9 @@ use Doctrine\ORM\Query; | ||||
| use Symfony\Component\Form\Extension\Core\Type\ChoiceType; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
| use Symfony\Component\Security\Core\Role\Role; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
| use Symfony\Component\Validator\Constraints\Callback; | ||||
| use Symfony\Component\Validator\Context\ExecutionContextInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| use function array_key_exists; | ||||
| use function count; | ||||
|   | ||||
| @@ -21,7 +21,7 @@ use Symfony\Component\Form\FormBuilderInterface; | ||||
| use Symfony\Component\Form\FormError; | ||||
| use Symfony\Component\Form\FormEvent; | ||||
| use Symfony\Component\Form\FormEvents; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
|  | ||||
| class ActivityDateFilter implements FilterInterface | ||||
| { | ||||
|   | ||||
| @@ -29,8 +29,8 @@ use Symfony\Component\Form\FormError; | ||||
| use Symfony\Component\Form\FormEvent; | ||||
| use Symfony\Component\Form\FormEvents; | ||||
| use Symfony\Component\Form\FormInterface; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
| use Symfony\Component\Validator\Context\ExecutionContextInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| use function count; | ||||
|  | ||||
|   | ||||
| @@ -125,9 +125,7 @@ class ActivityType extends AbstractType | ||||
|         } | ||||
|  | ||||
|         if ($activityType->isVisible('socialIssues') && $accompanyingPeriod) { | ||||
|             $builder->add('socialIssues', HiddenType::class, [ | ||||
|                 'required' => $activityType->getSocialIssuesVisible() === 2, | ||||
|             ]); | ||||
|             $builder->add('socialIssues', HiddenType::class); | ||||
|             $builder->get('socialIssues') | ||||
|                 ->addModelTransformer(new CallbackTransformer( | ||||
|                     static function (iterable $socialIssuesAsIterable): string { | ||||
| @@ -153,9 +151,7 @@ class ActivityType extends AbstractType | ||||
|         } | ||||
|  | ||||
|         if ($activityType->isVisible('socialActions') && $accompanyingPeriod) { | ||||
|             $builder->add('socialActions', HiddenType::class, [ | ||||
|                 'required' => $activityType->getSocialActionsVisible() === 2, | ||||
|             ]); | ||||
|             $builder->add('socialActions', HiddenType::class); | ||||
|             $builder->get('socialActions') | ||||
|                 ->addModelTransformer(new CallbackTransformer( | ||||
|                     static function (iterable $socialActionsAsIterable): string { | ||||
| @@ -309,10 +305,8 @@ class ActivityType extends AbstractType | ||||
|                 'label' => $activityType->getLabel('documents'), | ||||
|                 'required' => $activityType->isRequired('documents'), | ||||
|                 'allow_add' => true, | ||||
|                 'allow_delete' => true, | ||||
|                 'button_add_label' => 'activity.Insert a document', | ||||
|                 'button_remove_label' => 'activity.Remove a document', | ||||
|                 'empty_collection_explain' => 'No documents', | ||||
|             ]); | ||||
|         } | ||||
|  | ||||
| @@ -343,9 +337,7 @@ class ActivityType extends AbstractType | ||||
|         } | ||||
|  | ||||
|         if ($activityType->isVisible('location')) { | ||||
|             $builder->add('location', HiddenType::class, [ | ||||
|                 'required' => $activityType->getLocationVisible() === 2, | ||||
|             ]) | ||||
|             $builder->add('location', HiddenType::class) | ||||
|                 ->get('location') | ||||
|                 ->addModelTransformer(new CallbackTransformer( | ||||
|                     static function (?Location $location): string { | ||||
|   | ||||
| @@ -15,7 +15,7 @@ use Chill\ActivityBundle\Security\Authorization\ActivityVoter; | ||||
| use Chill\MainBundle\Routing\LocalMenuBuilderInterface; | ||||
| use Knp\Menu\MenuItem; | ||||
| use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
|  | ||||
| class PersonMenuBuilder implements LocalMenuBuilderInterface | ||||
| { | ||||
|   | ||||
| @@ -1,45 +0,0 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Chill is a software for social workers | ||||
|  * | ||||
|  * For the full copyright and license information, please view | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Notification; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\ActivityBundle\Repository\ActivityRepository; | ||||
| use Chill\MainBundle\Entity\Notification; | ||||
| use Chill\MainBundle\Notification\NotificationHandlerInterface; | ||||
|  | ||||
| final class ActivityNotificationHandler implements NotificationHandlerInterface | ||||
| { | ||||
|     private ActivityRepository $activityRepository; | ||||
|  | ||||
|     public function __construct(ActivityRepository $activityRepository) | ||||
|     { | ||||
|         $this->activityRepository = $activityRepository; | ||||
|     } | ||||
|  | ||||
|     public function getTemplate(Notification $notification, array $options = []): string | ||||
|     { | ||||
|         return '@ChillActivity/Activity/showInNotification.html.twig'; | ||||
|     } | ||||
|  | ||||
|     public function getTemplateData(Notification $notification, array $options = []): array | ||||
|     { | ||||
|         return [ | ||||
|             'notification' => $notification, | ||||
|             'activity' => $this->activityRepository->find($notification->getRelatedEntityId()), | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     public function supports(Notification $notification, array $options = []): bool | ||||
|     { | ||||
|         return $notification->getRelatedEntityClass() === Activity::class; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,33 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Chill is a software for social workers | ||||
|  * | ||||
|  * For the full copyright and license information, please view | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Notification; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\MainBundle\Entity\Notification; | ||||
|  | ||||
| final class ActivityNotificationRenderer | ||||
| { | ||||
|     public function getTemplate() | ||||
|     { | ||||
|         return '@ChillActivity/Activity/showInNotification.html.twig'; | ||||
|     } | ||||
|  | ||||
|     public function getTemplateData(Notification $notification) | ||||
|     { | ||||
|         return ['notification' => $notification]; | ||||
|     } | ||||
|  | ||||
|     public function supports(Notification $notification, array $options = []): bool | ||||
|     { | ||||
|         return $notification->getRelatedEntityClass() === Activity::class; | ||||
|     } | ||||
| } | ||||
| @@ -9,9 +9,8 @@ div.new-activity-select-type { | ||||
|       display: flex; | ||||
|       flex-direction: row; | ||||
|       flex-wrap: wrap; | ||||
|       justify-content: flex-start; | ||||
|       justify-content: center; | ||||
|       gap: 12px; | ||||
|       margin-bottom: 30px; | ||||
|  | ||||
|       div.bloc { | ||||
|          width: 200px; | ||||
| @@ -28,28 +27,26 @@ div.new-activity-select-type { | ||||
| // precise dashboard specific details | ||||
|  | ||||
| p.date-label { | ||||
|    display: inline-block; | ||||
|    margin: 0 0.5em 0 0; | ||||
|    font-weight: 700; | ||||
|    font-size: 18pt; | ||||
|     display: inline-block; | ||||
|     margin: 0 0.5em 0 0; | ||||
|     font-weight: 700; | ||||
|     font-size: 18pt; | ||||
| } | ||||
| div.dashboard, | ||||
| h4.badge-title, | ||||
| h3.badge-title, | ||||
| h2.badge-title { | ||||
|    ul.list-content { | ||||
|       font-size: 70%; | ||||
|       list-style-type: none; | ||||
|       padding-left: 0; | ||||
|       margin: 0; | ||||
|       li { | ||||
|          margin-bottom: 0.2em; | ||||
|          // exception: change bg color for action badges above dashboard | ||||
|          .bg-light { | ||||
|                background-color: $chill-light-gray !important; | ||||
|          } | ||||
|       } | ||||
|    } | ||||
|     ul.list-content { | ||||
|         font-size: 70%; | ||||
|         list-style-type: none; | ||||
|         padding-left: 0; | ||||
|         margin: 0; | ||||
|         li { | ||||
|             margin-bottom: 0.2em; | ||||
|             // exception: change bg color for action badges above dashboard | ||||
|             .bg-light { | ||||
|                 background-color: $chill-light-gray !important; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| //// ACTIVITY SHOW AND FORM PAGES | ||||
|   | ||||
| @@ -1,16 +0,0 @@ | ||||
| div.chill-dropzone__below-zone { | ||||
|     a.btn-delete { | ||||
|         display: none; | ||||
|     } | ||||
| } | ||||
|  | ||||
| // do it in js does not work | ||||
| // document.addEventListener('DOMContentLoaded', e => { | ||||
| //     const dropzoneBelow = document.querySelectorAll('div.chill-dropzone__below-zone'); | ||||
| //     dropzoneBelow.forEach( | ||||
| //         d => { | ||||
| //             const a = d.querySelector('a.btn-delete'); | ||||
| //             d.removeChild(a); | ||||
| //         } | ||||
| //     ) | ||||
| // }); | ||||
| @@ -11,7 +11,7 @@ import Location from './components/Location.vue'; | ||||
|  | ||||
| export default { | ||||
|    name: "App", | ||||
|    props: ['hasSocialIssues', 'hasLocation', 'hasPerson'], | ||||
|     props: ['hasSocialIssues', 'hasLocation', 'hasPerson'], | ||||
|    components: { | ||||
|       ConcernedGroups, | ||||
|       SocialIssuesAcc, | ||||
|   | ||||
| @@ -1,52 +1,45 @@ | ||||
| <template> | ||||
|    <teleport to="#add-persons" v-if="isComponentVisible"> | ||||
|     <teleport to="#add-persons" v-if="isComponentVisible"> | ||||
|  | ||||
|       <div class="flex-bloc concerned-groups" :class="getContext"> | ||||
|          <persons-bloc | ||||
|                v-for="bloc in contextPersonsBlocs" | ||||
|                v-bind:key="bloc.key" | ||||
|                v-bind:bloc="bloc" | ||||
|                v-bind:blocWidth="getBlocWidth" | ||||
|                v-bind:setPersonsInBloc="setPersonsInBloc"> | ||||
|          </persons-bloc> | ||||
|       </div> | ||||
|       <div v-if="getContext === 'accompanyingCourse' && suggestedEntities.length > 0"> | ||||
|          <ul class="list-suggest add-items inline"> | ||||
|                <li v-for="(p, i) in suggestedEntities" @click="addSuggestedEntity(p)" :key="`suggestedEntities-${i}`"> | ||||
|                   <person-text v-if="p.type === 'person'" :person="p"></person-text> | ||||
|                   <span v-else>{{ p.text }}</span> | ||||
|                </li> | ||||
|          </ul> | ||||
|       </div> | ||||
|         <div class="flex-bloc concerned-groups" :class="getContext"> | ||||
|             <persons-bloc | ||||
|                 v-for="bloc in contextPersonsBlocs" | ||||
|                 v-bind:key="bloc.key" | ||||
|                 v-bind:bloc="bloc" | ||||
|                 v-bind:blocWidth="getBlocWidth" | ||||
|                 v-bind:setPersonsInBloc="setPersonsInBloc"> | ||||
|             </persons-bloc> | ||||
|         </div> | ||||
|         <div v-if="getContext === 'accompanyingCourse' && suggestedEntities.length > 0"> | ||||
|             <ul class="list-suggest add-items inline"> | ||||
|                 <li v-for="p in suggestedEntities" @click="addSuggestedEntity(p)"> | ||||
|                     <span>{{ p.text }}</span> | ||||
|                 </li> | ||||
|             </ul> | ||||
|         </div> | ||||
|  | ||||
|       <ul class="record_actions"> | ||||
|          <li class="add-persons"> | ||||
|             <add-persons | ||||
|                buttonTitle="activity.add_persons" | ||||
|                modalTitle="activity.add_persons" | ||||
|                v-bind:key="addPersons.key" | ||||
|                v-bind:options="addPersonsOptions" | ||||
|                @addNewPersons="addNewPersons" | ||||
|                ref="addPersons"> | ||||
|             </add-persons> | ||||
|          </li> | ||||
|       </ul> | ||||
|         <add-persons | ||||
|             buttonTitle="activity.add_persons" | ||||
|             modalTitle="activity.add_persons" | ||||
|             v-bind:key="addPersons.key" | ||||
|             v-bind:options="addPersonsOptions" | ||||
|             @addNewPersons="addNewPersons" | ||||
|             ref="addPersons"> | ||||
|         </add-persons> | ||||
|  | ||||
|    </teleport> | ||||
|     </teleport> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { mapState, mapGetters } from 'vuex'; | ||||
| import AddPersons from 'ChillPersonAssets/vuejs/_components/AddPersons.vue'; | ||||
| import PersonsBloc from './ConcernedGroups/PersonsBloc.vue'; | ||||
| import PersonText from 'ChillPersonAssets/vuejs/_components/Entity/PersonText.vue'; | ||||
|  | ||||
| export default { | ||||
|    name: "ConcernedGroups", | ||||
|    components: { | ||||
|       AddPersons, | ||||
|       PersonsBloc, | ||||
|       PersonText | ||||
|       PersonsBloc | ||||
|    }, | ||||
|    data() { | ||||
|       return { | ||||
|   | ||||
| @@ -1,29 +1,21 @@ | ||||
| <template> | ||||
|    <li> | ||||
|       <span :title="person.text" @click.prevent="$emit('remove', person)"> | ||||
|          <span class="chill_denomination"> | ||||
|             <person-text :person="person" :isCut="true"></person-text> | ||||
|          </span> | ||||
|       <span :title="person.text"> | ||||
|          <span class="chill_denomination" @click.prevent="$emit('remove', person)">{{ textCutted }}</span> | ||||
|       </span> | ||||
|    </li> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import PersonText from 'ChillPersonAssets/vuejs/_components/Entity/PersonText.vue'; | ||||
|  | ||||
|  | ||||
| export default { | ||||
|    name: "PersonBadge", | ||||
|    props: ['person'], | ||||
|    components: { | ||||
|       PersonText | ||||
|    computed: { | ||||
|       textCutted() { | ||||
|          let more = (this.person.text.length > 15) ?'…' : ''; | ||||
|          return this.person.text.slice(0,15) + more; | ||||
|       } | ||||
|    }, | ||||
|    // computed: { | ||||
|    //    textCutted() { | ||||
|    //       let more = (this.person.text.length > 15) ?'…' : ''; | ||||
|    //       return this.person.text.slice(0,15) + more; | ||||
|    //    } | ||||
|    // }, | ||||
|    emits: ['remove'], | ||||
| } | ||||
| </script> | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <template> | ||||
|     <teleport to="#location"> | ||||
|         <div class="mb-3 row"> | ||||
|             <label :class="locationClassList"> | ||||
|             <label class="col-form-label col-sm-4"> | ||||
|                 {{ $t("activity.location") }} | ||||
|             </label> | ||||
|             <div class="col-sm-8"> | ||||
| @@ -15,16 +15,14 @@ | ||||
|                     :searchable="true" | ||||
|                     :placeholder="$t('activity.choose_location')" | ||||
|                     :custom-label="customLabel" | ||||
|                     :select-label="$t('multiselect.select_label')" | ||||
|                     :deselect-label="$t('multiselect.deselect_label')" | ||||
|                     :selected-label="$t('multiselect.selected_label')" | ||||
|                     :options="availableLocations" | ||||
|                     group-values="locations" | ||||
|                     group-label="locationGroup" | ||||
|                     v-model="location" | ||||
|                 > | ||||
|                 </VueMultiselect> | ||||
|                 <new-location v-bind:availableLocations="availableLocations"></new-location> | ||||
|  | ||||
|                 <new-location v-bind:locations="locations"></new-location> | ||||
|             </div> | ||||
|         </div> | ||||
|     </teleport> | ||||
| @@ -34,6 +32,7 @@ | ||||
| import { mapState, mapGetters } from "vuex"; | ||||
| import VueMultiselect from "vue-multiselect"; | ||||
| import NewLocation from "./Location/NewLocation.vue"; | ||||
| import { getLocations, getLocationTypeByDefaultFor, getUserCurrentLocation } from "../api.js"; | ||||
|  | ||||
| export default { | ||||
|     name: "Location", | ||||
| @@ -41,12 +40,6 @@ export default { | ||||
|         NewLocation, | ||||
|         VueMultiselect, | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             locationClassList: | ||||
|                `col-form-label col-sm-4 ${document.querySelector('input#chill_activitybundle_activity_location').getAttribute('required') ? 'required' : ''}`, | ||||
|         } | ||||
|     }, | ||||
|     computed: { | ||||
|         ...mapState(["activity", "availableLocations"]), | ||||
|         ...mapGetters(["suggestedEntities"]), | ||||
|   | ||||
| @@ -18,10 +18,13 @@ | ||||
|                 </template> | ||||
|                 <template v-slot:body> | ||||
|                     <form> | ||||
|                         <div class="alert alert-warning" v-if="errors.length"> | ||||
|                             <ul> | ||||
|                                 <li v-for="(e, i) in errors" :key="i">{{ e }}</li> | ||||
|                             </ul> | ||||
|                         <div class="form-floating mb-3"> | ||||
|                             <p v-if="errors.length"> | ||||
|                                 <b>{{ $t('activity.errors') }}</b> | ||||
|                                 <ul> | ||||
|                                     <li v-for="error in errors" :key="error">{{ error }}</li> | ||||
|                                 </ul> | ||||
|                             </p> | ||||
|                         </div> | ||||
|  | ||||
|                         <div class="form-floating mb-3"> | ||||
| @@ -59,7 +62,6 @@ | ||||
|                             <input class="form-control form-control-lg" id="email" v-model="inputEmail" placeholder /> | ||||
|                             <label for="email">{{ $t('activity.location_fields.email') }}</label> | ||||
|                         </div> | ||||
|  | ||||
|                     </form> | ||||
|                 </template> | ||||
|                 <template v-slot:footer> | ||||
| @@ -79,8 +81,7 @@ | ||||
| import Modal from 'ChillMainAssets/vuejs/_components/Modal.vue'; | ||||
| import AddAddress from "ChillMainAssets/vuejs/Address/components/AddAddress.vue"; | ||||
| import { mapState } from "vuex"; | ||||
| import { getLocationTypes } from "../../api"; | ||||
| import { makeFetch } from 'ChillMainAssets/lib/api/apiMethods'; | ||||
| import { getLocationTypes, postLocation } from "../../api"; | ||||
|  | ||||
| export default { | ||||
|     name: "NewLocation", | ||||
| @@ -88,7 +89,7 @@ export default { | ||||
|         Modal, | ||||
|         AddAddress, | ||||
|     }, | ||||
|     props: ['availableLocations'], | ||||
|     props: ['locations'], | ||||
|     data() { | ||||
|         return { | ||||
|             errors: [], | ||||
| @@ -222,6 +223,7 @@ export default { | ||||
|         }, | ||||
|         saveNewLocation() { | ||||
|             if (this.checkForm()) { | ||||
|                 console.log('saveNewLocation', this.selected); | ||||
|                 let body = { | ||||
|                     type: 'location', | ||||
|                     name: this.selected.name, | ||||
| @@ -240,28 +242,23 @@ export default { | ||||
|                         } | ||||
|                     }); | ||||
|                 } | ||||
|  | ||||
|                 makeFetch('POST', '/api/1.0/main/location.json', body) | ||||
|                     .then(response => { | ||||
|                          this.$store.dispatch('addAvailableLocationGroup', { | ||||
|                             locationGroup: 'Localisations nouvellement créées', | ||||
|                             locations: [response] | ||||
|                         }); | ||||
|                         this.$store.dispatch('updateLocation', response); | ||||
|                         this.modal.showModal = false; | ||||
|                     }) | ||||
|                     .catch((error) => { | ||||
|                         if (error.name === 'ValidationException') { | ||||
|                             for (let v of error.violations) { | ||||
|                                 this.errors.push(v); | ||||
|                             } | ||||
|                         } else { | ||||
|                             this.errors.push('An error occurred'); | ||||
|                 postLocation(body) | ||||
|                     .then( | ||||
|                         location => new Promise(resolve => { | ||||
|                             this.locations.push(location); | ||||
|                             this.$store.dispatch('updateLocation', location); | ||||
|                             resolve(); | ||||
|                             this.modal.showModal = false; | ||||
|                         }) | ||||
|                     ).catch( | ||||
|                         err => { | ||||
|                             this.errors.push(err.message); | ||||
|                         } | ||||
|                     }) | ||||
|                     ); | ||||
|             }; | ||||
|         }, | ||||
|         submitNewAddress(payload) { | ||||
|             console.log('submitNewAddress', payload); | ||||
|             this.selected.addressId = payload.addressId; | ||||
|             this.addAddress.context.addressId = payload.addressId; | ||||
|             this.addAddress.context.edit = true; | ||||
|   | ||||
| @@ -3,15 +3,15 @@ | ||||
|  | ||||
|       <div class="mb-3 row"> | ||||
|          <div class="col-4"> | ||||
|             <label :class="socialIssuesClassList">{{ $t('activity.social_issues') }}</label> | ||||
|             <label class="col-form-label">{{ $t('activity.social_issues') }}</label> | ||||
|          </div> | ||||
|          <div class="col-8"> | ||||
|  | ||||
|             <check-social-issue | ||||
|                v-for="issue in socialIssuesList" | ||||
|                :key="issue.id" | ||||
|                :issue="issue" | ||||
|                :selection="socialIssuesSelected" | ||||
|                v-bind:key="issue.id" | ||||
|                v-bind:issue="issue" | ||||
|                v-bind:selection="socialIssuesSelected" | ||||
|                @updateSelected="updateIssuesSelected"> | ||||
|             </check-social-issue> | ||||
|  | ||||
| @@ -21,18 +21,18 @@ | ||||
|                label="text" | ||||
|                track-by="id" | ||||
|                open-direction="bottom" | ||||
|                :close-on-select="true" | ||||
|                :preserve-search="false" | ||||
|                :reset-after="true" | ||||
|                :hide-selected="true" | ||||
|                :taggable="false" | ||||
|                :multiple="false" | ||||
|                :searchable="true" | ||||
|                :allow-empty="true" | ||||
|                :show-labels="false" | ||||
|                :loading="issueIsLoading" | ||||
|                :placeholder="$t('activity.choose_other_social_issue')" | ||||
|                :options="socialIssuesOther" | ||||
|                v-bind:close-on-select="true" | ||||
|                v-bind:preserve-search="false" | ||||
|                v-bind:reset-after="true" | ||||
|                v-bind:hide-selected="true" | ||||
|                v-bind:taggable="false" | ||||
|                v-bind:multiple="false" | ||||
|                v-bind:searchable="true" | ||||
|                v-bind:allow-empty="true" | ||||
|                v-bind:show-labels="false" | ||||
|                v-bind:loading="issueIsLoading" | ||||
|                v-bind:placeholder="$t('activity.choose_other_social_issue')" | ||||
|                v-bind:options="socialIssuesOther" | ||||
|                @select="addIssueInList"> | ||||
|             </VueMultiselect> | ||||
|             </div> | ||||
| @@ -42,7 +42,7 @@ | ||||
|  | ||||
|       <div class="mb-3 row"> | ||||
|          <div class="col-4"> | ||||
|             <label :class="socialActionsClassList">{{ $t('activity.social_actions') }}</label> | ||||
|             <label class="col-form-label">{{ $t('activity.social_actions') }}</label> | ||||
|          </div> | ||||
|          <div class="col-8"> | ||||
|  | ||||
| @@ -58,9 +58,9 @@ | ||||
|                  <check-social-action | ||||
|                      v-if="socialIssuesSelected.length || socialActionsSelected.length" | ||||
|                      v-for="action in socialActionsList" | ||||
|                      :key="action.id" | ||||
|                      :action="action" | ||||
|                      :selection="socialActionsSelected" | ||||
|                      v-bind:key="action.id" | ||||
|                      v-bind:action="action" | ||||
|                      v-bind:selection="socialActionsSelected" | ||||
|                      @updateSelected="updateActionsSelected"> | ||||
|                  </check-social-action> | ||||
|              </template> | ||||
| @@ -94,10 +94,6 @@ export default { | ||||
|          issueIsLoading: false, | ||||
|          actionIsLoading: false, | ||||
|          actionAreLoaded: false, | ||||
|          socialIssuesClassList: | ||||
|             `col-form-label ${document.querySelector('input#chill_activitybundle_activity_socialIssues').getAttribute('required') ? 'required' : ''}`, | ||||
|          socialActionsClassList: | ||||
|             `col-form-label ${document.querySelector('input#chill_activitybundle_activity_socialActions').getAttribute('required') ? 'required' : ''}`, | ||||
|       } | ||||
|    }, | ||||
|    computed: { | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| import { personMessages } from 'ChillPersonAssets/vuejs/_js/i18n' | ||||
| import { multiSelectMessages } from 'ChillMainAssets/vuejs/_js/i18n' | ||||
|  | ||||
| const activityMessages = { | ||||
|    fr: { | ||||
| @@ -34,11 +33,12 @@ const activityMessages = { | ||||
|           }, | ||||
|           create_address: 'Créer une adresse', | ||||
|           edit_address: "Modifier l'adresse" | ||||
|  | ||||
|       } | ||||
|    } | ||||
| } | ||||
|  | ||||
| Object.assign(activityMessages.fr, personMessages.fr, multiSelectMessages.fr); | ||||
| Object.assign(activityMessages.fr, personMessages.fr); | ||||
|  | ||||
| export { | ||||
|    activityMessages | ||||
|   | ||||
| @@ -2,25 +2,17 @@ import { createApp } from 'vue'; | ||||
| import { _createI18n } from 'ChillMainAssets/vuejs/_js/i18n' | ||||
| import { activityMessages } from './i18n' | ||||
| import store from './store' | ||||
| import PickTemplate from 'ChillDocGeneratorAssets/vuejs/_components/PickTemplate.vue'; | ||||
| import {fetchTemplates} from 'ChillDocGeneratorAssets/api/pickTemplate.js'; | ||||
|  | ||||
| import App from './App.vue'; | ||||
|  | ||||
| const i18n = _createI18n(activityMessages); | ||||
|  | ||||
| // app for activity | ||||
|  | ||||
| const hasSocialIssues = document.querySelector('#social-issues-acc') !== null; | ||||
| const hasLocation = document.querySelector('#location') !== null; | ||||
| const hasPerson = document.querySelector('#add-persons') !== null; | ||||
|  | ||||
| const app = createApp({ | ||||
|    template: `<app | ||||
|        :hasSocialIssues="hasSocialIssues" | ||||
|        :hasLocation="hasLocation" | ||||
|        :hasPerson="hasPerson" | ||||
|     ></app>`, | ||||
|    template: `<app :hasSocialIssues="hasSocialIssues", :hasLocation="hasLocation", :hasPerson="hasPerson"></app>`, | ||||
|     data() { | ||||
|        return { | ||||
|            hasSocialIssues, | ||||
| @@ -33,54 +25,3 @@ const app = createApp({ | ||||
| .use(i18n) | ||||
| .component('app', App) | ||||
| .mount('#activity'); | ||||
|  | ||||
|  | ||||
| // app for picking template | ||||
|  | ||||
| const i18nGendoc = _createI18n({}); | ||||
|  | ||||
| document.querySelectorAll('div[data-docgen-template-picker]').forEach(el => { | ||||
|     fetchTemplates(el.dataset.entityClass).then(templates => { | ||||
|         const picker = { | ||||
|             template: | ||||
|                 '<pick-template :templates="this.templates" :preventDefaultMoveToGenerate="true" ' + | ||||
|                     ':entityClass="faked" @go-to-generate-document="generateDoc"></pick-template>', | ||||
|             components: { | ||||
|                 PickTemplate, | ||||
|             }, | ||||
|             data() { | ||||
|                 return { | ||||
|                     templates: templates, | ||||
|                     entityId: el.dataset.entityId, | ||||
|                 } | ||||
|             }, | ||||
|             methods: { | ||||
|                 generateDoc({event, link, template}) { | ||||
|                     console.log('generateDoc'); | ||||
|                     console.log('link', link); | ||||
|                     console.log('template', template); | ||||
|  | ||||
|                     let hiddenInput = document.querySelector("input[data-template-id]"); | ||||
|  | ||||
|                     if (hiddenInput === null) { | ||||
|                         console.error('hidden input not found'); | ||||
|                         return; | ||||
|                     } | ||||
|  | ||||
|                     hiddenInput.value = template; | ||||
|  | ||||
|                     let form = document.querySelector('form[name="chill_activitybundle_activity"'); | ||||
|  | ||||
|                     if (form === null) { | ||||
|                         console.error('form not found'); | ||||
|                         return; | ||||
|                     } | ||||
|  | ||||
|                     form.submit(); | ||||
|                 } | ||||
|             } | ||||
|         }; | ||||
|         createApp(picker).use(i18nGendoc).mount(el); | ||||
|     }) | ||||
|  | ||||
| }); | ||||
|   | ||||
| @@ -240,9 +240,6 @@ const store = createStore({ | ||||
|             }); | ||||
|             commit("updateActionsSelected", payload); | ||||
|         }, | ||||
|         addAvailableLocationGroup({ commit }, payload) { | ||||
|             commit("addAvailableLocationGroup", payload); | ||||
|         }, | ||||
|         addPersonsInvolved({ commit }, payload) { | ||||
|             //console.log('### action addPersonsInvolved', payload.result.type); | ||||
|             switch (payload.result.type) { | ||||
|   | ||||
| @@ -110,8 +110,10 @@ export default function prepareLocations(store) { | ||||
|         console.log('default loation id', window.default_location_id); | ||||
|         if (window.default_location_id) { | ||||
|             for (let group of store.state.availableLocations) { | ||||
|                 console.log(group); | ||||
|                 let location = group.locations.find((l) => l.id === window.default_location_id); | ||||
|                 if (location !== undefined & store.state.activity.location === null) { | ||||
|                 console.log(location); | ||||
|                 if (location !== undefined) { | ||||
|                     store.dispatch('updateLocation', location); | ||||
|                     break; | ||||
|                 } | ||||
|   | ||||
| @@ -1,170 +0,0 @@ | ||||
| {% set t = activity.type %} | ||||
| <div class="item-bloc activity-item{% if itemBlocClass is defined %} {{ itemBlocClass }}{% endif %}"> | ||||
|  | ||||
|     <div class="item-row"> | ||||
|         <div class="wrap-list"> | ||||
|             <div class="wl-row"> | ||||
|                 <div class="wl-col title"> | ||||
|                     {% if activity.date %} | ||||
|                         <p class="date-label"> | ||||
|                             {{ activity.date|format_date('short') }} | ||||
|                         </p> | ||||
|                     {% endif %} | ||||
|                 </div> | ||||
|                 <div class="wl-col list"> | ||||
|                     <h2 class="badge-title"> | ||||
|                         <span class="title_label"></span> | ||||
|                         <span class="title_action"> | ||||
|                             {{ activity.type.name | localize_translatable_string }} | ||||
|  | ||||
|                             {% if activity.emergency %} | ||||
|                                 <span class="badge bg-danger rounded-pill fs-6 float-end">{{ 'Emergency'|trans|upper }}</span> | ||||
|                             {% endif %} | ||||
|                         </span> | ||||
|                     </h2> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </div> | ||||
|     </div> | ||||
|  | ||||
|     <div class="item-row column separator"> | ||||
|         <div class="wrap-list"> | ||||
|             {% if activity.location and t.locationVisible %} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"><h3>{{ 'location'|trans }}</h3></div> | ||||
|                     <div class="wl-col list"> | ||||
|                         <p class="wl-item"> | ||||
|                             {{ activity.location.name }} | ||||
|                             <span>({{ activity.location.locationType.title|localize_translatable_string }})</span> | ||||
|                         </p> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|  | ||||
|             {% if activity.attendee and t.attendeeVisible %} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"><h3>{{ 'Attendee'|trans }}</h3></div> | ||||
|                     <div class="wl-col list"> | ||||
|                         <p class="wl-item"> | ||||
|                             {{ activity.attendee.name|localize_translatable_string }} | ||||
|                         </p> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|  | ||||
|             {% if activity.sentReceived is not empty and t.sentReceivedVisible %} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"><h3>{{ 'Sent received'|trans }}</h3></div> | ||||
|                     <div class="wl-col list"> | ||||
|                         <p class="wl-item"> | ||||
|                             {{ activity.sentReceived|capitalize|trans }} | ||||
|                         </p> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|  | ||||
|             {% if activity.user and t.userVisible %} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"><h3>{{ 'Referrer'|trans }}</h3></div> | ||||
|                     <div class="wl-col list"> | ||||
|                         <p class="wl-item"> | ||||
|                             {{ activity.user|chill_entity_render_box }} | ||||
|                         </p> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|         </div> | ||||
|  | ||||
|         {% include 'ChillActivityBundle:Activity:concernedGroups.html.twig' with { | ||||
|             'context': context, | ||||
|             'render': 'wrap-list', | ||||
|             'entity': activity, | ||||
|             'badge_person': true | ||||
|         } %} | ||||
|  | ||||
|         <div class="wrap-list"> | ||||
|             {%- if activity.reasons is not empty and t.reasonsVisible -%} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"> | ||||
|                         <h3>{{ 'Reasons'|trans }}</h3> | ||||
|                     </div> | ||||
|                     <div class="wl-col list"> | ||||
|                         {% for r in activity.reasons %} | ||||
|                             <p class="wl-item reasons"> | ||||
|                                 {{ r|chill_entity_render_box }} | ||||
|                             </p> | ||||
|                         {% endfor %} | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|  | ||||
|             {%- if activity.socialIssues is not empty and t.socialIssuesVisible -%} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"> | ||||
|                         <h3>{{ 'Social issues'|trans }}</h3> | ||||
|                     </div> | ||||
|                     <div class="wl-col list"> | ||||
|                         {% for r in activity.socialIssues %} | ||||
|                             <p class="wl-item social-issues"> | ||||
|                                 {{ r|chill_entity_render_box }} | ||||
|                             </p> | ||||
|                         {% endfor %} | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|  | ||||
|             {%- if activity.socialActions is not empty and t.socialActionsVisible -%} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"> | ||||
|                         <h3>{{ 'Social actions'|trans }}</h3> | ||||
|                     </div> | ||||
|                     <div class="wl-col list"> | ||||
|                         {% for r in activity.socialActions %} | ||||
|                             <p class="wl-item social-actions"> | ||||
|                                 {{ r|chill_entity_render_box }} | ||||
|                             </p> | ||||
|                         {% endfor %} | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|  | ||||
|             {% if activity.comment.comment is not empty and is_granted('CHILL_ACTIVITY_SEE_DETAILS', activity) %} | ||||
|                 <div class="wl-row"> | ||||
|                     <div class="wl-col title"> | ||||
|                         <h3>{{ 'Comment'|trans }}</h3> | ||||
|                     </div> | ||||
|                     <div class="wl-col list"> | ||||
|                         {{ activity.comment|chill_entity_render_box({ | ||||
|                             'disable_markdown': false, | ||||
|                             'limit_lines': 3, | ||||
|                             'metadata': false | ||||
|                         }) }} | ||||
|                     </div> | ||||
|                 </div> | ||||
|             {% endif %} | ||||
|  | ||||
|             {#  Only if ACL SEE_DETAILS AND/OR only on template SHOW ?? | ||||
|                 durationTime | ||||
|                 travelTime | ||||
|                 comment | ||||
|                 documents | ||||
|                 attendee | ||||
|             #} | ||||
|         </div> | ||||
|     </div> | ||||
|  | ||||
|     <div class="item-row separator"> | ||||
|         <div class="item-col item-meta"> | ||||
|             {% set notif_counter = chill_count_notifications('Chill\\ActivityBundle\\Entity\\Activity', activity.id) %} | ||||
|             {% if notif_counter.total > 0 %} | ||||
|                 {{ chill_counter_notifications('Chill\\ActivityBundle\\Entity\\Activity', activity.id) }} | ||||
|             {% endif %} | ||||
|         </div> | ||||
|         <div class="item-col"> | ||||
|             <ul class="record_actions"> | ||||
|                 {{ recordAction }} | ||||
|             </ul> | ||||
|         </div> | ||||
|     </div> | ||||
|  | ||||
| </div> | ||||
| @@ -3,13 +3,11 @@ | ||||
|     {{ path(pathname, parms) }} | ||||
| {% endmacro %} | ||||
|  | ||||
| {% macro insert_onthefly(type, entity, parent = null) %} | ||||
| {% macro insert_onthefly(type, entity) %} | ||||
|     {% include '@ChillMain/OnTheFly/_insert_vue_onthefly.html.twig' with { | ||||
|         action: 'show', displayBadge: true, | ||||
|         targetEntity: { name: type, id: entity.id }, | ||||
|         buttonText: entity|chill_entity_render_string, | ||||
|         isDead: entity.deathdate is defined and entity.deathdate is not null, | ||||
|         parent: parent | ||||
|         buttonText: entity|chill_entity_render_string | ||||
|     } %} | ||||
| {% endmacro %} | ||||
|  | ||||
| @@ -61,7 +59,7 @@ | ||||
|     }]) %} | ||||
| {% endif %} | ||||
|  | ||||
| {% if (render == 'bloc') %} | ||||
| {% if (with_display == 'bloc') %} | ||||
| <div class="{{ context }} flex-bloc concerned-groups"> | ||||
|     {% for bloc in blocks %} | ||||
|  | ||||
| @@ -92,7 +90,7 @@ | ||||
| </div> | ||||
| {% endif %} | ||||
|  | ||||
| {% if (render == 'row') %} | ||||
| {% if (with_display == 'row') %} | ||||
| <div class="concerned-groups"> | ||||
|     {% for bloc in blocks %} | ||||
|     <div class="group"> | ||||
| @@ -117,7 +115,7 @@ | ||||
| </div> | ||||
| {% endif %} | ||||
|  | ||||
| {% if (render == 'wrap-list') %} | ||||
| {% if (with_display == 'wrap-list') %} | ||||
| <div class="concerned-groups wrap-list"> | ||||
|     {% for bloc in blocks %} | ||||
|         <div class="wl-row"> | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
|  | ||||
| {% block title  'Remove activity'|trans %} | ||||
|  | ||||
| {% block content %} | ||||
| {% block personcontent %} | ||||
| {{ include('@ChillMain/Util/confirmation_template.html.twig', | ||||
|     { | ||||
|         'title'             : 'Remove activity'|trans, | ||||
|   | ||||
| @@ -35,7 +35,7 @@ | ||||
|     {{ form_row(edit_form.socialActions) }} | ||||
| {% endif %} | ||||
|  | ||||
| {%- if edit_form.socialIssues is defined or edit_form.socialActions is defined -%} | ||||
| {%- if edit_form.socialIssues is defined or edit_form.socialIssues is defined -%} | ||||
| <div id="social-issues-acc"></div> | ||||
| {% endif %} | ||||
|  | ||||
| @@ -83,15 +83,15 @@ | ||||
|     {{ form_row(edit_form.comment) }} | ||||
| {% endif %} | ||||
|  | ||||
| {%- if edit_form.documents is defined -%} | ||||
|     {{ form_row(edit_form.documents) }} | ||||
| {% endif %} | ||||
|  | ||||
| {%- if edit_form.attendee is defined -%} | ||||
|     {{ form_row(edit_form.attendee) }} | ||||
| {% endif %} | ||||
|  | ||||
| {%- if edit_form.documents is defined -%} | ||||
|     {{ form_row(edit_form.documents) }} | ||||
|     <div data-docgen-template-picker="data-docgen-template-picker" data-entity-class="Chill\ActivityBundle\Entity\Activity" data-entity-id="{{ entity.id }}"></div> | ||||
| {% endif %} | ||||
|  | ||||
| {# TODO .. status #} | ||||
|  | ||||
| {% set person_id = null %} | ||||
| {% if entity.person %} | ||||
|   | ||||
| @@ -15,7 +15,7 @@ | ||||
|  | ||||
| {% block js %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_script_tags('mod_async_upload') }} | ||||
|     {{ encore_entry_link_tags('mod_async_upload') }} | ||||
|     <script type="text/javascript"> | ||||
|         window.addEventListener('DOMContentLoaded', function (e) { | ||||
|             chill.displayAlertWhenLeavingModifiedForm('form[name="{{ edit_form.vars.form.vars.name }}"]', | ||||
| @@ -30,5 +30,4 @@ | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_link_tags('mod_async_upload') }} | ||||
|     {{ encore_entry_link_tags('vue_activity') }} | ||||
|     {{ encore_entry_link_tags('page_edit_activity') }} | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -20,7 +20,7 @@ | ||||
|  | ||||
| {% block title  'Update activity'|trans %} | ||||
|  | ||||
| {% block content %} | ||||
| {% block personcontent %} | ||||
| <div class="activity-edit"> | ||||
|  | ||||
|     <div id="activity"></div> {# <=== vue component #} | ||||
| @@ -30,7 +30,7 @@ | ||||
| {% endblock %} | ||||
|  | ||||
| {% block js %} | ||||
|     {{ encore_entry_script_tags('mod_async_upload') }} | ||||
|     {{ encore_entry_link_tags('mod_async_upload') }} | ||||
|     <script type="text/javascript"> | ||||
|         window.addEventListener('DOMContentLoaded', function (e) { | ||||
|             chill.displayAlertWhenLeavingModifiedForm('form[name="{{ edit_form.vars.form.vars.name }}"]', | ||||
|   | ||||
| @@ -1,65 +1,3 @@ | ||||
| {% macro recordAction(activity, context = null, person_id = null, accompanying_course_id = null) %} | ||||
|     {% if is_granted('CHILL_ACTIVITY_SEE_DETAILS', activity) %} | ||||
|         {% if no_action is not defined or no_action == false %} | ||||
|             <li> | ||||
|                 <a class="btn btn-misc" href="{{ chill_path_add_return_path('chill_main_notification_create', { | ||||
|                     'entityClass': 'Chill\\ActivityBundle\\Entity\\Activity', | ||||
|                     'entityId': activity.id | ||||
|                 }) }}"> | ||||
|                     <i class="fa fa-paper-plane fa-fw"></i> | ||||
|                     {{ 'notification.Notify'|trans }}</a> | ||||
|             </li> | ||||
|         {% endif %} | ||||
|         {% if context == 'person' and activity.accompanyingPeriod is not empty %} | ||||
|             {# | ||||
|                 Disable person_id in following links, for redirect to accompanyingCourse context | ||||
|             #} | ||||
|             {% set person_id = null %} | ||||
|             {% set accompanying_course_id = activity.accompanyingPeriod.id %} | ||||
|             <li> | ||||
|                 <a href="{{ chill_path_add_return_path('chill_activity_activity_list',{ | ||||
|                         'accompanying_period_id': accompanying_course_id | ||||
|                     }) }}" | ||||
|                     class="btn btn-primary" | ||||
|                     title="{{ 'See activity in accompanying course context'|trans }}"> | ||||
|                     <i class="fa fa-random fa-fw"></i> | ||||
|                     {{ 'Period number %number%'|trans({'%number%': accompanying_course_id}) }} | ||||
|                 </a> | ||||
|             </li> | ||||
|         {% endif %} | ||||
|         <li> | ||||
|             <a href="{{ path('chill_activity_activity_show', {'id': activity.id, | ||||
|                     'person_id': person_id, | ||||
|                     'accompanying_period_id': accompanying_course_id | ||||
|                 }) }}" | ||||
|                 class="btn btn-show" | ||||
|                 title="{{ 'Show'|trans }}"></a> | ||||
|         </li> | ||||
|         {% if no_action is not defined or no_action == false %} | ||||
|             {% if is_granted('CHILL_ACTIVITY_UPDATE', activity) %} | ||||
|                 <li> | ||||
|                     <a href="{{ path('chill_activity_activity_edit', {'id': activity.id, | ||||
|                             'person_id': person_id, | ||||
|                             'accompanying_period_id': accompanying_course_id | ||||
|                         }) }}" | ||||
|                         class="btn btn-update" | ||||
|                         title="{{ 'Edit'|trans }}"></a> | ||||
|                 </li> | ||||
|             {% endif %} | ||||
|             {% if is_granted('CHILL_ACTIVITY_DELETE', activity) %} | ||||
|                 <li> | ||||
|                     <a href="{{ path('chill_activity_activity_delete', {'id': activity.id, | ||||
|                             'person_id': person_id, | ||||
|                             'accompanying_period_id': accompanying_course_id | ||||
|                         }) }}" | ||||
|                         class="btn btn-delete" | ||||
|                         title="{{ 'Delete'|trans }}"></a> | ||||
|                 </li> | ||||
|             {% endif %} | ||||
|         {% endif %} | ||||
|     {% endif %} | ||||
| {% endmacro %} | ||||
|  | ||||
| <div class="context-{{ context }}"> | ||||
|  | ||||
|     {% if activities|length == 0 %} | ||||
| @@ -70,10 +8,203 @@ | ||||
|     {% else %} | ||||
|         <div class="flex-table activity-list"> | ||||
|             {% for activity in activities %} | ||||
|                 {% include 'ChillActivityBundle:Activity:_list_item.html.twig' with { | ||||
|                     'context': context, | ||||
|                     'recordAction': _self.recordAction(activity, context, person_id, accompanying_course_id) | ||||
|                 } %} | ||||
|                 {% set t = activity.type %} | ||||
|                 <div class="item-bloc"> | ||||
|  | ||||
|                     <div class="item-row"> | ||||
|                         <div class="wrap-list"> | ||||
|                             <div class="wl-row"> | ||||
|                                 <div class="wl-col title"> | ||||
|                                     {% if activity.date %} | ||||
|                                         <p class="date-label"> | ||||
|                                             {{ activity.date|format_date('short') }} | ||||
|                                         </p> | ||||
|                                     {% endif %} | ||||
|                                 </div> | ||||
|                                 <div class="wl-col list"> | ||||
|                                     <h2 class="badge-title"> | ||||
|                                         <span class="title_label"></span> | ||||
|                                         <span class="title_action"> | ||||
|                                             {{ activity.type.name | localize_translatable_string }} | ||||
|  | ||||
|                                             {% if activity.emergency %} | ||||
|                                                 <span class="badge bg-danger rounded-pill fs-6 float-end">{{ 'Emergency'|trans|upper }}</span> | ||||
|                                             {% endif %} | ||||
|                                         </span> | ||||
|                                     </h2> | ||||
|                                 </div> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|  | ||||
|                     <div class="item-row column separator"> | ||||
|                         <div class="wrap-list"> | ||||
|                             {% if activity.location and t.locationVisible %} | ||||
|                                 <div class="wl-row"> | ||||
|                                     <div class="wl-col title"><h3>{{ 'location'|trans }}</h3></div> | ||||
|                                     <div class="wl-col list"> | ||||
|                                         <p class="wl-item"> | ||||
|                                             <span>{{ activity.location.locationType.title|localize_translatable_string }}</span> | ||||
|                                             {{ activity.location.name }} | ||||
|                                         </p> | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|                             {% endif %} | ||||
|  | ||||
|                             {% if activity.sentReceived is not empty and t.sentReceivedVisible %} | ||||
|                                 <div class="wl-row"> | ||||
|                                     <div class="wl-col title"><h3>{{ 'Sent received'|trans }}</h3></div> | ||||
|                                     <div class="wl-col list"> | ||||
|                                         <p class="wl-item"> | ||||
|                                             {{ activity.sentReceived|capitalize|trans }} | ||||
|                                         </p> | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|                             {% endif %} | ||||
|  | ||||
|                             {% if activity.user and t.userVisible %} | ||||
|                                 <div class="wl-row"> | ||||
|                                     <div class="wl-col title"><h3>{{ 'Referrer'|trans }}</h3></div> | ||||
|                                     <div class="wl-col list"> | ||||
|                                         <p class="wl-item"> | ||||
|                                             {{ activity.user.usernameCanonical|chill_entity_render_string|capitalize }} | ||||
|                                         </p> | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|                             {% endif %} | ||||
|                         </div> | ||||
|  | ||||
|                         {% include 'ChillActivityBundle:Activity:concernedGroups.html.twig' with { | ||||
|                             'context': context, | ||||
|                             'with_display': 'wrap-list', | ||||
|                             'entity': activity, | ||||
|                             'badge_person': true | ||||
|                         } %} | ||||
|  | ||||
|                         <div class="wrap-list"> | ||||
|                             {%- if activity.reasons is not empty and t.reasonsVisible -%} | ||||
|                                 <div class="wl-row"> | ||||
|                                     <div class="wl-col title"> | ||||
|                                         <h3>{{ 'Reasons'|trans }}</h3> | ||||
|                                     </div> | ||||
|                                     <div class="wl-col list"> | ||||
|                                         {% for r in activity.reasons %} | ||||
|                                             <p class="wl-item reasons"> | ||||
|                                                 {{ r|chill_entity_render_box }} | ||||
|                                             </p> | ||||
|                                         {% endfor %} | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|                             {% endif %} | ||||
|  | ||||
|                             {%- if activity.socialIssues is not empty and t.socialIssuesVisible -%} | ||||
|                                 <div class="wl-row"> | ||||
|                                     <div class="wl-col title"> | ||||
|                                         <h3>{{ 'Social issues'|trans }}</h3> | ||||
|                                     </div> | ||||
|                                     <div class="wl-col list"> | ||||
|                                         {% for r in activity.socialIssues %} | ||||
|                                             <p class="wl-item social-issues"> | ||||
|                                                 {{ r|chill_entity_render_box }} | ||||
|                                             </p> | ||||
|                                         {% endfor %} | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|                             {% endif %} | ||||
|  | ||||
|                             {%- if activity.socialActions is not empty and t.socialActionsVisible -%} | ||||
|                                 <div class="wl-row"> | ||||
|                                     <div class="wl-col title"> | ||||
|                                         <h3>{{ 'Social actions'|trans }}</h3> | ||||
|                                     </div> | ||||
|                                     <div class="wl-col list"> | ||||
|                                         {% for r in activity.socialActions %} | ||||
|                                             <p class="wl-item social-actions"> | ||||
|                                                 {{ r|chill_entity_render_box }} | ||||
|                                             </p> | ||||
|                                         {% endfor %} | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|                             {% endif %} | ||||
|  | ||||
|                             {% if activity.comment.comment is not empty and is_granted('CHILL_ACTIVITY_SEE_DETAILS', activity) %} | ||||
|                                 <div class="wl-row"> | ||||
|                                     <div class="wl-col title"> | ||||
|                                         <h3>{{ 'Comment'|trans }}</h3> | ||||
|                                     </div> | ||||
|                                     <div class="wl-col list"> | ||||
|                                         {{ activity.comment|chill_entity_render_box({ | ||||
|                                             'disable_markdown': false, | ||||
|                                             'limit_lines': 3, | ||||
|                                             'metadata': false | ||||
|                                         }) }} | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|                             {% endif %} | ||||
|                              | ||||
|                             {#  Only if ACL SEE_DETAILS AND/OR only on template SHOW ?? | ||||
|                                 durationTime | ||||
|                                 travelTime | ||||
|                                 comment | ||||
|                                 documents | ||||
|                                 attendee | ||||
|                             #} | ||||
|                         </div> | ||||
|                     </div> | ||||
|  | ||||
|                     <div class="item-row separator"> | ||||
|                         <ul class="record_actions"> | ||||
|                             {% if context == 'person' and activity.accompanyingPeriod is not empty %} | ||||
|                                 {# | ||||
|                                     Disable person_id in following links, for redirect to accompanyingCourse context | ||||
|                                 #} | ||||
|                                 {% set person_id = null %} | ||||
|                                 {% set accompanying_course_id = activity.accompanyingPeriod.id %} | ||||
|                                 <li> | ||||
|                                     <a href="{{ chill_path_add_return_path('chill_activity_activity_list',{ | ||||
|                                            'accompanying_period_id': accompanying_course_id | ||||
|                                        }) }}" | ||||
|                                        class="btn btn-primary" | ||||
|                                        title="{{ 'See activity in accompanying course context'|trans }}"> | ||||
|                                        <i class="fa fa-random fa-fw"></i> | ||||
|                                        {{ 'Period number %number%'|trans({'%number%': accompanying_course_id}) }} | ||||
|                                     </a> | ||||
|                                 </li> | ||||
|                             {% endif %} | ||||
|                             <li> | ||||
|                                 <a href="{{ path('chill_activity_activity_show', {'id': activity.id, | ||||
|                                         'person_id': person_id, | ||||
|                                         'accompanying_period_id': accompanying_course_id | ||||
|                                     }) }}" | ||||
|                                    class="btn btn-show" | ||||
|                                    title="{{ 'Show'|trans }}"></a> | ||||
|                             </li> | ||||
|                             {% if no_action is not defined or no_action == false %} | ||||
|                                 {% if is_granted('CHILL_ACTIVITY_UPDATE', activity) %} | ||||
|                                     <li> | ||||
|                                         <a href="{{ path('chill_activity_activity_edit', {'id': activity.id, | ||||
|                                                 'person_id': person_id, | ||||
|                                                 'accompanying_period_id': accompanying_course_id | ||||
|                                             }) }}" | ||||
|                                            class="btn btn-update" | ||||
|                                            title="{{ 'Edit'|trans }}"></a> | ||||
|                                     </li> | ||||
|                                 {% endif %} | ||||
|                                 {% if is_granted('CHILL_ACTIVITY_DELETE', activity) %} | ||||
|                                     <li> | ||||
|                                         <a href="{{ path('chill_activity_activity_delete', {'id': activity.id, | ||||
|                                                 'person_id': person_id, | ||||
|                                                 'accompanying_period_id': accompanying_course_id | ||||
|                                             }) }}" | ||||
|                                            class="btn btn-delete" | ||||
|                                            title="{{ 'Delete'|trans }}"></a> | ||||
|                                     </li> | ||||
|                                 {% endif %} | ||||
|                             {% endif %} | ||||
|                         </ul> | ||||
|                     </div> | ||||
|  | ||||
|                 </div> | ||||
|             {% endfor %} | ||||
|         </div> | ||||
|     {% endif %} | ||||
|   | ||||
| @@ -4,17 +4,6 @@ | ||||
|  | ||||
| {% block title %}{{ 'Activity list' |trans }}{% endblock title %} | ||||
|  | ||||
|  | ||||
| {% block js %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_script_tags('mod_notification_toggle_read_status') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block css %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_link_tags('mod_notification_toggle_read_status') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block content %} | ||||
|  | ||||
|     {% set person_id = null %} | ||||
|   | ||||
| @@ -20,17 +20,7 @@ | ||||
|  | ||||
| {% block title %}{{ 'Activity list' |trans }}{% endblock title %} | ||||
|  | ||||
| {% block js %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_script_tags('mod_notification_toggle_read_status') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block css %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_link_tags('mod_notification_toggle_read_status') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block content %} | ||||
| {% block personcontent %} | ||||
|  | ||||
|     {% set person_id = null %} | ||||
|     {% if person %} | ||||
| @@ -46,7 +36,7 @@ | ||||
|  | ||||
|     {% include 'ChillActivityBundle:Activity:list.html.twig' with {'context': 'person'} %} | ||||
|  | ||||
|     {% if is_granted('CHILL_ACTIVITY_CREATE_PERSON', person) %} | ||||
|     {% if is_granted('CHILL_ACTIVITY_CREATE', person) %} | ||||
|     <ul class="record_actions sticky-form-buttons"> | ||||
|         <li> | ||||
|             <a href="{{ path('chill_activity_activity_new', {'person_id': person_id, 'accompanying_period_id': accompanying_course_id}) }}" | ||||
|   | ||||
| @@ -13,7 +13,7 @@ | ||||
|                         <p class="date-label">{{ activity.date|format_date('short') }}</p> | ||||
|                     {%- endif -%} | ||||
|  | ||||
|                     <span class="like-h3">{{ activity.type.name|localize_translatable_string }}</span> | ||||
|                     <span class="like-h3">{{ activity.type.name | localize_translatable_string }}</span> | ||||
|  | ||||
|                     {% if activity.emergency %} | ||||
|                         <span class="badge bg-danger rounded-pill fs-6">{{ 'Emergency'|trans|upper }}</span> | ||||
| @@ -41,14 +41,14 @@ | ||||
|                         {% if activity.user and t.userVisible %} | ||||
|                             <li> | ||||
|                                 <span class="item-key">{{ 'Referrer'|trans ~ ': ' }}</span> | ||||
|                                 <b>{{ activity.user|chill_entity_render_box}}</b> | ||||
|                                 <b>{{ activity.user.usernameCanonical }}</b> | ||||
|                             </li> | ||||
|                         {% endif %} | ||||
|  | ||||
|                         <li class="associated-persons"> | ||||
|                             <span class="item-key">{{ 'Participants'|trans ~ ' : ' }}</span> | ||||
|                             {% for p in activity.personsAssociated %} | ||||
|                                 <span class="badge-person">{{ p|chill_entity_render_box({'addAgeBadge': true}) }}</span> | ||||
|                                 <span class="badge-person">{{ p|chill_entity_render_box }}</span> | ||||
|                             {% endfor %} | ||||
|                         </li> | ||||
|                     </ul> | ||||
|   | ||||
| @@ -35,7 +35,7 @@ | ||||
|     {{ form_row(form.socialActions) }} | ||||
| {% endif %} | ||||
|  | ||||
| {%- if form.socialIssues is defined or form.socialActions is defined -%} | ||||
| {%- if form.socialIssues is defined or form.socialIssues is defined -%} | ||||
|     <div id="social-issues-acc"></div> | ||||
| {% endif %} | ||||
|  | ||||
| @@ -87,7 +87,6 @@ | ||||
|  | ||||
| {%- if form.documents is defined -%} | ||||
|     {{ form_row(form.documents) }} | ||||
|     <div data-docgen-template-picker="data-docgen-template-picker" data-entity-class="Chill\ActivityBundle\Entity\Activity" data-entity-id="{{ entity.id }}"></div> | ||||
| {% endif %} | ||||
|  | ||||
| {%- if form.attendee is defined -%} | ||||
|   | ||||
| @@ -17,6 +17,10 @@ | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_script_tags('mod_async_upload') }} | ||||
|     <script type="text/javascript"> | ||||
|         window.addEventListener('DOMContentLoaded', function (e) { | ||||
|             chill.displayAlertWhenLeavingUnsubmittedForm('form[name="{{ form.vars.form.vars.name }}"]', | ||||
|             '{{ "You are going to leave a page with unsubmitted data. Are you sure you want to leave ?"|trans }}'); | ||||
|         }); | ||||
|         window.activity = {{ activity_json|json_encode|raw }}; | ||||
|         {% if default_location is not null %}window.default_location_id = {{ default_location.id }}{% endif %}; | ||||
|     </script> | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|  | ||||
| {% block title 'Activity creation' |trans %} | ||||
|  | ||||
| {% block content %} | ||||
| {% block personcontent %} | ||||
| <div class="activity-new"> | ||||
|  | ||||
|     <div id="activity"></div> {# <=== vue component #} | ||||
| @@ -14,7 +14,7 @@ | ||||
| {% endblock %} | ||||
|  | ||||
| {% block js %} | ||||
|     {{ encore_entry_script_tags('mod_async_upload') }} | ||||
|     {{ encore_entry_link_tags('mod_async_upload') }} | ||||
|     <script type="text/javascript"> | ||||
|         window.addEventListener('DOMContentLoaded', function (e) { | ||||
|             chill.displayAlertWhenLeavingUnsubmittedForm('form[name="{{ form.vars.form.vars.name }}"]', | ||||
|   | ||||
| @@ -25,7 +25,7 @@ | ||||
|                     'activityData': activityData | ||||
|                 }) }}"> | ||||
|  | ||||
|                     <div class="btn btn-primary"> | ||||
|                     <div class="bloc btn btn-primary btn-lg btn-block"> | ||||
|                         {{ activityType.name|localize_translatable_string }} | ||||
|                     </div> | ||||
|                 </a> | ||||
|   | ||||
| @@ -4,6 +4,6 @@ | ||||
|  | ||||
| {% block title 'Activity creation'|trans %} | ||||
|  | ||||
| {% block content %} | ||||
| {% block personcontent %} | ||||
|     {% include 'ChillActivityBundle:Activity:selectType.html.twig' %} | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -34,7 +34,7 @@ | ||||
|         <div class="item-row separator"> | ||||
|             <dl class="chill_view_data"> | ||||
|                 <dt class="inline">{{ 'Referrer'|trans|capitalize }}</dt> | ||||
|                 <dd>{{ entity.user|chill_entity_render_box }}</dd> | ||||
|                 <dd>{{ entity.user }}</dd> | ||||
|  | ||||
|                 {%- if entity.scope -%} | ||||
|                     <dt class="inline">{{ 'Scope'|trans }}</dt> | ||||
| @@ -85,8 +85,8 @@ | ||||
|  | ||||
| {% include 'ChillActivityBundle:Activity:concernedGroups.html.twig' with { | ||||
|     'context': context, | ||||
|     'render': 'bloc', | ||||
|     'badge_person': true | ||||
|     'with_display': 'bloc', | ||||
|     'badge_person': 'true' | ||||
| } %} | ||||
|  | ||||
| <h2 class="chill-blue">{{ 'Activity data'|trans }}</h2> | ||||
| @@ -103,8 +103,8 @@ | ||||
|                 <dd> | ||||
|                     {% if entity.location is not null %} | ||||
|                         <p> | ||||
|                             <span>{{ entity.location.locationType.title|localize_translatable_string }}</span> | ||||
|                             {{ entity.location.name }} | ||||
|                             <span>({{ entity.location.locationType.title|localize_translatable_string }})</span> | ||||
|                         </p> | ||||
|                         <div class="ms-3">{{ entity.location.address|chill_entity_render_box }}</div> | ||||
|                     {% else %} | ||||
| @@ -165,7 +165,11 @@ | ||||
|                 <dt class="inline">{{ 'Attendee'|trans }}</dt> | ||||
|                 <dd> | ||||
|                     {% if entity.attendee is not null %} | ||||
|                         {{ entity.attendee.name|localize_translatable_string }} | ||||
|                         {% if entity.attendee %} | ||||
|                             {{ 'present'|trans|capitalize }} | ||||
|                         {% else %} | ||||
|                             {{ 'not present'|trans|capitalize }} | ||||
|                         {% endif %} | ||||
|                     {% else %} | ||||
|                         <span class="chill-no-data-statement">{{ 'None'|trans|capitalize }}</span> | ||||
|                     {% endif %} | ||||
| @@ -177,13 +181,6 @@ | ||||
|     </div> | ||||
| </div> | ||||
|  | ||||
| <div class="notification notification-list"> | ||||
|     {% set notifications =  chill_list_notifications('Chill\\ActivityBundle\\Entity\\Activity', entity.id) %} | ||||
|     {% if notifications is not empty %} | ||||
|         {{ notifications|raw }} | ||||
|     {% endif %} | ||||
| </div> | ||||
|  | ||||
| {% set person_id = null %} | ||||
| {% if person %} | ||||
|     {% set person_id = person.id %} | ||||
| @@ -200,21 +197,24 @@ | ||||
|             {{ 'Back to the list'|trans }} | ||||
|         </a> | ||||
|     </li> | ||||
|     {% if is_granted('CHILL_ACTIVITY_UPDATE', entity) %} | ||||
|     <li> | ||||
|         <a class="btn btn-notify" href="{{ chill_path_add_return_path('chill_main_notification_create', {'entityClass': 'Chill\\ActivityBundle\\Entity\\Activity', 'entityId': entity.id}) }}"> | ||||
|             {{ 'notification.Notify'|trans }} | ||||
|         <a class="btn btn-update" href="{{ path('chill_activity_activity_edit', { 'id': entity.id, 'person_id': person_id, 'accompanying_period_id': accompanying_course_id }) }}"> | ||||
|             {{ 'Edit'|trans }} | ||||
|         </a> | ||||
|     </li> | ||||
|     {% if is_granted('CHILL_ACTIVITY_UPDATE', entity) %} | ||||
|         <li> | ||||
|             <a href="{{ path('chill_activity_activity_edit', { 'id': entity.id, 'person_id': person_id, 'accompanying_period_id': accompanying_course_id }) }}" | ||||
|                class="btn btn-update">{{ 'Edit'|trans }}</a> | ||||
|         </li> | ||||
|     {% endif %} | ||||
|     {% if is_granted('CHILL_ACTIVITY_DELETE', entity) %} | ||||
|     <li> | ||||
|         <a href="{{ path('chill_activity_activity_delete', { 'id': entity.id, 'person_id' : person_id, 'accompanying_period_id': accompanying_course_id } ) }}" | ||||
|            class="btn btn-delete" title="{{ 'Delete'|trans }}"></a> | ||||
|         <a href="{{ path('chill_activity_activity_delete', { 'id': entity.id, 'person_id' : person_id, 'accompanying_period_id': accompanying_course_id } ) }}" class="btn btn-delete"> | ||||
|             {{ 'Delete'|trans }} | ||||
|         </a> | ||||
|     </li> | ||||
|     {% endif %} | ||||
| </ul> | ||||
| <script> | ||||
|     import ShowPane from "../../../../ChillMainBundle/Resources/public/vuejs/Address/components/ShowPane"; | ||||
|     export default { | ||||
|         components: {ShowPane} | ||||
|     } | ||||
| </script> | ||||
|   | ||||
| @@ -4,18 +4,6 @@ | ||||
|  | ||||
| {% block title 'Show the activity'|trans %} | ||||
|  | ||||
| {% block js %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_script_tags('mod_notification_toggle_read_status') }} | ||||
|     {{ encore_entry_script_tags('mod_async_upload') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block css %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_link_tags('mod_notification_toggle_read_status') }} | ||||
|     {{ encore_entry_link_tags('mod_async_upload') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% import 'ChillActivityBundle:ActivityReason:macro.html.twig' as m %} | ||||
|  | ||||
| {% block content -%} | ||||
| @@ -23,7 +11,3 @@ | ||||
|     {% include 'ChillActivityBundle:Activity:show.html.twig' with {'context': 'accompanyingCourse'} %} | ||||
| </div> | ||||
| {% endblock content %} | ||||
|  | ||||
| {% block block_post_menu %} | ||||
| <div class="post-menu pt-4"></div> | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -1,27 +1,2 @@ | ||||
| {% macro recordAction(activity) %} | ||||
|     <li> | ||||
|         <a href="{{ path('chill_activity_activity_show', {'id': activity.id }) }}" | ||||
|            class="btn btn-show" title="{{ 'Show the activity'|trans }}"></a> | ||||
|     </li> | ||||
| {% endmacro %} | ||||
|  | ||||
| {% if activity is not null %} | ||||
|     <div class="flex-table"> | ||||
|         {% if is_granted('CHILL_ACTIVITY_SEE', activity) %} | ||||
|             {% include 'ChillActivityBundle:Activity:_list_item.html.twig' with { | ||||
|                 'recordAction': _self.recordAction(activity), | ||||
|                 'context': 'accompanyingCourse', | ||||
|                 'itemBlocClass': 'bg-chill-llight-gray' | ||||
|             } %} | ||||
|         {% else %} | ||||
|             <div class="alert alert-warning border-warning border-1"> | ||||
|                 {{ 'This is the minimal activity data'|trans ~ ': ' ~ activity.id }}<br> | ||||
|                 {{ 'you are not allowed to see it details'|trans }} | ||||
|             </div> | ||||
|         {% endif %} | ||||
|     </div> | ||||
| {% else %} | ||||
|     <div class="alert alert-warning border-warning border-1"> | ||||
|         {{ 'You get notified of an activity which does not exists any more'|trans }} | ||||
|     </div> | ||||
| {% endif %} | ||||
| <a href="{{ path('chill_activity_activity_show', {'id': notification.relatedEntityId })  }}">Go to Activity</a> | ||||
|   | ||||
| @@ -4,39 +4,10 @@ | ||||
|  | ||||
| {% block title 'Show the activity'|trans %} | ||||
|  | ||||
| {% block js %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_script_tags('mod_notification_toggle_read_status') }} | ||||
|     {{ encore_entry_link_tags('mod_async_upload') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block css %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_link_tags('mod_notification_toggle_read_status') }} | ||||
|     {{ encore_entry_link_tags('mod_async_upload') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% import 'ChillActivityBundle:ActivityReason:macro.html.twig' as m %} | ||||
|  | ||||
| {% block content -%} | ||||
| {% block personcontent -%} | ||||
| <div class="activity-show"> | ||||
|     {% include 'ChillActivityBundle:Activity:show.html.twig' with {'context': 'person'} %} | ||||
| </div> | ||||
| {% endblock %} | ||||
|  | ||||
| {% block block_post_menu %} | ||||
|     <div class="post-menu pt-4"> | ||||
|  | ||||
|         <div class="d-grid gap-2"> | ||||
|             <a class="btn btn-notify" href="{{ chill_path_add_return_path('chill_main_notification_create', {'entityClass': 'Chill\\ActivityBundle\\Entity\\Activity', 'entityId': entity.id}) }}"> | ||||
|                 {{ 'notification.Notify'|trans }} | ||||
|             </a> | ||||
|         </div> | ||||
|  | ||||
|         {% set notifications =  chill_list_notifications('Chill\\ActivityBundle\\Entity\\Activity', entity.id) %} | ||||
|         {% if notifications is not empty %} | ||||
|             {{ notifications|raw }} | ||||
|         {% endif %} | ||||
|  | ||||
|     </div> | ||||
| {% endblock %} | ||||
| {% endblock personcontent %} | ||||
|   | ||||
| @@ -25,7 +25,7 @@ | ||||
| {% endblock %} | ||||
|  | ||||
| {% block layout_wvm_content %} | ||||
|     {% block admin_content %}<!-- block content empty --> | ||||
|     {% block admin_content %}<!-- block personcontent empty --> | ||||
|         <h1>{{ 'Activity configuration' |trans }}</h1> | ||||
|     {% endblock %} | ||||
| {% endblock  %} | ||||
| @@ -1,216 +0,0 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Chill is a software for social workers | ||||
|  * | ||||
|  * For the full copyright and license information, please view | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Service\DocGenerator; | ||||
|  | ||||
| use Chill\ActivityBundle\Entity\Activity; | ||||
| use Chill\DocGeneratorBundle\Context\DocGeneratorContextWithAdminFormInterface; | ||||
| use Chill\DocGeneratorBundle\Context\DocGeneratorContextWithPublicFormInterface; | ||||
| use Chill\DocGeneratorBundle\Context\Exception\UnexpectedTypeException; | ||||
| use Chill\DocGeneratorBundle\Entity\DocGeneratorTemplate; | ||||
| use Chill\DocGeneratorBundle\Service\Context\BaseContextData; | ||||
| use Chill\DocStoreBundle\Entity\StoredObject; | ||||
| use Chill\DocStoreBundle\Repository\DocumentCategoryRepository; | ||||
| use Chill\MainBundle\Templating\TranslatableStringHelperInterface; | ||||
| use Chill\PersonBundle\Entity\AccompanyingPeriod; | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use Chill\PersonBundle\Templating\Entity\PersonRenderInterface; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| use Symfony\Bridge\Doctrine\Form\Type\EntityType; | ||||
| use Symfony\Component\Form\Extension\Core\Type\CheckboxType; | ||||
| use Symfony\Component\Form\Extension\Core\Type\TextType; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
| use Symfony\Component\Serializer\Normalizer\NormalizerInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| class ActivityContext implements | ||||
|     DocGeneratorContextWithAdminFormInterface, | ||||
|     DocGeneratorContextWithPublicFormInterface | ||||
| { | ||||
|     private BaseContextData $baseContextData; | ||||
|  | ||||
|     private DocumentCategoryRepository $documentCategoryRepository; | ||||
|  | ||||
|     private EntityManagerInterface $em; | ||||
|  | ||||
|     private NormalizerInterface $normalizer; | ||||
|  | ||||
|     private PersonRenderInterface $personRender; | ||||
|  | ||||
|     private TranslatableStringHelperInterface $translatableStringHelper; | ||||
|  | ||||
|     private TranslatorInterface $translator; | ||||
|  | ||||
|     public function __construct( | ||||
|         DocumentCategoryRepository $documentCategoryRepository, | ||||
|         NormalizerInterface $normalizer, | ||||
|         TranslatableStringHelperInterface $translatableStringHelper, | ||||
|         EntityManagerInterface $em, | ||||
|         PersonRenderInterface $personRender, | ||||
|         TranslatorInterface $translator, | ||||
|         BaseContextData $baseContextData | ||||
|     ) { | ||||
|         $this->documentCategoryRepository = $documentCategoryRepository; | ||||
|         $this->normalizer = $normalizer; | ||||
|         $this->translatableStringHelper = $translatableStringHelper; | ||||
|         $this->em = $em; | ||||
|         $this->personRender = $personRender; | ||||
|         $this->translator = $translator; | ||||
|         $this->baseContextData = $baseContextData; | ||||
|     } | ||||
|  | ||||
|     public function adminFormReverseTransform(array $data): array | ||||
|     { | ||||
|         return $data; | ||||
|     } | ||||
|  | ||||
|     public function adminFormTransform(array $data): array | ||||
|     { | ||||
|         return [ | ||||
|             'mainPerson' => $data['mainPerson'] ?? false, | ||||
|             'mainPersonLabel' => $data['mainPersonLabel'] ?? $this->translator->trans('docgen.Main person'), | ||||
|             'person1' => $data['person1'] ?? false, | ||||
|             'person1Label' => $data['person1Label'] ?? $this->translator->trans('docgen.person 1'), | ||||
|             'person2' => $data['person2'] ?? false, | ||||
|             'person2Label' => $data['person2Label'] ?? $this->translator->trans('docgen.person 2'), | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     public function buildAdminForm(FormBuilderInterface $builder): void | ||||
|     { | ||||
|         $builder | ||||
|             ->add('mainPerson', CheckboxType::class, [ | ||||
|                 'required' => false, | ||||
|                 'label' => 'docgen.Ask for main person', | ||||
|             ]) | ||||
|             ->add('mainPersonLabel', TextType::class, [ | ||||
|                 'label' => 'main person label', | ||||
|                 'required' => true, | ||||
|             ]) | ||||
|             ->add('person1', CheckboxType::class, [ | ||||
|                 'required' => false, | ||||
|                 'label' => 'docgen.Ask for person 1', | ||||
|             ]) | ||||
|             ->add('person1Label', TextType::class, [ | ||||
|                 'label' => 'person 1 label', | ||||
|                 'required' => true, | ||||
|             ]) | ||||
|             ->add('person2', CheckboxType::class, [ | ||||
|                 'required' => false, | ||||
|                 'label' => 'docgen.Ask for person 2', | ||||
|             ]) | ||||
|             ->add('person2Label', TextType::class, [ | ||||
|                 'label' => 'person 2 label', | ||||
|                 'required' => true, | ||||
|             ]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param Activity $entity | ||||
|      */ | ||||
|     public function buildPublicForm(FormBuilderInterface $builder, DocGeneratorTemplate $template, $entity): void | ||||
|     { | ||||
|         $options = $template->getOptions(); | ||||
|         $persons = $entity->getPersons(); | ||||
|  | ||||
|         foreach (['mainPerson', 'person1', 'person2'] as $key) { | ||||
|             if ($options[$key] ?? false) { | ||||
|                 $builder->add($key, EntityType::class, [ | ||||
|                     'class' => Person::class, | ||||
|                     'choices' => $persons, | ||||
|                     'choice_label' => function (Person $p) { | ||||
|                         return $this->personRender->renderString($p, []); | ||||
|                     }, | ||||
|                     'multiple' => false, | ||||
|                     'expanded' => true, | ||||
|                     'label' => $options[$key . 'Label'], | ||||
|                 ]); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function getData(DocGeneratorTemplate $template, $entity, array $contextGenerationData = []): array | ||||
|     { | ||||
|         if (!$entity instanceof Activity) { | ||||
|             throw new UnexpectedTypeException($entity, Activity::class); | ||||
|         } | ||||
|         $options = $template->getOptions(); | ||||
|  | ||||
|         $data = []; | ||||
|         $data = array_merge($data, $this->baseContextData->getData()); | ||||
|         $data['activity'] = $this->normalizer->normalize($entity, 'docgen', ['docgen:expects' => Activity::class, 'groups' => 'docgen:read']); | ||||
|  | ||||
|         $data['course'] = $this->normalizer->normalize($entity->getAccompanyingPeriod(), 'docgen', ['docgen:expects' => AccompanyingPeriod::class, 'groups' => 'docgen:read']); | ||||
|         $data['person'] = $this->normalizer->normalize($entity->getPerson(), 'docgen', ['docgen:expects' => Person::class, 'groups' => 'docgen:read']); | ||||
|  | ||||
|         foreach (['mainPerson', 'person1', 'person2'] as $k) { | ||||
|             if ($options[$k]) { | ||||
|                 $data[$k] = $this->normalizer->normalize($contextGenerationData[$k], 'docgen', [ | ||||
|                     'docgen:expects' => Person::class, | ||||
|                     'groups' => 'docgen:read', | ||||
|                     'docgen:person:with-household' => true, | ||||
|                     'docgen:person:with-relations' => true, | ||||
|                 ]); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $data; | ||||
|     } | ||||
|  | ||||
|     public function getDescription(): string | ||||
|     { | ||||
|         return 'docgen.A basic context for activity'; | ||||
|     } | ||||
|  | ||||
|     public function getEntityClass(): string | ||||
|     { | ||||
|         return Activity::class; | ||||
|     } | ||||
|  | ||||
|     public function getFormData(DocGeneratorTemplate $template, $entity): array | ||||
|     { | ||||
|         return [ | ||||
|             'activity' => $entity, | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     public static function getKey(): string | ||||
|     { | ||||
|         return self::class; | ||||
|     } | ||||
|  | ||||
|     public function getName(): string | ||||
|     { | ||||
|         return 'docgen.Activity basic'; | ||||
|     } | ||||
|  | ||||
|     public function hasAdminForm(): bool | ||||
|     { | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     public function hasPublicForm(DocGeneratorTemplate $template, $entity): bool | ||||
|     { | ||||
|         $options = $template->getOptions(); | ||||
|  | ||||
|         return $options['mainPerson'] || $options['person1'] || $options['person2']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param Activity $entity | ||||
|      */ | ||||
|     public function storeGenerated(DocGeneratorTemplate $template, StoredObject $storedObject, object $entity, array $contextGenerationData): void | ||||
|     { | ||||
|         $entity->addDocument($storedObject); | ||||
|  | ||||
|         $this->em->persist($storedObject); | ||||
|     } | ||||
| } | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Aggregator; | ||||
|  | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Aggregator; | ||||
|  | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Tests\Export\Aggregator; | ||||
| namespace Chill\ActivityBundle\Tests\Aggregator; | ||||
|  | ||||
| use Chill\MainBundle\Test\Export\AbstractAggregatorTest; | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Filter; | ||||
|  | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use Doctrine\Common\Collections\ArrayCollection; | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\ActivityBundle\Tests\Export\Filter; | ||||
| namespace Chill\ActivityBundle\Tests\Filter; | ||||
|  | ||||
| use Chill\MainBundle\Test\Export\AbstractFilterTest; | ||||
| use DateTime; | ||||
|   | ||||
| @@ -29,13 +29,9 @@ use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface; | ||||
| final class ActivityVoterTest extends KernelTestCase | ||||
| { | ||||
|     use PrepareActivityTrait; | ||||
|  | ||||
|     use PrepareCenterTrait; | ||||
|  | ||||
|     use PreparePersonTrait; | ||||
|  | ||||
|     use PrepareScopeTrait; | ||||
|  | ||||
|     use PrepareUserTrait; | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -7,7 +7,5 @@ module.exports = function(encore, entries) | ||||
|         ChillActivityAssets: __dirname + '/Resources/public' | ||||
|     }); | ||||
|  | ||||
|     encore.addEntry('page_edit_activity', __dirname + '/Resources/public/page/edit_activity/index.scss'); | ||||
|  | ||||
|     encore.addEntry('vue_activity', __dirname + '/Resources/public/vuejs/Activity/index.js'); | ||||
| }; | ||||
|   | ||||
| @@ -32,8 +32,3 @@ services: | ||||
|         autowire: true | ||||
|         autoconfigure: true | ||||
|         resource: '../Validator/Constraints/' | ||||
|  | ||||
|     Chill\ActivityBundle\Service\DocGenerator\: | ||||
|         autowire: true | ||||
|         autoconfigure: true | ||||
|         resource: '../Service/DocGenerator/' | ||||
|   | ||||
| @@ -76,7 +76,7 @@ activity: | ||||
|     Insert a document: Insérer un document | ||||
|     Remove a document: Supprimer le document | ||||
|     comment: Commentaire | ||||
| No documents: Aucun document | ||||
|  | ||||
|  | ||||
| #timeline | ||||
| '%user% has done an %activity_type%': '%user% a effectué une activité de type "%activity_type%"' | ||||
| @@ -224,11 +224,3 @@ Aggregate by activity reason: Aggréger par sujet de l'activité | ||||
| Last activities: Les dernières activités | ||||
|  | ||||
| See activity in accompanying course context: Voir l'activité dans le contexte du parcours d'accompagnement | ||||
|  | ||||
| You get notified of an activity which does not exists any more: Cette notification ne correspond pas à une activité valide. | ||||
| you are not allowed to see it details: La notification fait référence à une activité à laquelle vous n'avez pas accès. | ||||
| This is the minimal activity data: Activité n° | ||||
|  | ||||
| docgen: | ||||
|     Activity basic: Echange | ||||
|     A basic context for activity: Contexte pour les échanges | ||||
|   | ||||
| @@ -20,4 +20,3 @@ For this type of activity, you must add at least one social action: Pour ce type | ||||
|  | ||||
| # admin | ||||
| This parameter must be equal to social issue parameter: Ce paramètre doit être égal au paramètre "Visibilité du champs Problématiques sociales" | ||||
| The socialActionsVisible value is not compatible with the socialIssuesVisible value: Cette valeur du paramètre "Visibilité du champs Actions sociales" n'est pas compatible avec la valeur du paramètre "Visibilité du champs Problématiques sociales" | ||||
| @@ -32,8 +32,6 @@ final class AsideActivityController extends CRUDController | ||||
|     { | ||||
|         $asideActivity = new AsideActivity(); | ||||
|  | ||||
|         $asideActivity->setAgent($this->getUser()); | ||||
|  | ||||
|         $duration = $request->query->get('duration', '300'); | ||||
|         $duration = DateTime::createFromFormat('U', $duration); | ||||
|         $asideActivity->setDuration($duration); | ||||
|   | ||||
| @@ -167,6 +167,7 @@ class AsideActivityCategory | ||||
|         } | ||||
|  | ||||
|         $this->parent = $parent; | ||||
|         dump($this); | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|   | ||||
| @@ -14,9 +14,9 @@ namespace Chill\AsideActivityBundle\Form; | ||||
| use Chill\AsideActivityBundle\Entity\AsideActivity; | ||||
| use Chill\AsideActivityBundle\Entity\AsideActivityCategory; | ||||
| use Chill\AsideActivityBundle\Templating\Entity\CategoryRender; | ||||
| use Chill\MainBundle\Entity\User; | ||||
| use Chill\MainBundle\Form\Type\ChillDateType; | ||||
| use Chill\MainBundle\Form\Type\ChillTextareaType; | ||||
| use Chill\MainBundle\Form\Type\PickUserDynamicType; | ||||
| use DateInterval; | ||||
| use DateTime; | ||||
| use DateTimeImmutable; | ||||
| @@ -68,10 +68,22 @@ final class AsideActivityFormType extends AbstractType | ||||
|         ]; | ||||
|  | ||||
|         $builder | ||||
|             ->add('agent', PickUserDynamicType::class, [ | ||||
|                 'label' => 'For agent', | ||||
|                 'required' => true, | ||||
|             ]) | ||||
|             ->add( | ||||
|                 'agent', | ||||
|                 EntityType::class, | ||||
|                 [ | ||||
|                     'label' => 'For agent', | ||||
|                     'required' => true, | ||||
|                     'class' => User::class, | ||||
|                     'data' => $this->storage->getToken()->getUser(), | ||||
|                     'query_builder' => static function (EntityRepository $er) { | ||||
|                         return $er->createQueryBuilder('u')->where('u.enabled = true'); | ||||
|                     }, | ||||
|                     'attr' => ['class' => 'select2 '], | ||||
|                     'placeholder' => 'Choose the agent for whom this activity is created', | ||||
|                     'choice_label' => 'username', | ||||
|                 ] | ||||
|             ) | ||||
|             ->add( | ||||
|                 'date', | ||||
|                 ChillDateType::class, | ||||
|   | ||||
| @@ -16,7 +16,7 @@ use Chill\TaskBundle\Templating\UI\CountNotificationTask; | ||||
| use Knp\Menu\MenuItem; | ||||
| use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface; | ||||
| use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
|  | ||||
| class UserMenuBuilder implements LocalMenuBuilderInterface | ||||
| { | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
|  | ||||
| {% block layout_wvm_content %} | ||||
| 	{% block admin_content %} | ||||
| 		<!-- block content empty --> | ||||
| 		<!-- block personcontent empty --> | ||||
| 		<h1>{{ 'Aside activity configuration'|trans }}</h1> | ||||
| 	{% endblock %} | ||||
| {% endblock  %} | ||||
|   | ||||
| @@ -40,7 +40,7 @@ | ||||
| 									{% endif %} | ||||
| 								</div> | ||||
| 							</div> | ||||
| 							<div class="item-col" style="justify-content: flex-end;"> | ||||
| 							<div class="item-col"> | ||||
| 								<div class="box"> | ||||
| 									<ul class="list-content fa-ul"> | ||||
| 										<li> | ||||
| @@ -79,7 +79,7 @@ | ||||
|  | ||||
| 			{{ chill_pagination(paginator) }} | ||||
|  | ||||
| 			<ul class="record_actions sticky-form-buttons"> | ||||
| 			<ul class="record_actions"> | ||||
| 				<li> | ||||
| 					<a href="{{ chill_path_add_return_path('chill_crud_aside_activity_new') }}" class="btn btn-create"> | ||||
| 						{{ 'Create'|trans }} | ||||
|   | ||||
| @@ -1,15 +1,5 @@ | ||||
| {% extends '@ChillMain/Admin/layout.html.twig' %} | ||||
|  | ||||
| {% block js %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_script_tags('mod_pickentity_type') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block css %} | ||||
|     {{ parent() }} | ||||
|     {{ encore_entry_link_tags('mod_pickentity_type') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block title %} | ||||
| {% include('@ChillMain/CRUD/_new_title.html.twig') %} | ||||
| {% endblock %} | ||||
| @@ -18,5 +8,4 @@ | ||||
| {% embed '@ChillMain/CRUD/_new_content.html.twig' %} | ||||
|     {% block content_form_actions_save_and_show %}{% endblock %} | ||||
| {% endembed %} | ||||
| {% endblock %} | ||||
|  | ||||
| {% endblock %} | ||||
| @@ -9,9 +9,9 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Calculator; | ||||
| namespace Chill\AMLI\BudgetBundle\Calculator; | ||||
|  | ||||
| use Chill\BudgetBundle\Entity\AbstractElement; | ||||
| use Chill\AMLI\BudgetBundle\Entity\AbstractElement; | ||||
|  | ||||
| interface CalculatorInterface | ||||
| { | ||||
|   | ||||
| @@ -9,9 +9,9 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Calculator; | ||||
| namespace Chill\AMLI\BudgetBundle\Calculator; | ||||
|  | ||||
| use Chill\BudgetBundle\Entity\AbstractElement; | ||||
| use Chill\AMLI\BudgetBundle\Entity\AbstractElement; | ||||
| use OutOfBoundsException; | ||||
|  | ||||
| use function array_key_exists; | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Calculator; | ||||
| namespace Chill\AMLI\BudgetBundle\Calculator; | ||||
|  | ||||
| class CalculatorResult | ||||
| { | ||||
|   | ||||
| @@ -9,12 +9,12 @@ | ||||
| 
 | ||||
| declare(strict_types=1); | ||||
| 
 | ||||
| namespace Chill\BudgetBundle; | ||||
| namespace Chill\AMLI\BudgetBundle; | ||||
| 
 | ||||
| use Chill\BudgetBundle\DependencyInjection\Compiler\CalculatorCompilerPass; | ||||
| use Chill\AMLI\BudgetBundle\DependencyInjection\Compiler\CalculatorCompilerPass; | ||||
| use Symfony\Component\HttpKernel\Bundle\Bundle; | ||||
| 
 | ||||
| class ChillBudgetBundle extends Bundle | ||||
| class ChillAMLIBudgetBundle extends Bundle | ||||
| { | ||||
|     public function build(\Symfony\Component\DependencyInjection\ContainerBuilder $container) | ||||
|     { | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Config; | ||||
| namespace Chill\AMLI\BudgetBundle\Config; | ||||
|  | ||||
| class ConfigRepository | ||||
| { | ||||
| @@ -29,11 +29,6 @@ class ConfigRepository | ||||
|         $this->charges = $charges; | ||||
|     } | ||||
|  | ||||
|     public function getChargesKeys(): array | ||||
|     { | ||||
|         return array_map(static function ($element) { return $element['key']; }, $this->charges); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array where keys are the resource'key and label the ressource label | ||||
|      */ | ||||
| @@ -48,11 +43,6 @@ class ConfigRepository | ||||
|         return $charges; | ||||
|     } | ||||
|  | ||||
|     public function getResourcesKeys(): array | ||||
|     { | ||||
|         return array_map(static function ($element) { return $element['key']; }, $this->resources); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array where keys are the resource'key and label the ressource label | ||||
|      */ | ||||
|   | ||||
| @@ -9,29 +9,37 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Controller; | ||||
| namespace Chill\AMLI\BudgetBundle\Controller; | ||||
|  | ||||
| use Chill\BudgetBundle\Entity\AbstractElement; | ||||
| use Chill\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\AMLI\BudgetBundle\Entity\AbstractElement; | ||||
| use Chill\AMLI\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| use Psr\Log\LoggerInterface; | ||||
| use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; | ||||
| use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; | ||||
| use Symfony\Bundle\FrameworkBundle\Controller\Controller; | ||||
| use Symfony\Component\Form\Extension\Core\Type\SubmitType; | ||||
| use Symfony\Component\Form\Form; | ||||
| use Symfony\Component\HttpFoundation\Request; | ||||
| use Symfony\Component\HttpFoundation\Response; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
|  | ||||
| use function get_class; | ||||
|  | ||||
| abstract class AbstractElementController extends AbstractController | ||||
| abstract class AbstractElementController extends Controller | ||||
| { | ||||
|     protected LoggerInterface $chillMainLogger; | ||||
|     /** | ||||
|      * @var LoggerInterface | ||||
|      */ | ||||
|     protected $chillMainLogger; | ||||
|  | ||||
|     protected EntityManagerInterface $em; | ||||
|     /** | ||||
|      * @var EntityManagerInterface | ||||
|      */ | ||||
|     protected $em; | ||||
|  | ||||
|     protected TranslatorInterface $translator; | ||||
|     /** | ||||
|      * @var TranslatorInterface | ||||
|      */ | ||||
|     protected $translator; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em, | ||||
| @@ -51,22 +59,16 @@ abstract class AbstractElementController extends AbstractController | ||||
|      * | ||||
|      * @param mixed $template | ||||
|      * @param mixed $flashMessage | ||||
|      * | ||||
|      * @return \Symfony\Component\BrowserKit\Response | ||||
|      */ | ||||
|     protected function _delete(AbstractElement $element, Request $request, $template, $flashMessage): Response | ||||
|     protected function _delete(AbstractElement $element, Request $request, $template, $flashMessage) | ||||
|     { | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::DELETE, $element, 'You are not ' | ||||
|             . 'allowed to delete this item'); | ||||
|              . 'allowed to delete this family membership'); | ||||
|  | ||||
|         $form = $this->createDeleteForm(); | ||||
|  | ||||
|         if (null !== $element->getPerson()) { | ||||
|             $entity = $element->getPerson(); | ||||
|             $indexPage = 'chill_budget_elements_index'; | ||||
|         } else { | ||||
|             $entity = $element->getHousehold(); | ||||
|             $indexPage = 'chill_budget_elements_household_index'; | ||||
|         } | ||||
|  | ||||
|         if ($request->getMethod() === Request::METHOD_DELETE) { | ||||
|             $form->handleRequest($request); | ||||
|  | ||||
| @@ -86,8 +88,8 @@ abstract class AbstractElementController extends AbstractController | ||||
|                 $this->addFlash('success', $this->translator | ||||
|                     ->trans($flashMessage)); | ||||
|  | ||||
|                 return $this->redirectToRoute($indexPage, [ | ||||
|                     'id' => $entity->getId(), | ||||
|                 return $this->redirectToRoute('chill_budget_elements_index', [ | ||||
|                     'id' => $element->getPerson()->getId(), | ||||
|                 ]); | ||||
|             } | ||||
|         } | ||||
| @@ -101,23 +103,13 @@ abstract class AbstractElementController extends AbstractController | ||||
|     /** | ||||
|      * @param string $template | ||||
|      * @param string $flashOnSuccess | ||||
|      * | ||||
|      * @return \Symfony\Component\HttpFoundation\Response | ||||
|      */ | ||||
|     protected function _edit(AbstractElement $element, Request $request, $template, $flashOnSuccess): Response | ||||
|     protected function _edit(AbstractElement $element, Request $request, $template, $flashOnSuccess) | ||||
|     { | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::UPDATE, $element); | ||||
|  | ||||
|         if (null !== $element->getPerson()) { | ||||
|             $entity = $element->getPerson(); | ||||
|             $entityStr = 'person'; | ||||
|             $indexPage = 'chill_budget_elements_index'; | ||||
|         } else { | ||||
|             $entity = $element->getHousehold(); | ||||
|             $entityStr = 'household'; | ||||
|             $indexPage = 'chill_budget_elements_household_index'; | ||||
|         } | ||||
|  | ||||
|         $entity = null !== $element->getPerson() ? $element->getPerson() : $element->getHousehold(); | ||||
|  | ||||
|         $form = $this->createForm($this->getType(), $element); | ||||
|         $form->add('submit', SubmitType::class); | ||||
|  | ||||
| @@ -129,39 +121,29 @@ abstract class AbstractElementController extends AbstractController | ||||
|  | ||||
|             $this->addFlash('success', $this->translator->trans($flashOnSuccess)); | ||||
|  | ||||
|             return $this->redirectToRoute($indexPage, [ | ||||
|                 'id' => $entity->getId(), | ||||
|             return $this->redirectToRoute('chill_budget_elements_index', [ | ||||
|                 'id' => $element->getPerson()->getId(), | ||||
|             ]); | ||||
|         } | ||||
|  | ||||
|         return $this->render($template, [ | ||||
|             'element' => $element, | ||||
|             'form' => $form->createView(), | ||||
|             $entityStr => $entity, | ||||
|             'person' => $element->getPerson(), | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param mixed $template | ||||
|      * @param mixed $flashMessageOnSuccess | ||||
|      * @param mixed $entity | ||||
|      */ | ||||
|     protected function _new($entity, Request $request, $template, $flashMessageOnSuccess) | ||||
|     protected function _new(Person $person, Request $request, $template, $flashMessageOnSuccess) | ||||
|     { | ||||
|         /** @var AbstractElement $element */ | ||||
|         $element = $this->createNewElement(); | ||||
|         /** @var \Chill\AMLI\BudgetBundle\Entity\AbstractElement $element */ | ||||
|         $element = $this->createNewElement() | ||||
|             ->setPerson($person); | ||||
|  | ||||
|         if ($entity instanceof Person) { | ||||
|             $element->setPerson($entity); | ||||
|             $entityStr = 'person'; | ||||
|             $indexPage = 'chill_budget_elements_index'; | ||||
|         } else { | ||||
|             $element->setHousehold($entity); | ||||
|             $entityStr = 'household'; | ||||
|             $indexPage = 'chill_budget_elements_household_index'; | ||||
|         } | ||||
|  | ||||
|         // $this->denyAccessUnlessGranted(BudgetElementVoter::CREATE, $entity); | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::CREATE, $element); | ||||
|  | ||||
|         $form = $this->createForm($this->getType(), $element); | ||||
|         $form->add('submit', SubmitType::class); | ||||
| @@ -175,8 +157,8 @@ abstract class AbstractElementController extends AbstractController | ||||
|  | ||||
|             $this->addFlash('success', $this->translator->trans($flashMessageOnSuccess)); | ||||
|  | ||||
|             return $this->redirectToRoute($indexPage, [ | ||||
|                 'id' => $entity->getId(), | ||||
|             return $this->redirectToRoute('chill_budget_elements_index', [ | ||||
|                 'id' => $person->getId(), | ||||
|             ]); | ||||
|         } | ||||
|  | ||||
| @@ -186,7 +168,7 @@ abstract class AbstractElementController extends AbstractController | ||||
|  | ||||
|         return $this->render($template, [ | ||||
|             'form' => $form->createView(), | ||||
|             $entityStr => $entity, | ||||
|             'person' => $person, | ||||
|             'element' => $element, | ||||
|         ]); | ||||
|     } | ||||
| @@ -201,7 +183,7 @@ abstract class AbstractElementController extends AbstractController | ||||
|      */ | ||||
|     protected function _view(AbstractElement $element, $template) | ||||
|     { | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::SEE, $element); | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::SHOW, $element); | ||||
|  | ||||
|         return $this->render($template, [ | ||||
|             'element' => $element, | ||||
| @@ -217,8 +199,10 @@ abstract class AbstractElementController extends AbstractController | ||||
|  | ||||
|     /** | ||||
|      * Creates a form to delete a help request entity by id. | ||||
|      * | ||||
|      * @return \Symfony\Component\Form\Form The form | ||||
|      */ | ||||
|     private function createDeleteForm(): Form | ||||
|     private function createDeleteForm() | ||||
|     { | ||||
|         return $this->createFormBuilder() | ||||
|             ->setMethod(Request::METHOD_DELETE) | ||||
|   | ||||
| @@ -9,11 +9,10 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Controller; | ||||
| namespace Chill\AMLI\BudgetBundle\Controller; | ||||
|  | ||||
| use Chill\BudgetBundle\Entity\Charge; | ||||
| use Chill\BudgetBundle\Form\ChargeType; | ||||
| use Chill\PersonBundle\Entity\Household\Household; | ||||
| use Chill\AMLI\BudgetBundle\Entity\Charge; | ||||
| use Chill\AMLI\BudgetBundle\Form\ChargeType; | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; | ||||
| use Symfony\Component\HttpFoundation\Request; | ||||
| @@ -33,7 +32,7 @@ class ChargeController extends AbstractElementController | ||||
|         return $this->_delete( | ||||
|             $charge, | ||||
|             $request, | ||||
|             '@ChillBudget/Charge/confirm_delete.html.twig', | ||||
|             '@ChillAMLIBudget/Charge/confirm_delete.html.twig', | ||||
|             'Charge deleted' | ||||
|         ); | ||||
|     } | ||||
| @@ -51,7 +50,7 @@ class ChargeController extends AbstractElementController | ||||
|         return $this->_edit( | ||||
|             $charge, | ||||
|             $request, | ||||
|             '@ChillBudget/Charge/edit.html.twig', | ||||
|             '@ChillAMLIBudget/Charge/edit.html.twig', | ||||
|             'Charge updated' | ||||
|         ); | ||||
|     } | ||||
| @@ -69,25 +68,7 @@ class ChargeController extends AbstractElementController | ||||
|         return $this->_new( | ||||
|             $person, | ||||
|             $request, | ||||
|             '@ChillBudget/Charge/new.html.twig', | ||||
|             'Charge created' | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @Route( | ||||
|      *     "{_locale}/budget/charge/by-household/{id}/new", | ||||
|      *     name="chill_budget_charge_household_new" | ||||
|      * ) | ||||
|      * | ||||
|      * @return \Symfony\Component\HttpFoundation\Response | ||||
|      */ | ||||
|     public function newHouseholdAction(Request $request, Household $household) | ||||
|     { | ||||
|         return $this->_new( | ||||
|             $household, | ||||
|             $request, | ||||
|             '@ChillBudget/Charge/new.html.twig', | ||||
|             '@ChillAMLIBudget/Charge/new.html.twig', | ||||
|             'Charge created' | ||||
|         ); | ||||
|     } | ||||
| @@ -102,7 +83,7 @@ class ChargeController extends AbstractElementController | ||||
|      */ | ||||
|     public function viewAction(Charge $charge) | ||||
|     { | ||||
|         return $this->_view($charge, '@ChillBudget/Charge/view.html.twig'); | ||||
|         return $this->_view($charge, '@ChillAMLIBudget/Charge/view.html.twig'); | ||||
|     } | ||||
|  | ||||
|     protected function createNewElement() | ||||
|   | ||||
| @@ -9,33 +9,44 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Controller; | ||||
| namespace Chill\AMLI\BudgetBundle\Controller; | ||||
|  | ||||
| use Chill\BudgetBundle\Calculator\CalculatorManager; | ||||
| use Chill\BudgetBundle\Entity\Charge; | ||||
| use Chill\BudgetBundle\Entity\Resource; | ||||
| use Chill\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\PersonBundle\Entity\Household\Household; | ||||
| use Chill\AMLI\BudgetBundle\Calculator\CalculatorManager; | ||||
| use Chill\AMLI\BudgetBundle\Entity\Charge; | ||||
| use Chill\AMLI\BudgetBundle\Entity\Resource; | ||||
| use Chill\AMLI\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use DateTime; | ||||
| use Doctrine\ORM\EntityManagerInterface; | ||||
| use Psr\Log\LoggerInterface; | ||||
| use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; | ||||
| use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
| use Symfony\Bundle\FrameworkBundle\Controller\Controller; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
|  | ||||
| use function array_merge; | ||||
| use function count; | ||||
|  | ||||
| class ElementController extends AbstractController | ||||
| class ElementController extends Controller | ||||
| { | ||||
|     protected CalculatorManager $calculator; | ||||
|     /** | ||||
|      * @var CalculatorManager | ||||
|      */ | ||||
|     protected $calculator; | ||||
|  | ||||
|     protected LoggerInterface $chillMainLogger; | ||||
|     /** | ||||
|      * @var LoggerInterface | ||||
|      */ | ||||
|     protected $chillMainLogger; | ||||
|  | ||||
|     protected EntityManagerInterface $em; | ||||
|     /** | ||||
|      * @var EntityManagerInterface | ||||
|      */ | ||||
|     protected $em; | ||||
|  | ||||
|     protected TranslatorInterface $translator; | ||||
|     /** | ||||
|      * @var TranslatorInterface | ||||
|      */ | ||||
|     protected $translator; | ||||
|  | ||||
|     public function __construct( | ||||
|         EntityManagerInterface $em, | ||||
| @@ -57,12 +68,11 @@ class ElementController extends AbstractController | ||||
|      */ | ||||
|     public function indexAction(Person $person) | ||||
|     { | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::SEE, $person); | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::SHOW, $person); | ||||
|  | ||||
|         $charges = $this->em | ||||
|             ->getRepository(Charge::class) | ||||
|             ->findByPerson($person); | ||||
|  | ||||
|         $ressources = $this->em | ||||
|             ->getRepository(Resource::class) | ||||
|             ->findByPerson($person); | ||||
| @@ -71,10 +81,10 @@ class ElementController extends AbstractController | ||||
|  | ||||
|         $actualCharges = $this->em | ||||
|             ->getRepository(Charge::class) | ||||
|             ->findByEntityAndDate($person, $now); | ||||
|             ->findByPersonAndDate($person, $now); | ||||
|         $actualResources = $this->em | ||||
|             ->getRepository(Resource::class) | ||||
|             ->findByEntityAndDate($person, $now); | ||||
|             ->findByPersonAndDate($person, $now); | ||||
|  | ||||
|         $elements = array_merge($actualCharges, $actualResources); | ||||
|  | ||||
| @@ -82,79 +92,11 @@ class ElementController extends AbstractController | ||||
|             $results = $this->calculator->calculateDefault($elements); | ||||
|         } | ||||
|  | ||||
|         return $this->render('ChillBudgetBundle:Person:index.html.twig', [ | ||||
|         return $this->render('ChillAMLIBudgetBundle:Element:index.html.twig', [ | ||||
|             'person' => $person, | ||||
|             'charges' => $charges, | ||||
|             'resources' => $ressources, | ||||
|             'results' => $results ?? [], | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @Route( | ||||
|      *     "{_locale}/budget/elements/by-household/{id}", | ||||
|      *     name="chill_budget_elements_household_index" | ||||
|      * ) | ||||
|      */ | ||||
|     public function indexHouseholdAction(Household $household) | ||||
|     { | ||||
|         $this->denyAccessUnlessGranted(BudgetElementVoter::SEE, $household); | ||||
|  | ||||
|         $charges = $this->em | ||||
|             ->getRepository(Charge::class) | ||||
|             ->findByHousehold($household); | ||||
|  | ||||
|         $ressources = $this->em | ||||
|             ->getRepository(Resource::class) | ||||
|             ->findByHousehold($household); | ||||
|  | ||||
|         $now = new DateTime('now'); | ||||
|  | ||||
|         $actualCharges = $this->em | ||||
|             ->getRepository(Charge::class) | ||||
|             ->findByEntityAndDate($household, $now); | ||||
|         $actualResources = $this->em | ||||
|             ->getRepository(Resource::class) | ||||
|             ->findByEntityAndDate($household, $now); | ||||
|  | ||||
|         $elements = array_merge($actualCharges, $actualResources); | ||||
|  | ||||
|         if (count($elements) > 0) { | ||||
|             $results = $this->calculator->calculateDefault($elements); | ||||
|         } | ||||
|  | ||||
|         // quick solution to calculate the sum, difference and amount from | ||||
|         // controller. This should be done from the calculators | ||||
|         // TODO replace this by calculators | ||||
|         $wholeCharges = $actualCharges; | ||||
|         $wholeResources = $actualResources; | ||||
|  | ||||
|         foreach ($household->getCurrentPersons() as $person) { | ||||
|             $wholeCharges = array_merge( | ||||
|                 $wholeCharges, | ||||
|                 $this->em | ||||
|                     ->getRepository(Charge::class) | ||||
|                     ->findByEntityAndDate($person, $now) | ||||
|             ); | ||||
|             $wholeResources = array_merge( | ||||
|                 $wholeResources, | ||||
|                 $this->em | ||||
|                     ->getRepository(Resource::class) | ||||
|                     ->findByEntityAndDate($person, $now) | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return $this->render('ChillBudgetBundle:Household:index.html.twig', [ | ||||
|             'household' => $household, | ||||
|             'charges' => $charges, | ||||
|             'resources' => $ressources, | ||||
|             'wholeResources' => array_filter($wholeResources, static function (Resource $r) use ($now) { | ||||
|                 return $r->getStartDate() <= $now && ($r->getEndDate() === null || $r->getEndDate() >= $now); | ||||
|             }), | ||||
|             'wholeCharges' => array_filter($wholeCharges, static function (Charge $c) use ($now) { | ||||
|                 return $c->getStartDate() <= $now && ($c->getEndDate() === null || $c->getEndDate() >= $now); | ||||
|             }), | ||||
|             'results' => $results ?? [], | ||||
|         ]); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -9,15 +9,13 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Controller; | ||||
| namespace Chill\AMLI\BudgetBundle\Controller; | ||||
|  | ||||
| use Chill\BudgetBundle\Entity\Resource; | ||||
| use Chill\BudgetBundle\Form\ResourceType; | ||||
| use Chill\PersonBundle\Entity\Household\Household; | ||||
| use Chill\AMLI\BudgetBundle\Entity\Resource; | ||||
| use Chill\AMLI\BudgetBundle\Form\ResourceType; | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; | ||||
| use Symfony\Component\HttpFoundation\Request; | ||||
| use Symfony\Component\HttpFoundation\Response; | ||||
|  | ||||
| class ResourceController extends AbstractElementController | ||||
| { | ||||
| @@ -26,13 +24,15 @@ class ResourceController extends AbstractElementController | ||||
|      *     "{_locale}/budget/resource/{id}/delete", | ||||
|      *     name="chill_budget_resource_delete" | ||||
|      * ) | ||||
|      * | ||||
|      * @return \Symfony\Component\HttpFoundation\Response | ||||
|      */ | ||||
|     public function deleteAction(Request $request, Resource $resource) | ||||
|     { | ||||
|         return $this->_delete( | ||||
|             $resource, | ||||
|             $request, | ||||
|             '@ChillBudget/Resource/confirm_delete.html.twig', | ||||
|             '@ChillAMLIBudget/Resource/confirm_delete.html.twig', | ||||
|             'Resource deleted' | ||||
|         ); | ||||
|     } | ||||
| @@ -42,49 +42,33 @@ class ResourceController extends AbstractElementController | ||||
|      *     "{_locale}/budget/resource/{id}/edit", | ||||
|      *     name="chill_budget_resource_edit" | ||||
|      * ) | ||||
|      * | ||||
|      * @return \Symfony\Component\HttpFoundation\Response | ||||
|      */ | ||||
|     public function editAction(Request $request, Resource $resource): Response | ||||
|     public function editAction(Request $request, Resource $resource) | ||||
|     { | ||||
|         return $this->_edit( | ||||
|             $resource, | ||||
|             $request, | ||||
|             '@ChillBudget/Resource/edit.html.twig', | ||||
|             '@ChillAMLIBudget/Resource/edit.html.twig', | ||||
|             'Resource updated' | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create a new budget element for a person. | ||||
|      * | ||||
|      * @Route( | ||||
|      *     "{_locale}/budget/resource/by-person/{id}/new", | ||||
|      *     name="chill_budget_resource_new" | ||||
|      * ) | ||||
|      * | ||||
|      * @return \Symfony\Component\HttpFoundation\Response | ||||
|      */ | ||||
|     public function newAction(Request $request, Person $person): Response | ||||
|     public function newAction(Request $request, Person $person) | ||||
|     { | ||||
|         return $this->_new( | ||||
|             $person, | ||||
|             $request, | ||||
|             '@ChillBudget/Resource/new.html.twig', | ||||
|             'Resource created' | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create new budget element for a household. | ||||
|      * | ||||
|      * @Route( | ||||
|      *     "{_locale}/budget/resource/by-household/{id}/new", | ||||
|      *     name="chill_budget_resource_household_new" | ||||
|      * ) | ||||
|      */ | ||||
|     public function newHouseholdAction(Request $request, Household $household): Response | ||||
|     { | ||||
|         return $this->_new( | ||||
|             $household, | ||||
|             $request, | ||||
|             '@ChillBudget/Resource/new.html.twig', | ||||
|             '@ChillAMLIBudget/Resource/new.html.twig', | ||||
|             'Resource created' | ||||
|         ); | ||||
|     } | ||||
| @@ -94,10 +78,12 @@ class ResourceController extends AbstractElementController | ||||
|      *     "{_locale}/budget/resource/{id}/view", | ||||
|      *     name="chill_budget_resource_view" | ||||
|      * ) | ||||
|      * | ||||
|      * @return \Symfony\Component\HttpFoundation\Response | ||||
|      */ | ||||
|     public function viewAction(Resource $resource): Response | ||||
|     public function viewAction(Resource $resource) | ||||
|     { | ||||
|         return $this->_view($resource, '@ChillBudget/Resource/view.html.twig'); | ||||
|         return $this->_view($resource, '@ChillAMLIBudget/Resource/view.html.twig'); | ||||
|     } | ||||
|  | ||||
|     protected function createNewElement() | ||||
|   | ||||
| @@ -9,9 +9,9 @@ | ||||
| 
 | ||||
| declare(strict_types=1); | ||||
| 
 | ||||
| namespace Chill\BudgetBundle\DependencyInjection; | ||||
| namespace Chill\AMLI\BudgetBundle\DependencyInjection; | ||||
| 
 | ||||
| use Chill\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\AMLI\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Symfony\Component\Config\FileLocator; | ||||
| use Symfony\Component\DependencyInjection\ContainerBuilder; | ||||
| use Symfony\Component\DependencyInjection\Extension\PrependExtensionInterface; | ||||
| @@ -23,11 +23,11 @@ use Symfony\Component\HttpKernel\DependencyInjection\Extension; | ||||
|  * | ||||
|  * @see http://symfony.com/doc/current/cookbook/bundles/extension.html | ||||
|  */ | ||||
| class ChillBudgetExtension extends Extension implements PrependExtensionInterface | ||||
| class ChillAMLIBudgetExtension extends Extension implements PrependExtensionInterface | ||||
| { | ||||
|     public function load(array $configs, ContainerBuilder $container) | ||||
|     { | ||||
|         $configuration = $this->getConfiguration($configs, $container); | ||||
|         $configuration = new Configuration(); | ||||
|         $config = $this->processConfiguration($configuration, $configs); | ||||
| 
 | ||||
|         $loader = new Loader\YamlFileLoader($container, new FileLocator(__DIR__ . '/../config')); | ||||
| @@ -38,7 +38,6 @@ class ChillBudgetExtension extends Extension implements PrependExtensionInterfac | ||||
|         $loader->load('services/templating.yaml'); | ||||
|         $loader->load('services/menu.yaml'); | ||||
|         $loader->load('services/calculator.yaml'); | ||||
|         $loader->load('services/services.yaml'); | ||||
| 
 | ||||
|         $this->storeConfig('resources', $config, $container); | ||||
|         $this->storeConfig('charges', $config, $container); | ||||
| @@ -59,7 +58,7 @@ class ChillBudgetExtension extends Extension implements PrependExtensionInterfac | ||||
|         $container->prependExtensionConfig('chill_main', [ | ||||
|             'routing' => [ | ||||
|                 'resources' => [ | ||||
|                     '@ChillBudgetBundle/config/routing.yaml', | ||||
|                     '@ChillAMLIBudgetBundle/config/routing.yaml', | ||||
|                 ], | ||||
|             ], | ||||
|         ]); | ||||
| @@ -69,8 +68,8 @@ class ChillBudgetExtension extends Extension implements PrependExtensionInterfac | ||||
|     { | ||||
|         $container->prependExtensionConfig('security', [ | ||||
|             'role_hierarchy' => [ | ||||
|                 BudgetElementVoter::UPDATE => [BudgetElementVoter::SEE], | ||||
|                 BudgetElementVoter::CREATE => [BudgetElementVoter::SEE], | ||||
|                 BudgetElementVoter::UPDATE => [BudgetElementVoter::SHOW], | ||||
|                 BudgetElementVoter::CREATE => [BudgetElementVoter::SHOW], | ||||
|             ], | ||||
|         ]); | ||||
|     } | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\DependencyInjection\Compiler; | ||||
| namespace Chill\AMLI\BudgetBundle\DependencyInjection\Compiler; | ||||
|  | ||||
| use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface; | ||||
| use Symfony\Component\DependencyInjection\ContainerBuilder; | ||||
| @@ -19,7 +19,7 @@ class CalculatorCompilerPass implements CompilerPassInterface | ||||
| { | ||||
|     public function process(ContainerBuilder $container) | ||||
|     { | ||||
|         $manager = $container->getDefinition('Chill\BudgetBundle\Calculator\CalculatorManager'); | ||||
|         $manager = $container->getDefinition('Chill\AMLI\BudgetBundle\Calculator\CalculatorManager'); | ||||
|  | ||||
|         foreach ($container->findTaggedServiceIds('chill_budget.calculator') as $id => $tags) { | ||||
|             foreach ($tags as $tag) { | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\DependencyInjection; | ||||
| namespace Chill\AMLI\BudgetBundle\DependencyInjection; | ||||
|  | ||||
| use Symfony\Component\Config\Definition\Builder\TreeBuilder; | ||||
| use Symfony\Component\Config\Definition\ConfigurationInterface; | ||||
| @@ -23,14 +23,14 @@ class Configuration implements ConfigurationInterface | ||||
| { | ||||
|     public function getConfigTreeBuilder() | ||||
|     { | ||||
|         $treeBuilder = new TreeBuilder('chill_budget'); | ||||
|         $rootNode = $treeBuilder->getRootNode('chill_budget'); | ||||
|         $treeBuilder = new TreeBuilder('chill_amli_budget'); | ||||
|         $rootNode = $treeBuilder->getRootNode('chill_amli_budget'); | ||||
|  | ||||
|         $rootNode | ||||
|             ->children() | ||||
|  | ||||
|                 // ressources | ||||
|             ->arrayNode('resources')->defaultValue([]) | ||||
|             ->arrayNode('resources')->isRequired()->requiresAtLeastOneElement() | ||||
|             ->arrayPrototype() | ||||
|             ->children() | ||||
|             ->scalarNode('key')->isRequired()->cannotBeEmpty() | ||||
| @@ -52,7 +52,7 @@ class Configuration implements ConfigurationInterface | ||||
|             ->end() | ||||
|             ->end() | ||||
|             ->end() | ||||
|             ->arrayNode('charges')->defaultValue([]) | ||||
|             ->arrayNode('charges')->isRequired()->requiresAtLeastOneElement() | ||||
|             ->arrayPrototype() | ||||
|             ->children() | ||||
|             ->scalarNode('key')->isRequired()->cannotBeEmpty() | ||||
|   | ||||
| @@ -9,15 +9,13 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Entity; | ||||
| namespace Chill\AMLI\BudgetBundle\Entity; | ||||
|  | ||||
| use Chill\PersonBundle\Entity\Household\Household; | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use DateTime; | ||||
| use DateTimeImmutable; | ||||
| use DateTimeInterface; | ||||
| use Doctrine\ORM\Mapping as ORM; | ||||
| use Ramsey\Uuid\Type\Decimal; | ||||
| use Symfony\Component\Validator\Constraints as Assert; | ||||
|  | ||||
| /** | ||||
| @@ -28,6 +26,8 @@ use Symfony\Component\Validator\Constraints as Assert; | ||||
| abstract class AbstractElement | ||||
| { | ||||
|     /** | ||||
|      * @var decimal | ||||
|      * | ||||
|      * @ORM\Column(name="amount", type="decimal", precision=10, scale=2) | ||||
|      * @Assert\GreaterThan( | ||||
|      *     value=0 | ||||
| @@ -36,80 +36,100 @@ abstract class AbstractElement | ||||
|      *     message="The amount cannot be empty" | ||||
|      * ) | ||||
|      */ | ||||
|     private string $amount; | ||||
|     private $amount; | ||||
|  | ||||
|     /** | ||||
|      * @var string|null | ||||
|      * | ||||
|      * @ORM\Column(name="comment", type="text", nullable=true) | ||||
|      */ | ||||
|     private ?string $comment; | ||||
|     private $comment; | ||||
|  | ||||
|     /** | ||||
|      * @var DateTimeImmutable|null | ||||
|      * | ||||
|      * @ORM\Column(name="endDate", type="datetime_immutable", nullable=true) | ||||
|      * @Assert\GreaterThan( | ||||
|      *     propertyPath="startDate", | ||||
|      *     message="The budget element's end date must be after the start date" | ||||
|      * ) | ||||
|      */ | ||||
|     private ?DateTimeImmutable $endDate; | ||||
|  | ||||
|     /** | ||||
|      * @ORM\ManyToOne( | ||||
|      *     targetEntity="\Chill\PersonBundle\Entity\Household\Household" | ||||
|      * ) | ||||
|      */ | ||||
|     private ?Household $household = null; | ||||
|     private $endDate; | ||||
|  | ||||
|     /** | ||||
|      * @var Person | ||||
|      * @ORM\ManyToOne( | ||||
|      *     targetEntity="\Chill\PersonBundle\Entity\Person" | ||||
|      * ) | ||||
|      */ | ||||
|     private ?Person $person = null; | ||||
|     private $person; | ||||
|  | ||||
|     /** | ||||
|      * @var DateTimeImmutable | ||||
|      * | ||||
|      * @ORM\Column(name="startDate", type="datetime_immutable") | ||||
|      * @Assert\Date | ||||
|      */ | ||||
|     private DateTimeImmutable $startDate; | ||||
|     private $startDate; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      * | ||||
|      * @ORM\Column(name="type", type="string", length=255) | ||||
|      */ | ||||
|     private string $type; | ||||
|     private $type; | ||||
|  | ||||
|     /*Getters and Setters */ | ||||
|  | ||||
|     public function getAmount(): float | ||||
|     /** | ||||
|      * Get amount. | ||||
|      * | ||||
|      * @return float | ||||
|      */ | ||||
|     public function getAmount() | ||||
|     { | ||||
|         return (float) $this->amount; | ||||
|     } | ||||
|  | ||||
|     public function getComment(): ?string | ||||
|     /** | ||||
|      * Get comment. | ||||
|      * | ||||
|      * @return string|null | ||||
|      */ | ||||
|     public function getComment() | ||||
|     { | ||||
|         return $this->comment; | ||||
|     } | ||||
|  | ||||
|     public function getEndDate(): ?DateTimeImmutable | ||||
|     /** | ||||
|      * Get endDate. | ||||
|      * | ||||
|      * @return DateTimeImmutable|null | ||||
|      */ | ||||
|     public function getEndDate() | ||||
|     { | ||||
|         return $this->endDate; | ||||
|     } | ||||
|  | ||||
|     public function getHousehold(): ?Household | ||||
|     { | ||||
|         return $this->household; | ||||
|     } | ||||
|  | ||||
|     public function getPerson(): ?Person | ||||
|     public function getPerson(): Person | ||||
|     { | ||||
|         return $this->person; | ||||
|     } | ||||
|  | ||||
|     public function getStartDate(): DateTimeImmutable | ||||
|     /** | ||||
|      * Get startDate. | ||||
|      * | ||||
|      * @return DateTimeImmutable | ||||
|      */ | ||||
|     public function getStartDate() | ||||
|     { | ||||
|         return $this->startDate; | ||||
|     } | ||||
|  | ||||
|     public function getType(): string | ||||
|     /** | ||||
|      * Get type. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getType() | ||||
|     { | ||||
|         return $this->type; | ||||
|     } | ||||
| @@ -123,21 +143,40 @@ abstract class AbstractElement | ||||
|  | ||||
|     abstract public function isResource(): bool; | ||||
|  | ||||
|     public function setAmount(string $amount): self | ||||
|     /** | ||||
|      * Set amount. | ||||
|      * | ||||
|      * @param string $amount | ||||
|      * | ||||
|      * @return AbstractElement | ||||
|      */ | ||||
|     public function setAmount($amount) | ||||
|     { | ||||
|         $this->amount = $amount; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     public function setComment(?string $comment = null): self | ||||
|     /** | ||||
|      * Set comment. | ||||
|      * | ||||
|      * @param string|null $comment | ||||
|      * | ||||
|      * @return AbstractElement | ||||
|      */ | ||||
|     public function setComment($comment = null) | ||||
|     { | ||||
|         $this->comment = $comment; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     public function setEndDate(?DateTimeInterface $endDate = null): self | ||||
|     /** | ||||
|      * Set endDate. | ||||
|      * | ||||
|      * @return AbstractElement | ||||
|      */ | ||||
|     public function setEndDate(?DateTimeInterface $endDate = null) | ||||
|     { | ||||
|         if ($endDate instanceof DateTime) { | ||||
|             $this->endDate = DateTimeImmutable::createFromMutable($endDate); | ||||
| @@ -150,21 +189,19 @@ abstract class AbstractElement | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     public function setHousehold(Household $household): self | ||||
|     { | ||||
|         $this->household = $household; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     public function setPerson(Person $person): self | ||||
|     public function setPerson(Person $person) | ||||
|     { | ||||
|         $this->person = $person; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     public function setStartDate(DateTimeInterface $startDate): self | ||||
|     /** | ||||
|      * Set startDate. | ||||
|      * | ||||
|      * @return AbstractElement | ||||
|      */ | ||||
|     public function setStartDate(DateTimeInterface $startDate) | ||||
|     { | ||||
|         if ($startDate instanceof DateTime) { | ||||
|             $this->startDate = DateTimeImmutable::createFromMutable($startDate); | ||||
| @@ -177,7 +214,14 @@ abstract class AbstractElement | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     public function setType(string $type): self | ||||
|     /** | ||||
|      * Set type. | ||||
|      * | ||||
|      * @param string $type | ||||
|      * | ||||
|      * @return AbstractElement | ||||
|      */ | ||||
|     public function setType($type) | ||||
|     { | ||||
|         $this->type = $type; | ||||
|  | ||||
|   | ||||
| @@ -9,9 +9,8 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Entity; | ||||
| namespace Chill\AMLI\BudgetBundle\Entity; | ||||
|  | ||||
| use Chill\MainBundle\Entity\Center; | ||||
| use Chill\MainBundle\Entity\HasCenterInterface; | ||||
| use DateTimeImmutable; | ||||
| use Doctrine\ORM\Mapping as ORM; | ||||
| @@ -20,7 +19,7 @@ use Doctrine\ORM\Mapping as ORM; | ||||
|  * Charge. | ||||
|  * | ||||
|  * @ORM\Table(name="chill_budget.charge") | ||||
|  * @ORM\Entity(repositoryClass="Chill\BudgetBundle\Repository\ChargeRepository") | ||||
|  * @ORM\Entity(repositoryClass="Chill\AMLI\BudgetBundle\Repository\ChargeRepository") | ||||
|  */ | ||||
| class Charge extends AbstractElement implements HasCenterInterface | ||||
| { | ||||
| @@ -59,7 +58,7 @@ class Charge extends AbstractElement implements HasCenterInterface | ||||
|         $this->setStartDate(new DateTimeImmutable('today')); | ||||
|     } | ||||
|  | ||||
|     public function getCenter(): ?Center | ||||
|     public function getCenter(): \Chill\MainBundle\Entity\Center | ||||
|     { | ||||
|         return $this->getPerson()->getCenter(); | ||||
|     } | ||||
|   | ||||
| @@ -9,9 +9,8 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Entity; | ||||
| namespace Chill\AMLI\BudgetBundle\Entity; | ||||
|  | ||||
| use Chill\MainBundle\Entity\Center; | ||||
| use Chill\MainBundle\Entity\HasCenterInterface; | ||||
| use DateTimeImmutable; | ||||
| use Doctrine\ORM\Mapping as ORM; | ||||
| @@ -20,7 +19,7 @@ use Doctrine\ORM\Mapping as ORM; | ||||
|  * Resource. | ||||
|  * | ||||
|  * @ORM\Table(name="chill_budget.resource") | ||||
|  * @ORM\Entity(repositoryClass="Chill\BudgetBundle\Repository\ResourceRepository") | ||||
|  * @ORM\Entity(repositoryClass="Chill\AMLI\BudgetBundle\Repository\ResourceRepository") | ||||
|  */ | ||||
| class Resource extends AbstractElement implements HasCenterInterface | ||||
| { | ||||
| @@ -38,7 +37,7 @@ class Resource extends AbstractElement implements HasCenterInterface | ||||
|         $this->setStartDate(new DateTimeImmutable('today')); | ||||
|     } | ||||
|  | ||||
|     public function getCenter(): ?Center | ||||
|     public function getCenter(): \Chill\MainBundle\Entity\Center | ||||
|     { | ||||
|         return $this->getPerson()->getCenter(); | ||||
|     } | ||||
|   | ||||
| @@ -9,10 +9,10 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Form; | ||||
| namespace Chill\AMLI\BudgetBundle\Form; | ||||
|  | ||||
| use Chill\BudgetBundle\Config\ConfigRepository; | ||||
| use Chill\BudgetBundle\Entity\Charge; | ||||
| use Chill\AMLI\BudgetBundle\Config\ConfigRepository; | ||||
| use Chill\AMLI\BudgetBundle\Entity\Charge; | ||||
| use Chill\MainBundle\Form\Type\ChillDateType; | ||||
| use Chill\MainBundle\Templating\TranslatableStringHelperInterface; | ||||
| use Symfony\Component\Form\AbstractType; | ||||
| @@ -45,7 +45,6 @@ class ChargeType extends AbstractType | ||||
|             ->add('type', ChoiceType::class, [ | ||||
|                 'choices' => $this->getTypes(), | ||||
|                 'placeholder' => 'Choose a charge type', | ||||
|                 'attr' => ['class' => ' select2 '], | ||||
|             ]) | ||||
|             ->add('amount', MoneyType::class) | ||||
|             ->add('comment', TextareaType::class, [ | ||||
| @@ -97,7 +96,7 @@ class ChargeType extends AbstractType | ||||
|  | ||||
|     public function getBlockPrefix() | ||||
|     { | ||||
|         return 'chill_budgetbundle_charge'; | ||||
|         return 'chill_amli_budgetbundle_charge'; | ||||
|     } | ||||
|  | ||||
|     private function getTypes() | ||||
|   | ||||
| @@ -9,10 +9,10 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Form; | ||||
| namespace Chill\AMLI\BudgetBundle\Form; | ||||
|  | ||||
| use Chill\BudgetBundle\Config\ConfigRepository; | ||||
| use Chill\BudgetBundle\Entity\Resource; | ||||
| use Chill\AMLI\BudgetBundle\Config\ConfigRepository; | ||||
| use Chill\AMLI\BudgetBundle\Entity\Resource; | ||||
| use Chill\MainBundle\Form\Type\ChillDateType; | ||||
| use Chill\MainBundle\Templating\TranslatableStringHelperInterface; | ||||
| use Symfony\Component\Form\AbstractType; | ||||
| @@ -45,7 +45,6 @@ class ResourceType extends AbstractType | ||||
|                 'choices' => $this->getTypes(), | ||||
|                 'placeholder' => 'Choose a resource type', | ||||
|                 'label' => 'Resource element type', | ||||
|                 'attr' => ['class' => ' select2 '], | ||||
|             ]) | ||||
|             ->add('amount', MoneyType::class) | ||||
|             ->add('comment', TextareaType::class, [ | ||||
| @@ -81,7 +80,7 @@ class ResourceType extends AbstractType | ||||
|  | ||||
|     public function getBlockPrefix() | ||||
|     { | ||||
|         return 'chill_budgetbundle_resource'; | ||||
|         return 'chill_amli_budgetbundle_resource'; | ||||
|     } | ||||
|  | ||||
|     private function getTypes() | ||||
|   | ||||
| @@ -1,53 +0,0 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * Chill is a software for social workers | ||||
|  * | ||||
|  * For the full copyright and license information, please view | ||||
|  * the LICENSE file that was distributed with this source code. | ||||
|  */ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Menu; | ||||
|  | ||||
| use Chill\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\MainBundle\Routing\LocalMenuBuilderInterface; | ||||
| use Knp\Menu\MenuItem; | ||||
| use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| class HouseholdMenuBuilder implements LocalMenuBuilderInterface | ||||
| { | ||||
|     protected AuthorizationCheckerInterface $authorizationChecker; | ||||
|  | ||||
|     protected TranslatorInterface $translator; | ||||
|  | ||||
|     public function __construct( | ||||
|         AuthorizationCheckerInterface $authorizationChecker, | ||||
|         TranslatorInterface $translator | ||||
|     ) { | ||||
|         $this->authorizationChecker = $authorizationChecker; | ||||
|         $this->translator = $translator; | ||||
|     } | ||||
|  | ||||
|     public function buildMenu($menuId, MenuItem $menu, array $parameters) | ||||
|     { | ||||
|         /** @var Household $household */ | ||||
|         $household = $parameters['household']; | ||||
|  | ||||
|         // if ($this->authorizationChecker->isGranted(BudgetElementVoter::SHOW, $household)) { | ||||
|         $menu->addChild($this->translator->trans('household.Budget'), [ | ||||
|             'route' => 'chill_budget_elements_household_index', | ||||
|             'routeParameters' => [ | ||||
|                 'id' => $household->getId(), | ||||
|             ], ]) | ||||
|             ->setExtras(['order' => 19]); | ||||
|         // } | ||||
|     } | ||||
|  | ||||
|     public static function getMenuIds(): array | ||||
|     { | ||||
|         return ['household']; | ||||
|     } | ||||
| } | ||||
| @@ -9,19 +9,25 @@ | ||||
| 
 | ||||
| declare(strict_types=1); | ||||
| 
 | ||||
| namespace Chill\BudgetBundle\Menu; | ||||
| namespace Chill\AMLI\BudgetBundle\Menu; | ||||
| 
 | ||||
| use Chill\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\AMLI\BudgetBundle\Security\Authorization\BudgetElementVoter; | ||||
| use Chill\MainBundle\Routing\LocalMenuBuilderInterface; | ||||
| use Knp\Menu\MenuItem; | ||||
| use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
| use Symfony\Component\Translation\TranslatorInterface; | ||||
| 
 | ||||
| class PersonMenuBuilder implements LocalMenuBuilderInterface | ||||
| class UserMenuBuilder implements LocalMenuBuilderInterface | ||||
| { | ||||
|     protected AuthorizationCheckerInterface $authorizationChecker; | ||||
|     /** | ||||
|      * @var AuthorizationCheckerInterface | ||||
|      */ | ||||
|     protected $authorizationChecker; | ||||
| 
 | ||||
|     protected TranslatorInterface $translator; | ||||
|     /** | ||||
|      * @var TranslatorInterface | ||||
|      */ | ||||
|     protected $translator; | ||||
| 
 | ||||
|     public function __construct( | ||||
|         AuthorizationCheckerInterface $authorizationChecker, | ||||
| @@ -33,10 +39,10 @@ class PersonMenuBuilder implements LocalMenuBuilderInterface | ||||
| 
 | ||||
|     public function buildMenu($menuId, MenuItem $menu, array $parameters) | ||||
|     { | ||||
|         /** @var Person $person */ | ||||
|         /** @var \Chill\PersonBundle\Entity\Person $person */ | ||||
|         $person = $parameters['person']; | ||||
| 
 | ||||
|         if ($this->authorizationChecker->isGranted(BudgetElementVoter::SEE, $person)) { | ||||
|         if ($this->authorizationChecker->isGranted(BudgetElementVoter::SHOW, $person)) { | ||||
|             $menu->addChild( | ||||
|                 $this->translator->trans('Budget'), | ||||
|                 [ | ||||
| @@ -44,7 +50,7 @@ class PersonMenuBuilder implements LocalMenuBuilderInterface | ||||
|                     'routeParameters' => ['id' => $person->getId()], | ||||
|                 ] | ||||
|             ) | ||||
|                 ->setExtra('order', 59); | ||||
|                 ->setExtra('order', 460); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| @@ -9,11 +9,10 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Repository; | ||||
| namespace Chill\AMLI\BudgetBundle\Repository; | ||||
|  | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use DateTime; | ||||
| use Doctrine\ORM\EntityRepository; | ||||
|  | ||||
| /** | ||||
|  * ChargeRepository. | ||||
| @@ -21,15 +20,13 @@ use Doctrine\ORM\EntityRepository; | ||||
|  * This class was generated by the Doctrine ORM. Add your own custom | ||||
|  * repository methods below. | ||||
|  */ | ||||
| class ChargeRepository extends EntityRepository | ||||
| class ChargeRepository extends \Doctrine\ORM\EntityRepository | ||||
| { | ||||
|     public function findByEntityAndDate($entity, DateTime $date, $sort = null) | ||||
|     public function findByPersonAndDate(Person $person, DateTime $date, $sort = null) | ||||
|     { | ||||
|         $qb = $this->createQueryBuilder('c'); | ||||
|  | ||||
|         $entityStr = $entity instanceof Person ? 'person' : 'household'; | ||||
|  | ||||
|         $qb->where("c.{$entityStr} = :{$entityStr}") | ||||
|         $qb->where('c.person = :person') | ||||
|             ->andWhere('c.startDate < :date') | ||||
|             ->andWhere('c.startDate < :date OR c.startDate IS NULL'); | ||||
|  | ||||
| @@ -38,7 +35,7 @@ class ChargeRepository extends EntityRepository | ||||
|         } | ||||
|  | ||||
|         $qb->setParameters([ | ||||
|             $entityStr => $entity, | ||||
|             'person' => $person, | ||||
|             'date' => $date, | ||||
|         ]); | ||||
|  | ||||
|   | ||||
| @@ -9,11 +9,10 @@ | ||||
|  | ||||
| declare(strict_types=1); | ||||
|  | ||||
| namespace Chill\BudgetBundle\Repository; | ||||
| namespace Chill\AMLI\BudgetBundle\Repository; | ||||
|  | ||||
| use Chill\PersonBundle\Entity\Person; | ||||
| use DateTime; | ||||
| use Doctrine\ORM\EntityRepository; | ||||
|  | ||||
| /** | ||||
|  * ResourceRepository. | ||||
| @@ -21,28 +20,23 @@ use Doctrine\ORM\EntityRepository; | ||||
|  * This class was generated by the Doctrine ORM. Add your own custom | ||||
|  * repository methods below. | ||||
|  */ | ||||
| class ResourceRepository extends EntityRepository | ||||
| class ResourceRepository extends \Doctrine\ORM\EntityRepository | ||||
| { | ||||
|     public function findByEntityAndDate($entity, DateTime $date, $sort = null) | ||||
|     public function findByPersonAndDate(Person $person, DateTime $date, $sort = null) | ||||
|     { | ||||
|         $qb = $this->createQueryBuilder('c'); | ||||
|  | ||||
|         $entityStr = $entity instanceof Person ? 'person' : 'household'; | ||||
|  | ||||
|         $qb->where("c.{$entityStr} = :{$entityStr}") | ||||
|             // TODO: in controller, the budget and charges asked are also for future and actual | ||||
|             //->andWhere('c.startDate < :date') | ||||
|             // TODO: there is a misconception here, the end date must be lower or null. startDate are never null | ||||
|             //->andWhere('c.startDate < :date OR c.startDate IS NULL'); | ||||
| ; | ||||
|         $qb->where('c.person = :person') | ||||
|             ->andWhere('c.startDate < :date') | ||||
|             ->andWhere('c.startDate < :date OR c.startDate IS NULL'); | ||||
|  | ||||
|         if (null !== $sort) { | ||||
|             $qb->orderBy($sort); | ||||
|         } | ||||
|  | ||||
|         $qb->setParameters([ | ||||
|             $entityStr => $entity, | ||||
|             //'date' => $date, | ||||
|             'person' => $person, | ||||
|             'date' => $date, | ||||
|         ]); | ||||
|  | ||||
|         return $qb->getQuery()->getResult(); | ||||
|   | ||||
| @@ -9,29 +9,29 @@ | ||||
| 
 | ||||
| declare(strict_types=1); | ||||
| 
 | ||||
| namespace Chill\Migrations\Budget; | ||||
| namespace Application\Migrations; | ||||
| 
 | ||||
| use Doctrine\DBAL\Migrations\AbstractMigration; | ||||
| use Doctrine\DBAL\Schema\Schema; | ||||
| use Doctrine\Migrations\AbstractMigration; | ||||
| 
 | ||||
| /** | ||||
|  * create schema for chill budget. | ||||
|  */ | ||||
| final class Version20180522080432 extends AbstractMigration | ||||
| { | ||||
|     public function down(Schema $schema): void | ||||
|     public function down(Schema $schema) | ||||
|     { | ||||
|         $this->addSql('DROP SCHEMA chill_budget CASCADE'); | ||||
|         $this->abortIf($this->connection->getDatabasePlatform()->getName() !== 'postgresql', 'Migration can only be executed safely on \'postgresql\'.'); | ||||
| 
 | ||||
|         $this->addSql('CREATE SCHEMA chill_budget CASCADE'); | ||||
|     } | ||||
| 
 | ||||
|     public function getDescription(): string | ||||
|     public function up(Schema $schema) | ||||
|     { | ||||
|         return 'Creation of necessary tables for budget bundle'; | ||||
|     } | ||||
|         $this->abortIf($this->connection->getDatabasePlatform()->getName() !== 'postgresql', 'Migration can only be executed safely on \'postgresql\'.'); | ||||
| 
 | ||||
|     public function up(Schema $schema): void | ||||
|     { | ||||
|         $this->addSql('CREATE SCHEMA chill_budget'); | ||||
|         $this->addSql('DROP SEQUENCE report_id_seq CASCADE'); | ||||
|         $this->addSql('CREATE SEQUENCE chill_budget.resource_id_seq INCREMENT BY 1 MINVALUE 1 START 1'); | ||||
|         $this->addSql('CREATE SEQUENCE chill_budget.charge_id_seq INCREMENT BY 1 MINVALUE 1 START 1'); | ||||
|         $this->addSql('CREATE TABLE chill_budget.resource (id INT NOT NULL, person_id INT DEFAULT NULL, type VARCHAR(255) NOT NULL, amount NUMERIC(10, 2) NOT NULL, comment TEXT DEFAULT NULL, startDate TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, endDate TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL, PRIMARY KEY(id))'); | ||||
| @@ -9,7 +9,7 @@ | ||||
| 
 | ||||
| declare(strict_types=1); | ||||
| 
 | ||||
| namespace Chill\Migrations\Budget; | ||||
| namespace Application\Migrations; | ||||
| 
 | ||||
| use Doctrine\DBAL\Schema\Schema; | ||||
| use Doctrine\Migrations\AbstractMigration; | ||||
| @@ -21,11 +21,15 @@ final class Version20181219145631 extends AbstractMigration | ||||
| { | ||||
|     public function down(Schema $schema): void | ||||
|     { | ||||
|         $this->abortIf($this->connection->getDatabasePlatform()->getName() !== 'postgresql', 'Migration can only be executed safely on \'postgresql\'.'); | ||||
| 
 | ||||
|         $this->addSql('ALTER TABLE chill_budget.charge ALTER help SET NOT NULL'); | ||||
|     } | ||||
| 
 | ||||
|     public function up(Schema $schema): void | ||||
|     { | ||||
|         $this->abortIf($this->connection->getDatabasePlatform()->getName() !== 'postgresql', 'Migration can only be executed safely on \'postgresql\'.'); | ||||
| 
 | ||||
|         $this->addSql('ALTER TABLE chill_budget.charge ALTER help DROP NOT NULL'); | ||||
|     } | ||||
| } | ||||
| @@ -1,61 +0,0 @@ | ||||
| .subtitle { | ||||
|     margin-top: 1rem; | ||||
|     margin-bottom: 1rem; | ||||
|     padding: 1rem; | ||||
| } | ||||
| .family-title { | ||||
|     margin-bottom: 1rem !important; | ||||
| } | ||||
| .budget-table th { | ||||
|     th { | ||||
|         color: white; | ||||
|     } | ||||
| } | ||||
| .budget-table { | ||||
|     th.charge { | ||||
|         background-color: #e03851d7; | ||||
|     } | ||||
| } | ||||
| .budget-table { | ||||
|     th.resource { | ||||
|         background-color: #6d9e63d8; | ||||
|     } | ||||
| } | ||||
| .budget-table { | ||||
|     th, td { | ||||
|         padding: 10px; | ||||
|         text-align: right; | ||||
|     } | ||||
|     td.column-wide { | ||||
|         width: 20%; | ||||
|     } | ||||
|     td.column-small { | ||||
|         width: 15%; | ||||
|         &.right { | ||||
|             align-items: right; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| .btn-budget { | ||||
|     margin-right: 1rem !important; | ||||
| } | ||||
|  | ||||
| .el-type { | ||||
|     font-weight: 600; | ||||
|     text-align: left !important; | ||||
| } | ||||
|  | ||||
| .total { | ||||
|     margin-top: 1rem; | ||||
|     border-top: 1px dashed black; | ||||
| } | ||||
|  | ||||
| .accordion-item { | ||||
|     margin-bottom: 1rem; | ||||
| } | ||||
|  | ||||
| button[aria-expanded="true"] > span.folded, | ||||
| button[aria-expanded="false"] > span.unfolded { display: none; } | ||||
| button[aria-expanded="false"] > span.folded, | ||||
| button[aria-expanded="true"] > span.unfolded { display: inline; } | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user