mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
Merge remote-tracking branch 'origin/master' into issue389_add_age
This commit is contained in:
commit
90d0cbc3b1
25
CHANGELOG.md
25
CHANGELOG.md
@ -11,13 +11,32 @@ and this project adheres to
|
|||||||
## Unreleased
|
## Unreleased
|
||||||
|
|
||||||
<!-- write down unreleased development here -->
|
<!-- write down unreleased development here -->
|
||||||
* [parcours] comments truncated if too long + link added (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/406)
|
* [search]: listing of parcours display changed (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/410)
|
||||||
* [person]: possibility to add person resources (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/382)
|
* [user]: page with accompanying periods to which is user is referent (https://gitlab.com/champs-libres/departement-de-la-vendee/chill/-/issues/408)
|
||||||
* [person ressources]: module added
|
|
||||||
* [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)
|
* [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)
|
||||||
|
|
||||||
## Test releases
|
## Test releases
|
||||||
|
|
||||||
|
### 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
|
||||||
|
* [parcours] bugfix if deathdate is not defined (eg. for a thirdparty) parcours is still displayed. Gave error before.
|
||||||
|
|
||||||
|
|
||||||
### test release 2022-01-24
|
### 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)
|
* [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)
|
||||||
|
@ -256,7 +256,7 @@ final class ActivityController extends AbstractController
|
|||||||
if ($person instanceof Person) {
|
if ($person instanceof Person) {
|
||||||
$this->denyAccessUnlessGranted(ActivityVoter::SEE, $person);
|
$this->denyAccessUnlessGranted(ActivityVoter::SEE, $person);
|
||||||
$activities = $this->activityACLAwareRepository
|
$activities = $this->activityACLAwareRepository
|
||||||
->findByPerson($person, ActivityVoter::SEE, 0, null);
|
->findByPerson($person, ActivityVoter::SEE, 0, null, ['date' => 'DESC', 'id' => 'DESC']);
|
||||||
|
|
||||||
$event = new PrivacyEvent($person, [
|
$event = new PrivacyEvent($person, [
|
||||||
'element_class' => Activity::class,
|
'element_class' => Activity::class,
|
||||||
@ -269,7 +269,7 @@ final class ActivityController extends AbstractController
|
|||||||
$this->denyAccessUnlessGranted(ActivityVoter::SEE, $accompanyingPeriod);
|
$this->denyAccessUnlessGranted(ActivityVoter::SEE, $accompanyingPeriod);
|
||||||
|
|
||||||
$activities = $this->activityACLAwareRepository
|
$activities = $this->activityACLAwareRepository
|
||||||
->findByAccompanyingPeriod($accompanyingPeriod, ActivityVoter::SEE);
|
->findByAccompanyingPeriod($accompanyingPeriod, ActivityVoter::SEE, 0, null, ['date' => 'DESC', 'id' => 'DESC']);
|
||||||
|
|
||||||
$view = 'ChillActivityBundle:Activity:listAccompanyingCourse.html.twig';
|
$view = 'ChillActivityBundle:Activity:listAccompanyingCourse.html.twig';
|
||||||
}
|
}
|
||||||
|
@ -29,9 +29,13 @@ use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface;
|
|||||||
final class ActivityVoterTest extends KernelTestCase
|
final class ActivityVoterTest extends KernelTestCase
|
||||||
{
|
{
|
||||||
use PrepareActivityTrait;
|
use PrepareActivityTrait;
|
||||||
|
|
||||||
use PrepareCenterTrait;
|
use PrepareCenterTrait;
|
||||||
|
|
||||||
use PreparePersonTrait;
|
use PreparePersonTrait;
|
||||||
|
|
||||||
use PrepareScopeTrait;
|
use PrepareScopeTrait;
|
||||||
|
|
||||||
use PrepareUserTrait;
|
use PrepareUserTrait;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -32,6 +32,8 @@ final class AsideActivityController extends CRUDController
|
|||||||
{
|
{
|
||||||
$asideActivity = new AsideActivity();
|
$asideActivity = new AsideActivity();
|
||||||
|
|
||||||
|
$asideActivity->setAgent($this->getUser());
|
||||||
|
|
||||||
$duration = $request->query->get('duration', '300');
|
$duration = $request->query->get('duration', '300');
|
||||||
$duration = DateTime::createFromFormat('U', $duration);
|
$duration = DateTime::createFromFormat('U', $duration);
|
||||||
$asideActivity->setDuration($duration);
|
$asideActivity->setDuration($duration);
|
||||||
|
@ -14,7 +14,6 @@ namespace Chill\AsideActivityBundle\Form;
|
|||||||
use Chill\AsideActivityBundle\Entity\AsideActivity;
|
use Chill\AsideActivityBundle\Entity\AsideActivity;
|
||||||
use Chill\AsideActivityBundle\Entity\AsideActivityCategory;
|
use Chill\AsideActivityBundle\Entity\AsideActivityCategory;
|
||||||
use Chill\AsideActivityBundle\Templating\Entity\CategoryRender;
|
use Chill\AsideActivityBundle\Templating\Entity\CategoryRender;
|
||||||
use Chill\MainBundle\Entity\User;
|
|
||||||
use Chill\MainBundle\Form\Type\ChillDateType;
|
use Chill\MainBundle\Form\Type\ChillDateType;
|
||||||
use Chill\MainBundle\Form\Type\ChillTextareaType;
|
use Chill\MainBundle\Form\Type\ChillTextareaType;
|
||||||
use Chill\MainBundle\Form\Type\PickUserDynamicType;
|
use Chill\MainBundle\Form\Type\PickUserDynamicType;
|
||||||
@ -69,22 +68,6 @@ final class AsideActivityFormType extends AbstractType
|
|||||||
];
|
];
|
||||||
|
|
||||||
$builder
|
$builder
|
||||||
// ->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('agent', PickUserDynamicType::class, [
|
->add('agent', PickUserDynamicType::class, [
|
||||||
'label' => 'For agent',
|
'label' => 'For agent',
|
||||||
'required' => true,
|
'required' => true,
|
||||||
|
@ -42,10 +42,16 @@ class Address
|
|||||||
*/
|
*/
|
||||||
private $buildingName;
|
private $buildingName;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\Column(type="boolean")
|
||||||
|
* @Groups({"write"})
|
||||||
|
*/
|
||||||
|
private bool $confidential = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var string|null
|
* @var string|null
|
||||||
*
|
*
|
||||||
* @ORM\Column(type="string", length=16, nullable=true)
|
* @ORM\Column(type="string", length=255, nullable=true)
|
||||||
* @Groups({"write"})
|
* @Groups({"write"})
|
||||||
*/
|
*/
|
||||||
private $corridor;
|
private $corridor;
|
||||||
@ -78,7 +84,7 @@ class Address
|
|||||||
/**
|
/**
|
||||||
* @var string|null
|
* @var string|null
|
||||||
*
|
*
|
||||||
* @ORM\Column(type="string", length=16, nullable=true)
|
* @ORM\Column(type="string", length=255, nullable=true)
|
||||||
* @Groups({"write"})
|
* @Groups({"write"})
|
||||||
*/
|
*/
|
||||||
private $flat;
|
private $flat;
|
||||||
@ -86,7 +92,7 @@ class Address
|
|||||||
/**
|
/**
|
||||||
* @var string|null
|
* @var string|null
|
||||||
*
|
*
|
||||||
* @ORM\Column(type="string", length=16, nullable=true)
|
* @ORM\Column(type="string", length=255, nullable=true)
|
||||||
* @Groups({"write"})
|
* @Groups({"write"})
|
||||||
*/
|
*/
|
||||||
private $floor;
|
private $floor;
|
||||||
@ -143,7 +149,7 @@ class Address
|
|||||||
/**
|
/**
|
||||||
* @var string|null
|
* @var string|null
|
||||||
*
|
*
|
||||||
* @ORM\Column(type="string", length=16, nullable=true)
|
* @ORM\Column(type="string", length=255, nullable=true)
|
||||||
* @Groups({"write"})
|
* @Groups({"write"})
|
||||||
*/
|
*/
|
||||||
private $steps;
|
private $steps;
|
||||||
@ -192,6 +198,7 @@ class Address
|
|||||||
return (new Address())
|
return (new Address())
|
||||||
->setAddressReference($original->getAddressReference())
|
->setAddressReference($original->getAddressReference())
|
||||||
->setBuildingName($original->getBuildingName())
|
->setBuildingName($original->getBuildingName())
|
||||||
|
->setConfidential($original->getConfidential())
|
||||||
->setCorridor($original->getCorridor())
|
->setCorridor($original->getCorridor())
|
||||||
->setCustoms($original->getCustoms())
|
->setCustoms($original->getCustoms())
|
||||||
->setDistribution($original->getDistribution())
|
->setDistribution($original->getDistribution())
|
||||||
@ -229,6 +236,11 @@ class Address
|
|||||||
return $this->buildingName;
|
return $this->buildingName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getConfidential(): bool
|
||||||
|
{
|
||||||
|
return $this->confidential;
|
||||||
|
}
|
||||||
|
|
||||||
public function getCorridor(): ?string
|
public function getCorridor(): ?string
|
||||||
{
|
{
|
||||||
return $this->corridor;
|
return $this->corridor;
|
||||||
@ -369,6 +381,13 @@ class Address
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setConfidential(bool $confidential): self
|
||||||
|
{
|
||||||
|
$this->confidential = $confidential;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function setCorridor(?string $corridor): self
|
public function setCorridor(?string $corridor): self
|
||||||
{
|
{
|
||||||
$this->corridor = $corridor;
|
$this->corridor = $corridor;
|
||||||
|
@ -20,10 +20,9 @@ use Doctrine\ORM\Mapping as ORM;
|
|||||||
class CommentEmbeddable
|
class CommentEmbeddable
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @var string
|
|
||||||
* @ORM\Column(type="text", nullable=true)
|
* @ORM\Column(type="text", nullable=true)
|
||||||
*/
|
*/
|
||||||
private $comment;
|
private ?string $comment = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var DateTime
|
* @var DateTime
|
||||||
@ -39,10 +38,7 @@ class CommentEmbeddable
|
|||||||
*/
|
*/
|
||||||
private $userId;
|
private $userId;
|
||||||
|
|
||||||
/**
|
public function getComment(): ?string
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
public function getComment()
|
|
||||||
{
|
{
|
||||||
return $this->comment;
|
return $this->comment;
|
||||||
}
|
}
|
||||||
@ -68,9 +64,6 @@ class CommentEmbeddable
|
|||||||
return empty($this->getComment());
|
return empty($this->getComment());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $comment
|
|
||||||
*/
|
|
||||||
public function setComment(?string $comment)
|
public function setComment(?string $comment)
|
||||||
{
|
{
|
||||||
$this->comment = $comment;
|
$this->comment = $comment;
|
||||||
|
166
src/Bundle/ChillMainBundle/Entity/ResidentialAddress.php
Normal file
166
src/Bundle/ChillMainBundle/Entity/ResidentialAddress.php
Normal file
@ -0,0 +1,166 @@
|
|||||||
|
<?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\MainBundle\Entity;
|
||||||
|
|
||||||
|
use Chill\MainBundle\Entity\Embeddable\CommentEmbeddable;
|
||||||
|
use Chill\MainBundle\Repository\ResidentialAddressRepository;
|
||||||
|
use Chill\PersonBundle\Entity\Person;
|
||||||
|
use Chill\ThirdPartyBundle\Entity\ThirdParty;
|
||||||
|
use DateTimeImmutable;
|
||||||
|
use Doctrine\ORM\Mapping as ORM;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\Entity(repositoryClass=ResidentialAddressRepository::class)
|
||||||
|
* @ORM\Table(name="chill_main_residential_address")
|
||||||
|
*/
|
||||||
|
class ResidentialAddress
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @ORM\ManyToOne(targetEntity=Address::class)
|
||||||
|
* @ORM\JoinColumn(nullable=true)
|
||||||
|
*/
|
||||||
|
private ?Address $address = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\Embedded(class="Chill\MainBundle\Entity\Embeddable\CommentEmbeddable", columnPrefix="residentialAddressComment_")
|
||||||
|
*/
|
||||||
|
private CommentEmbeddable $comment;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\Column(type="datetime_immutable", nullable=true)
|
||||||
|
*/
|
||||||
|
private ?DateTimeImmutable $endDate = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\ManyToOne(targetEntity=Person::class)
|
||||||
|
* @ORM\JoinColumn(nullable=true)
|
||||||
|
*/
|
||||||
|
private ?Person $hostPerson = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\ManyToOne(targetEntity=ThirdParty::class)
|
||||||
|
* @ORM\JoinColumn(nullable=true)
|
||||||
|
*/
|
||||||
|
private ?ThirdParty $hostThirdParty = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\Id
|
||||||
|
* @ORM\GeneratedValue
|
||||||
|
* @ORM\Column(type="integer")
|
||||||
|
*/
|
||||||
|
private $id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\ManyToOne(targetEntity=Person::class)
|
||||||
|
* @ORM\JoinColumn(nullable=false)
|
||||||
|
*/
|
||||||
|
private Person $person;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\Column(type="datetime_immutable")
|
||||||
|
*/
|
||||||
|
private ?DateTimeImmutable $startDate = null;
|
||||||
|
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->comment = new CommentEmbeddable();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAddress(): ?Address
|
||||||
|
{
|
||||||
|
return $this->address;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getComment(): CommentEmbeddable
|
||||||
|
{
|
||||||
|
return $this->comment;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getEndDate(): ?DateTimeImmutable
|
||||||
|
{
|
||||||
|
return $this->endDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getHostPerson(): ?Person
|
||||||
|
{
|
||||||
|
return $this->hostPerson;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getHostThirdParty(): ?ThirdParty
|
||||||
|
{
|
||||||
|
return $this->hostThirdParty;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getId(): ?int
|
||||||
|
{
|
||||||
|
return $this->id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getPerson(): ?Person
|
||||||
|
{
|
||||||
|
return $this->person;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getStartDate(): ?DateTimeImmutable
|
||||||
|
{
|
||||||
|
return $this->startDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setAddress(?Address $address): self
|
||||||
|
{
|
||||||
|
$this->address = $address;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setComment(CommentEmbeddable $comment): self
|
||||||
|
{
|
||||||
|
$this->comment = $comment;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setEndDate(?DateTimeImmutable $endDate): self
|
||||||
|
{
|
||||||
|
$this->endDate = $endDate;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setHostPerson(?Person $hostPerson): self
|
||||||
|
{
|
||||||
|
$this->hostPerson = $hostPerson;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setHostThirdParty(?ThirdParty $hostThirdParty): self
|
||||||
|
{
|
||||||
|
$this->hostThirdParty = $hostThirdParty;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setPerson(?Person $person): self
|
||||||
|
{
|
||||||
|
$this->person = $person;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setStartDate(DateTimeImmutable $startDate): self
|
||||||
|
{
|
||||||
|
$this->startDate = $startDate;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
}
|
@ -37,6 +37,7 @@ use function count;
|
|||||||
class EntityWorkflow implements TrackCreationInterface, TrackUpdateInterface
|
class EntityWorkflow implements TrackCreationInterface, TrackUpdateInterface
|
||||||
{
|
{
|
||||||
use TrackCreationTrait;
|
use TrackCreationTrait;
|
||||||
|
|
||||||
use TrackUpdateTrait;
|
use TrackUpdateTrait;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -24,6 +24,7 @@ use Doctrine\ORM\Mapping as ORM;
|
|||||||
class EntityWorkflowComment implements TrackCreationInterface, TrackUpdateInterface
|
class EntityWorkflowComment implements TrackCreationInterface, TrackUpdateInterface
|
||||||
{
|
{
|
||||||
use TrackCreationTrait;
|
use TrackCreationTrait;
|
||||||
|
|
||||||
use TrackUpdateTrait;
|
use TrackUpdateTrait;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -0,0 +1,73 @@
|
|||||||
|
<?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\MainBundle\Form\Type;
|
||||||
|
|
||||||
|
use Chill\MainBundle\Entity\ResidentialAddress;
|
||||||
|
use Chill\PersonBundle\Form\Type\PickPersonDynamicType;
|
||||||
|
use Chill\ThirdPartyBundle\Form\Type\PickThirdpartyDynamicType;
|
||||||
|
use Symfony\Component\Form\AbstractType;
|
||||||
|
use Symfony\Component\Form\Extension\Core\Type\DateType;
|
||||||
|
use Symfony\Component\Form\FormBuilderInterface;
|
||||||
|
use Symfony\Component\OptionsResolver\OptionsResolver;
|
||||||
|
|
||||||
|
final class ResidentialAddressType extends AbstractType
|
||||||
|
{
|
||||||
|
public function buildForm(FormBuilderInterface $builder, array $options)
|
||||||
|
{
|
||||||
|
$builder
|
||||||
|
->add('startDate', DateType::class, [
|
||||||
|
'required' => true,
|
||||||
|
'input' => 'datetime_immutable',
|
||||||
|
'widget' => 'single_text',
|
||||||
|
])
|
||||||
|
->add('endDate', DateType::class, [
|
||||||
|
'required' => false,
|
||||||
|
'input' => 'datetime_immutable',
|
||||||
|
'widget' => 'single_text',
|
||||||
|
])
|
||||||
|
->add('comment', CommentType::class, [
|
||||||
|
'required' => false,
|
||||||
|
]);
|
||||||
|
|
||||||
|
if ('person' === $options['kind']) {
|
||||||
|
$builder
|
||||||
|
->add('hostPerson', PickPersonDynamicType::class, [
|
||||||
|
'label' => 'Person',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ('thirdparty' === $options['kind']) {
|
||||||
|
$builder
|
||||||
|
->add('hostThirdParty', PickThirdpartyDynamicType::class, [
|
||||||
|
'label' => 'Third party',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ('address' === $options['kind']) {
|
||||||
|
$builder
|
||||||
|
->add('address', PickAddressType::class, [
|
||||||
|
'required' => false,
|
||||||
|
'label' => 'Address',
|
||||||
|
'use_valid_from' => false,
|
||||||
|
'use_valid_to' => false,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function configureOptions(OptionsResolver $resolver)
|
||||||
|
{
|
||||||
|
$resolver->setDefaults([
|
||||||
|
'data_class' => ResidentialAddress::class,
|
||||||
|
'kind' => null,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,59 @@
|
|||||||
|
<?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\MainBundle\Repository;
|
||||||
|
|
||||||
|
use Chill\MainBundle\Entity\ResidentialAddress;
|
||||||
|
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
||||||
|
use Doctrine\Persistence\ManagerRegistry;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @method ResidentialAddress|null find($id, $lockMode = null, $lockVersion = null)
|
||||||
|
* @method ResidentialAddress|null findOneBy(array $criteria, array $orderBy = null)
|
||||||
|
* @method ResidentialAddress[] findAll()
|
||||||
|
* @method ResidentialAddress[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
|
||||||
|
*/
|
||||||
|
class ResidentialAddressRepository extends ServiceEntityRepository
|
||||||
|
{
|
||||||
|
public function __construct(ManagerRegistry $registry)
|
||||||
|
{
|
||||||
|
parent::__construct($registry, ResidentialAddress::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * @return ResidentialAddress[] Returns an array of ResidentialAddress objects
|
||||||
|
// */
|
||||||
|
/*
|
||||||
|
public function findByExampleField($value)
|
||||||
|
{
|
||||||
|
return $this->createQueryBuilder('r')
|
||||||
|
->andWhere('r.exampleField = :val')
|
||||||
|
->setParameter('val', $value)
|
||||||
|
->orderBy('r.id', 'ASC')
|
||||||
|
->setMaxResults(10)
|
||||||
|
->getQuery()
|
||||||
|
->getResult()
|
||||||
|
;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
public function findOneBySomeField($value): ?ResidentialAddress
|
||||||
|
{
|
||||||
|
return $this->createQueryBuilder('r')
|
||||||
|
->andWhere('r.exampleField = :val')
|
||||||
|
->setParameter('val', $value)
|
||||||
|
->getQuery()
|
||||||
|
->getOneOrNullResult()
|
||||||
|
;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
@ -1,21 +1,19 @@
|
|||||||
require('./blur.scss');
|
require('./blur.scss');
|
||||||
|
|
||||||
var toggleBlur = function(e){
|
document.querySelectorAll('.confidential').forEach(function (el) {
|
||||||
|
let i = document.createElement('i');
|
||||||
var btn = e.target;
|
const classes = ['fa', 'fa-eye', 'toggle'];
|
||||||
|
i.classList.add(...classes);
|
||||||
btn.previousElementSibling.classList.toggle("blur");
|
el.appendChild(i);
|
||||||
btn.classList.toggle("fa-eye");
|
const toggleBlur = function(e) {
|
||||||
btn.classList.toggle("fa-eye-slash");
|
for (let child of el.children) {
|
||||||
|
if (!child.classList.contains('toggle')) {
|
||||||
|
child.classList.toggle('blur');
|
||||||
}
|
}
|
||||||
|
|
||||||
var infos = document.getElementsByClassName("confidential");
|
|
||||||
for(var i=0; i < infos.length; i++){
|
|
||||||
infos[i].insertAdjacentHTML('beforeend', '<i class="fa fa-eye toggle" aria-hidden="true"></i>');
|
|
||||||
}
|
}
|
||||||
|
i.classList.toggle('fa-eye');
|
||||||
var toggles = document.getElementsByClassName("toggle");
|
i.classList.toggle('fa-eye-slash');
|
||||||
for(var i=0; i < toggles.length; i++){
|
|
||||||
toggles[i].addEventListener("click", toggleBlur);
|
|
||||||
}
|
}
|
||||||
|
i.addEventListener('click', toggleBlur);
|
||||||
|
toggleBlur();
|
||||||
|
});
|
||||||
|
@ -19,6 +19,12 @@ function loadDynamicPicker(element) {
|
|||||||
input = element.querySelector('[data-input-uniqid="'+ el.dataset.uniqid +'"]'),
|
input = element.querySelector('[data-input-uniqid="'+ el.dataset.uniqid +'"]'),
|
||||||
picked = (isMultiple) ? (JSON.parse(input.value)) : ((input.value === '[]') ? (null) : ([JSON.parse(input.value)]));
|
picked = (isMultiple) ? (JSON.parse(input.value)) : ((input.value === '[]') ? (null) : ([JSON.parse(input.value)]));
|
||||||
|
|
||||||
|
if (!isMultiple) {
|
||||||
|
if (input.value === '[]'){
|
||||||
|
input.value = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const app = createApp({
|
const app = createApp({
|
||||||
template: '<pick-entity ' +
|
template: '<pick-entity ' +
|
||||||
':multiple="multiple" ' +
|
':multiple="multiple" ' +
|
||||||
|
@ -562,6 +562,7 @@ export default {
|
|||||||
this.entity.loaded.cities = [];
|
this.entity.loaded.cities = [];
|
||||||
this.entity.loaded.countries = [];
|
this.entity.loaded.countries = [];
|
||||||
|
|
||||||
|
this.entity.selected.confidential = this.context.edit ? this.entity.address.confidential : false;
|
||||||
this.entity.selected.isNoAddress = (this.context.edit && this.entity.address.text === '') ? true : false;
|
this.entity.selected.isNoAddress = (this.context.edit && this.entity.address.text === '') ? true : false;
|
||||||
|
|
||||||
this.entity.selected.country = this.context.edit ? this.entity.address.country : {};
|
this.entity.selected.country = this.context.edit ? this.entity.address.country : {};
|
||||||
@ -593,6 +594,7 @@ export default {
|
|||||||
{
|
{
|
||||||
console.log('apply changes');
|
console.log('apply changes');
|
||||||
let newAddress = {
|
let newAddress = {
|
||||||
|
'confidential': this.entity.selected.confidential,
|
||||||
'isNoAddress': this.entity.selected.isNoAddress,
|
'isNoAddress': this.entity.selected.isNoAddress,
|
||||||
'street': this.entity.selected.isNoAddress ? '' : this.entity.selected.address.street,
|
'street': this.entity.selected.isNoAddress ? '' : this.entity.selected.address.street,
|
||||||
'streetNumber': this.entity.selected.isNoAddress ? '' : this.entity.selected.address.streetNumber,
|
'streetNumber': this.entity.selected.isNoAddress ? '' : this.entity.selected.address.streetNumber,
|
||||||
|
@ -6,7 +6,6 @@
|
|||||||
<input class="form-control"
|
<input class="form-control"
|
||||||
type="text"
|
type="text"
|
||||||
name="floor"
|
name="floor"
|
||||||
maxlength=16
|
|
||||||
:placeholder="$t('floor')"
|
:placeholder="$t('floor')"
|
||||||
v-model="floor"/>
|
v-model="floor"/>
|
||||||
<label for="floor">{{ $t('floor') }}</label>
|
<label for="floor">{{ $t('floor') }}</label>
|
||||||
@ -15,7 +14,6 @@
|
|||||||
<input class="form-control"
|
<input class="form-control"
|
||||||
type="text"
|
type="text"
|
||||||
name="corridor"
|
name="corridor"
|
||||||
maxlength=16
|
|
||||||
:placeholder="$t('corridor')"
|
:placeholder="$t('corridor')"
|
||||||
v-model="corridor"/>
|
v-model="corridor"/>
|
||||||
<label for="corridor">{{ $t('corridor') }}</label>
|
<label for="corridor">{{ $t('corridor') }}</label>
|
||||||
@ -24,7 +22,6 @@
|
|||||||
<input class="form-control"
|
<input class="form-control"
|
||||||
type="text"
|
type="text"
|
||||||
name="steps"
|
name="steps"
|
||||||
maxlength=16
|
|
||||||
:placeholder="$t('steps')"
|
:placeholder="$t('steps')"
|
||||||
v-model="steps"/>
|
v-model="steps"/>
|
||||||
<label for="steps">{{ $t('steps') }}</label>
|
<label for="steps">{{ $t('steps') }}</label>
|
||||||
@ -33,7 +30,6 @@
|
|||||||
<input class="form-control"
|
<input class="form-control"
|
||||||
type="text"
|
type="text"
|
||||||
name="flat"
|
name="flat"
|
||||||
maxlength=16
|
|
||||||
:placeholder="$t('flat')"
|
:placeholder="$t('flat')"
|
||||||
v-model="flat"/>
|
v-model="flat"/>
|
||||||
<label for="flat">{{ $t('flat') }}</label>
|
<label for="flat">{{ $t('flat') }}</label>
|
||||||
|
@ -17,12 +17,22 @@
|
|||||||
<div class="row my-3">
|
<div class="row my-3">
|
||||||
<div class="col-lg-6">
|
<div class="col-lg-6">
|
||||||
|
|
||||||
|
<div class="form-check">
|
||||||
|
<input type="checkbox"
|
||||||
|
class="form-check-input"
|
||||||
|
id="isConfidential"
|
||||||
|
v-model="isConfidential"
|
||||||
|
:value="valueConfidential" />
|
||||||
|
<label class="form-check-label" for="isConfidential">
|
||||||
|
{{ $t('isConfidential') }}
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
<div class="form-check">
|
<div class="form-check">
|
||||||
<input type="checkbox"
|
<input type="checkbox"
|
||||||
class="form-check-input"
|
class="form-check-input"
|
||||||
id="isNoAddress"
|
id="isNoAddress"
|
||||||
v-model="isNoAddress"
|
v-model="isNoAddress"
|
||||||
v-bind:value="value" />
|
:value="value" />
|
||||||
<label class="form-check-label" for="isNoAddress">
|
<label class="form-check-label" for="isNoAddress">
|
||||||
{{ $t('isNoAddress') }}
|
{{ $t('isNoAddress') }}
|
||||||
</label>
|
</label>
|
||||||
@ -118,7 +128,8 @@ export default {
|
|||||||
emits: ['getCities', 'getReferenceAddresses'],
|
emits: ['getCities', 'getReferenceAddresses'],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
value: false
|
value: false,
|
||||||
|
valueConfidential: false,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@ -134,6 +145,14 @@ export default {
|
|||||||
addressMap() {
|
addressMap() {
|
||||||
return this.entity.addressMap;
|
return this.entity.addressMap;
|
||||||
},
|
},
|
||||||
|
isConfidential: {
|
||||||
|
set(value) {
|
||||||
|
this.entity.selected.confidential = value;
|
||||||
|
},
|
||||||
|
get() {
|
||||||
|
return this.entity.selected.confidential;
|
||||||
|
}
|
||||||
|
},
|
||||||
isNoAddress: {
|
isNoAddress: {
|
||||||
set(value) {
|
set(value) {
|
||||||
console.log('isNoAddress value', value);
|
console.log('isNoAddress value', value);
|
||||||
|
@ -18,6 +18,7 @@ const addressMessages = {
|
|||||||
other_address: 'Autre adresse',
|
other_address: 'Autre adresse',
|
||||||
create_address: 'Adresse inconnue. Cliquez ici pour créer une nouvelle adresse',
|
create_address: 'Adresse inconnue. Cliquez ici pour créer une nouvelle adresse',
|
||||||
isNoAddress: 'Pas d\'adresse complète',
|
isNoAddress: 'Pas d\'adresse complète',
|
||||||
|
isConfidential: 'Adresse confidentielle',
|
||||||
street: 'Nom de rue',
|
street: 'Nom de rue',
|
||||||
streetNumber: 'Numéro',
|
streetNumber: 'Numéro',
|
||||||
floor: 'Étage',
|
floor: 'Étage',
|
||||||
|
@ -1,22 +1,26 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="confidential" v-on:click="toggleBlur">
|
<div :class="classes">
|
||||||
<div class="confidential-content blur">
|
<div class="confidential-content" :class="{ 'blur': isBlurred }">
|
||||||
<slot name="confidential-content"></slot>
|
<slot name="confidential-content"></slot>
|
||||||
</div>
|
</div>
|
||||||
<i class="fa fa-eye toggle" aria-hidden="true"></i>
|
<div>
|
||||||
|
<i class="fa fa-eye toggle" aria-hidden="true" @click="toggleBlur"></i>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
export default {
|
export default {
|
||||||
name: "Confidential",
|
name: "Confidential",
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
isBlurred: true,
|
||||||
|
};
|
||||||
|
},
|
||||||
methods : {
|
methods : {
|
||||||
toggleBlur: function(e){
|
toggleBlur() {
|
||||||
if(e.target.matches('.toggle')){
|
console.log('toggle blur');
|
||||||
e.target.previousElementSibling.classList.toggle("blur");
|
this.isBlurred = !this.isBlurred;
|
||||||
e.target.classList.toggle("fa-eye");
|
|
||||||
e.target.classList.toggle("fa-eye-slash");
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,12 @@
|
|||||||
<template>
|
<template>
|
||||||
|
|
||||||
<component :is="component" class="chill-entity entity-address my-3">
|
<component :is="component" class="chill-entity entity-address my-3">
|
||||||
|
|
||||||
<component :is="component" class="address" :class="multiline">
|
<component :is="component" class="address" :class="multiline">
|
||||||
|
|
||||||
|
<div v-if="isConfidential">
|
||||||
|
<confidential>
|
||||||
|
<template v-slot:confidential-content>
|
||||||
<div v-if="isMultiline === true">
|
<div v-if="isMultiline === true">
|
||||||
<p v-for="(l, i) in address.lines" :key="`line-${i}`">
|
<p v-for="(l, i) in address.lines" :key="`line-${i}`">
|
||||||
{{ l }}
|
{{ l }}
|
||||||
@ -21,6 +26,33 @@
|
|||||||
{{ address.country.name.fr }}
|
{{ address.country.name.fr }}
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
</confidential>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div v-if="!isConfidential">
|
||||||
|
<div v-if="isMultiline === true">
|
||||||
|
<p v-for="(l, i) in address.lines" :key="`line-${i}`">
|
||||||
|
{{ l }}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<p v-if="address.text"
|
||||||
|
class="street">
|
||||||
|
{{ address.text }}
|
||||||
|
</p>
|
||||||
|
<p v-if="address.postcode"
|
||||||
|
class="postcode">
|
||||||
|
{{ address.postcode.code }} {{ address.postcode.name }}
|
||||||
|
</p>
|
||||||
|
<p v-if="address.country"
|
||||||
|
class="country">
|
||||||
|
{{ address.country.name.fr }}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
</component>
|
</component>
|
||||||
|
|
||||||
<!-- <div v-if="isMultiline === true" class="address-more">
|
<!-- <div v-if="isMultiline === true" class="address-more">
|
||||||
@ -78,8 +110,14 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
|
||||||
|
import Confidential from 'ChillMainAssets/vuejs/_components/Confidential.vue';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'AddressRenderBox',
|
name: 'AddressRenderBox',
|
||||||
|
components: {
|
||||||
|
Confidential
|
||||||
|
},
|
||||||
props: {
|
props: {
|
||||||
address: {
|
address: {
|
||||||
type: Object
|
type: Object
|
||||||
@ -100,6 +138,9 @@ export default {
|
|||||||
multiline() {
|
multiline() {
|
||||||
//console.log(this.isMultiline, typeof this.isMultiline);
|
//console.log(this.isMultiline, typeof this.isMultiline);
|
||||||
return this.isMultiline === true ? "multiline" : "";
|
return this.isMultiline === true ? "multiline" : "";
|
||||||
|
},
|
||||||
|
isConfidential() {
|
||||||
|
return this.address.confidential;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -59,7 +59,7 @@
|
|||||||
must be shown in such list
|
must be shown in such list
|
||||||
#}
|
#}
|
||||||
{%- if render == 'list' -%}
|
{%- if render == 'list' -%}
|
||||||
<li class="chill-entity entity-address">
|
<li class="chill-entity entity-address {% if address.confidential %}confidential{% endif %}">
|
||||||
{% if options['with_picto'] %}
|
{% if options['with_picto'] %}
|
||||||
<i class="fa fa-li fa-map-marker"></i>
|
<i class="fa fa-li fa-map-marker"></i>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@ -68,7 +68,7 @@
|
|||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
|
|
||||||
{%- if render == 'inline' -%}
|
{%- if render == 'inline' -%}
|
||||||
<span class="chill-entity entity-address">
|
<span class="chill-entity entity-address {% if address.confidential %}confidential{% endif %}">
|
||||||
{% if options['with_picto'] %}
|
{% if options['with_picto'] %}
|
||||||
<i class="fa fa-fw fa-map-marker"></i>
|
<i class="fa fa-fw fa-map-marker"></i>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@ -77,7 +77,7 @@
|
|||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
|
|
||||||
{%- if render == 'bloc' -%}
|
{%- if render == 'bloc' -%}
|
||||||
<div class="chill-entity entity-address">
|
<div class="chill-entity entity-address {% if address.confidential %}confidential{% endif %}">
|
||||||
{% if options['has_no_address'] == true and address.isNoAddress == true %}
|
{% if options['has_no_address'] == true and address.isNoAddress == true %}
|
||||||
{% if address.postCode is not empty %}
|
{% if address.postCode is not empty %}
|
||||||
<div class="address{% if options['multiline'] %} multiline{% endif %}{% if options['with_delimiter'] %} delimiter{% endif %}">
|
<div class="address{% if options['multiline'] %} multiline{% endif %}{% if options['with_delimiter'] %} delimiter{% endif %}">
|
||||||
|
@ -45,13 +45,15 @@ class SearchUserApiProvider implements SearchApiInterface
|
|||||||
$query
|
$query
|
||||||
->setSelectKey('user')
|
->setSelectKey('user')
|
||||||
->setSelectJsonbMetadata("jsonb_build_object('id', u.id)")
|
->setSelectJsonbMetadata("jsonb_build_object('id', u.id)")
|
||||||
->setSelectPertinence('GREATEST(SIMILARITY(LOWER(UNACCENT(?)), u.usernamecanonical),
|
->setSelectPertinence('GREATEST(SIMILARITY(LOWER(UNACCENT(?)), u.label),
|
||||||
SIMILARITY(LOWER(UNACCENT(?)), u.emailcanonical))', [$pattern, $pattern])
|
SIMILARITY(LOWER(UNACCENT(?)), u.usernamecanonical))', [$pattern, $pattern])
|
||||||
->setFromClause('users AS u')
|
->setFromClause('users AS u')
|
||||||
->setWhereClauses('SIMILARITY(LOWER(UNACCENT(?)), u.usernamecanonical) > 0.15
|
->setWhereClauses('
|
||||||
OR
|
SIMILARITY(LOWER(UNACCENT(?)), u.usernamecanonical) > 0.15
|
||||||
SIMILARITY(LOWER(UNACCENT(?)), u.emailcanonical) > 0.15
|
OR u.usernamecanonical LIKE \'%\' || LOWER(UNACCENT(?)) || \'%\'
|
||||||
', [$pattern, $pattern]);
|
OR SIMILARITY(LOWER(UNACCENT(?)), LOWER(UNACCENT(u.label))) > 0.15
|
||||||
|
OR u.label LIKE \'%\' || LOWER(UNACCENT(?)) || \'%\'
|
||||||
|
', [$pattern, $pattern, $pattern, $pattern]);
|
||||||
|
|
||||||
return $query;
|
return $query;
|
||||||
}
|
}
|
||||||
|
@ -45,6 +45,7 @@ class AddressNormalizer implements ContextAwareNormalizerInterface, NormalizerAw
|
|||||||
'extra',
|
'extra',
|
||||||
'validFrom' => DateTimeInterface::class,
|
'validFrom' => DateTimeInterface::class,
|
||||||
'validTo' => DateTimeInterface::class,
|
'validTo' => DateTimeInterface::class,
|
||||||
|
'confidential',
|
||||||
];
|
];
|
||||||
|
|
||||||
private AddressRender $addressRender;
|
private AddressRender $addressRender;
|
||||||
@ -83,6 +84,7 @@ class AddressNormalizer implements ContextAwareNormalizerInterface, NormalizerAw
|
|||||||
'buildingName' => $address->getBuildingName(),
|
'buildingName' => $address->getBuildingName(),
|
||||||
'distribution' => $address->getDistribution(),
|
'distribution' => $address->getDistribution(),
|
||||||
'extra' => $address->getExtra(),
|
'extra' => $address->getExtra(),
|
||||||
|
'confidential' => $address->getConfidential(),
|
||||||
'lines' => $this->addressRender->renderLines($address),
|
'lines' => $this->addressRender->renderLines($address),
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -55,7 +55,7 @@ class CommentEmbeddableDocGenNormalizer implements ContextAwareNormalizerInterfa
|
|||||||
$user = $this->userRepository->find($object->getUserId());
|
$user = $this->userRepository->find($object->getUserId());
|
||||||
|
|
||||||
return [
|
return [
|
||||||
'comment' => (string) $object->getComment(),
|
'comment' => $object->getComment(),
|
||||||
'isNull' => false,
|
'isNull' => false,
|
||||||
'date' => $this->normalizer->normalize($object->getDate(), $format, array_merge($context, [
|
'date' => $this->normalizer->normalize($object->getDate(), $format, array_merge($context, [
|
||||||
'docgen:expects' => DateTime::class,
|
'docgen:expects' => DateTime::class,
|
||||||
|
@ -44,7 +44,9 @@ use function count;
|
|||||||
final class ExportManagerTest extends KernelTestCase
|
final class ExportManagerTest extends KernelTestCase
|
||||||
{
|
{
|
||||||
use PrepareCenterTrait;
|
use PrepareCenterTrait;
|
||||||
|
|
||||||
use PrepareScopeTrait;
|
use PrepareScopeTrait;
|
||||||
|
|
||||||
use PrepareUserTrait;
|
use PrepareUserTrait;
|
||||||
|
|
||||||
private Prophet $prophet;
|
private Prophet $prophet;
|
||||||
|
@ -34,8 +34,11 @@ use function in_array;
|
|||||||
final class AuthorizationHelperTest extends KernelTestCase
|
final class AuthorizationHelperTest extends KernelTestCase
|
||||||
{
|
{
|
||||||
use PrepareCenterTrait;
|
use PrepareCenterTrait;
|
||||||
|
|
||||||
use PrepareScopeTrait;
|
use PrepareScopeTrait;
|
||||||
|
|
||||||
use PrepareUserTrait;
|
use PrepareUserTrait;
|
||||||
|
|
||||||
use ProphecyTrait;
|
use ProphecyTrait;
|
||||||
|
|
||||||
protected function setUp(): void
|
protected function setUp(): void
|
||||||
|
@ -0,0 +1,44 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Chill is a software for social workers
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view
|
||||||
|
* the LICENSE file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Chill\Migrations\Main;
|
||||||
|
|
||||||
|
use Doctrine\DBAL\Schema\Schema;
|
||||||
|
use Doctrine\Migrations\AbstractMigration;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Alter some address fields + add confidential field on Address.
|
||||||
|
*/
|
||||||
|
final class Version20220124085957 extends AbstractMigration
|
||||||
|
{
|
||||||
|
public function down(Schema $schema): void
|
||||||
|
{
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address DROP confidential');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER corridor TYPE VARCHAR(16)');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER flat TYPE VARCHAR(16)');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER floor TYPE VARCHAR(16)');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER steps TYPE VARCHAR(16)');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDescription(): string
|
||||||
|
{
|
||||||
|
return 'Alter some address fields + add confidential field on Address';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function up(Schema $schema): void
|
||||||
|
{
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ADD confidential BOOLEAN DEFAULT FALSE');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER floor TYPE TEXT');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER corridor TYPE TEXT');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER steps TYPE TEXT');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_address ALTER flat TYPE TEXT');
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Chill is a software for social workers
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view
|
||||||
|
* the LICENSE file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Chill\Migrations\Main;
|
||||||
|
|
||||||
|
use Doctrine\DBAL\Schema\Schema;
|
||||||
|
use Doctrine\Migrations\AbstractMigration;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new entity ResidentialAddress.
|
||||||
|
*/
|
||||||
|
final class Version20220125134253 extends AbstractMigration
|
||||||
|
{
|
||||||
|
public function down(Schema $schema): void
|
||||||
|
{
|
||||||
|
$this->addSql('DROP SEQUENCE chill_main_residential_address_id_seq CASCADE');
|
||||||
|
$this->addSql('DROP TABLE chill_main_residential_address');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDescription(): string
|
||||||
|
{
|
||||||
|
return 'Create a new entity ResidentialAddress';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function up(Schema $schema): void
|
||||||
|
{
|
||||||
|
$this->addSql('CREATE SEQUENCE chill_main_residential_address_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
|
||||||
|
$this->addSql('CREATE TABLE chill_main_residential_address (id INT NOT NULL, person_id INT NOT NULL, address_id INT DEFAULT NULL, startDate TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, endDate TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL, residentialAddressComment_comment TEXT DEFAULT NULL, residentialAddressComment_date TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL, residentialAddressComment_userId INT DEFAULT NULL, hostPerson_id INT DEFAULT NULL, hostThirdParty_id INT DEFAULT NULL, PRIMARY KEY(id))');
|
||||||
|
$this->addSql('CREATE INDEX IDX_9BC1FD50217BBB47 ON chill_main_residential_address (person_id)');
|
||||||
|
$this->addSql('CREATE INDEX IDX_9BC1FD50DCA38092 ON chill_main_residential_address (hostPerson_id)');
|
||||||
|
$this->addSql('CREATE INDEX IDX_9BC1FD508DFC48DC ON chill_main_residential_address (hostThirdParty_id)');
|
||||||
|
$this->addSql('CREATE INDEX IDX_9BC1FD50F5B7AF75 ON chill_main_residential_address (address_id)');
|
||||||
|
$this->addSql('COMMENT ON COLUMN chill_main_residential_address.startDate IS \'(DC2Type:datetime_immutable)\'');
|
||||||
|
$this->addSql('COMMENT ON COLUMN chill_main_residential_address.endDate IS \'(DC2Type:datetime_immutable)\'');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_residential_address ADD CONSTRAINT FK_9BC1FD50217BBB47 FOREIGN KEY (person_id) REFERENCES chill_person_person (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_residential_address ADD CONSTRAINT FK_9BC1FD50DCA38092 FOREIGN KEY (hostPerson_id) REFERENCES chill_person_person (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_residential_address ADD CONSTRAINT FK_9BC1FD508DFC48DC FOREIGN KEY (hostThirdParty_id) REFERENCES chill_3party.third_party (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
|
||||||
|
$this->addSql('ALTER TABLE chill_main_residential_address ADD CONSTRAINT FK_9BC1FD50F5B7AF75 FOREIGN KEY (address_id) REFERENCES chill_main_address (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
|
||||||
|
}
|
||||||
|
}
|
@ -52,6 +52,8 @@ Since %date%: Depuis le %date%
|
|||||||
since %date%: depuis le %date%
|
since %date%: depuis le %date%
|
||||||
Until %date%: Jusqu'au %date%
|
Until %date%: Jusqu'au %date%
|
||||||
until %date%: jusqu'au %date%
|
until %date%: jusqu'au %date%
|
||||||
|
Since: Depuis le
|
||||||
|
Until: Jusqu'au
|
||||||
#elements used in software
|
#elements used in software
|
||||||
centers: centres
|
centers: centres
|
||||||
Centers: Centres
|
Centers: Centres
|
||||||
|
@ -148,8 +148,6 @@ final class PersonResourceController extends AbstractController
|
|||||||
$comment = $form['comment']->getData();
|
$comment = $form['comment']->getData();
|
||||||
$kind = $form['kind']->getData();
|
$kind = $form['kind']->getData();
|
||||||
|
|
||||||
dump($person);
|
|
||||||
|
|
||||||
$personResource->setKind($kind);
|
$personResource->setKind($kind);
|
||||||
$personResource->setPerson($person);
|
$personResource->setPerson($person);
|
||||||
$personResource->setThirdParty($thirdparty);
|
$personResource->setThirdParty($thirdparty);
|
||||||
|
@ -0,0 +1,161 @@
|
|||||||
|
<?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\PersonBundle\Controller;
|
||||||
|
|
||||||
|
use Chill\MainBundle\Entity\ResidentialAddress;
|
||||||
|
use Chill\MainBundle\Form\Type\ResidentialAddressType;
|
||||||
|
use Chill\MainBundle\Repository\ResidentialAddressRepository;
|
||||||
|
use Chill\PersonBundle\Entity\Person;
|
||||||
|
use Chill\PersonBundle\Security\Authorization\PersonVoter;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
|
use Symfony\Component\Form\Extension\Core\Type\FormType;
|
||||||
|
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
|
||||||
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
|
use Symfony\Component\Routing\Annotation\Route;
|
||||||
|
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
|
||||||
|
use Symfony\Contracts\Translation\TranslatorInterface;
|
||||||
|
|
||||||
|
final class ResidentialAddressController extends AbstractController
|
||||||
|
{
|
||||||
|
private UrlGeneratorInterface $generator;
|
||||||
|
|
||||||
|
private ResidentialAddressRepository $residentialAddressRepository;
|
||||||
|
|
||||||
|
private TranslatorInterface $translator;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
UrlGeneratorInterface $generator,
|
||||||
|
TranslatorInterface $translator,
|
||||||
|
ResidentialAddressRepository $residentialAddressRepository
|
||||||
|
) {
|
||||||
|
$this->generator = $generator;
|
||||||
|
$this->translator = $translator;
|
||||||
|
$this->residentialAddressRepository = $residentialAddressRepository;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Route("/{_locale}/person/residential-address/{id}/delete", name="chill_person_residential_address_delete")
|
||||||
|
*/
|
||||||
|
public function deleteAction(Request $request, ResidentialAddress $residentialAddress): Response
|
||||||
|
{
|
||||||
|
$this->denyAccessUnlessGranted(PersonVoter::UPDATE, $residentialAddress->getPerson());
|
||||||
|
|
||||||
|
$form = $this->createForm(FormType::class);
|
||||||
|
$form->add('submit', SubmitType::class, ['label' => 'Delete']);
|
||||||
|
$form->handleRequest($request);
|
||||||
|
|
||||||
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
|
$em = $this->getDoctrine()->getManager();
|
||||||
|
$em->remove($residentialAddress);
|
||||||
|
$em->flush();
|
||||||
|
|
||||||
|
$this->addFlash('success', $this->translator->trans('Residential address had been deleted'));
|
||||||
|
|
||||||
|
return $this->redirectToRoute('chill_person_residential_address_list', ['id' => $residentialAddress->getPerson()->getId()]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->render('@ChillPerson/ResidentialAddress/delete.html.twig', [
|
||||||
|
'person' => $residentialAddress->getPerson(),
|
||||||
|
'residentialAddress' => $residentialAddress,
|
||||||
|
'delete_form' => $form->createView(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Route("/{_locale}/person/residential-address/{id}/edit", name="chill_person_residential_address_edit")
|
||||||
|
*/
|
||||||
|
public function editAction(Request $request, ResidentialAddress $residentialAddress): Response
|
||||||
|
{
|
||||||
|
if ($request->query->has('kind')) {
|
||||||
|
$kind = $request->query->getAlpha('kind', '');
|
||||||
|
} else {
|
||||||
|
$kind = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$person = $residentialAddress->getPerson();
|
||||||
|
$this->denyAccessUnlessGranted(PersonVoter::UPDATE, $person);
|
||||||
|
|
||||||
|
$form = $this->createForm(ResidentialAddressType::class, $residentialAddress, ['kind' => $kind]);
|
||||||
|
$form->handleRequest($request);
|
||||||
|
|
||||||
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
|
$this->getDoctrine()->getManager()->flush();
|
||||||
|
|
||||||
|
$this->addFlash('success', $this->translator
|
||||||
|
->trans('The residential address was updated successfully'));
|
||||||
|
|
||||||
|
return $this->redirect(
|
||||||
|
$request->get('returnPath', null) ??
|
||||||
|
$this->generator->generate('chill_person_residential_address_list', ['id' => $person->getId()])
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->render('@ChillPerson/ResidentialAddress/edit.html.twig', [
|
||||||
|
'residentialAddress' => $residentialAddress,
|
||||||
|
'person' => $person,
|
||||||
|
'form' => $form->createView(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Route("/{_locale}/person/{id}/residential-address/list", name="chill_person_residential_address_list")
|
||||||
|
*/
|
||||||
|
public function listAction(Request $request, Person $person): Response
|
||||||
|
{
|
||||||
|
$this->denyAccessUnlessGranted(PersonVoter::SEE, $person);
|
||||||
|
|
||||||
|
$residentialAddresses = $this->residentialAddressRepository->findBy(['person' => $person], ['startDate' => 'DESC']);
|
||||||
|
|
||||||
|
return $this->render('@ChillPerson/ResidentialAddress/list.html.twig', [
|
||||||
|
'person' => $person,
|
||||||
|
'addresses' => $residentialAddresses,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Route("/{_locale}/person/{id}/residential-address/new", name="chill_person_residential_address_new")
|
||||||
|
*/
|
||||||
|
public function newAction(Request $request, Person $person): Response
|
||||||
|
{
|
||||||
|
$residentialAddress = new ResidentialAddress();
|
||||||
|
$residentialAddress->setPerson($person);
|
||||||
|
|
||||||
|
$this->denyAccessUnlessGranted(PersonVoter::UPDATE, $person);
|
||||||
|
|
||||||
|
if (!$request->query->has('kind')) {
|
||||||
|
return $this->render('@ChillPerson/ResidentialAddress/new_pick_kind.html.twig', ['person' => $person]);
|
||||||
|
}
|
||||||
|
$kind = $request->query->getAlpha('kind', '');
|
||||||
|
|
||||||
|
$form = $this->createForm(ResidentialAddressType::class, $residentialAddress, ['kind' => $kind]);
|
||||||
|
$form->handleRequest($request);
|
||||||
|
|
||||||
|
if ($form->isSubmitted() && $form->isValid()) {
|
||||||
|
$this->getDoctrine()->getManager()->persist($residentialAddress);
|
||||||
|
$this->getDoctrine()->getManager()->flush();
|
||||||
|
|
||||||
|
$this->addFlash('success', $this->translator
|
||||||
|
->trans('The new residential address was created successfully'));
|
||||||
|
|
||||||
|
return $this->redirect(
|
||||||
|
$request->get('returnPath', null) ??
|
||||||
|
$this->generator->generate('chill_person_residential_address_list', ['id' => $residentialAddress->getPerson()->getId()])
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->render('@ChillPerson/ResidentialAddress/new.html.twig', [
|
||||||
|
'person' => $person,
|
||||||
|
'form' => $form->createView(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,50 @@
|
|||||||
|
<?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\PersonBundle\Controller;
|
||||||
|
|
||||||
|
use Chill\MainBundle\Pagination\PaginatorFactory;
|
||||||
|
use Chill\PersonBundle\Repository\AccompanyingPeriodRepository;
|
||||||
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
|
use Symfony\Component\Routing\Annotation\Route;
|
||||||
|
|
||||||
|
class UserAccompanyingPeriodController extends AbstractController
|
||||||
|
{
|
||||||
|
|
||||||
|
private AccompanyingPeriodRepository $accompanyingPeriodRepository;
|
||||||
|
|
||||||
|
private PaginatorFactory $paginatorFactory;
|
||||||
|
|
||||||
|
public function __construct(AccompanyingPeriodRepository $accompanyingPeriodRepository, PaginatorFactory $paginatorFactory)
|
||||||
|
{
|
||||||
|
$this->accompanyingPeriodRepository = $accompanyingPeriodRepository;
|
||||||
|
$this->paginatorFactory = $paginatorFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Route("/{_locale}/accompanying-periods", name="chill_person_accompanying_period_user")
|
||||||
|
*/
|
||||||
|
public function listAction(Request $request)
|
||||||
|
{
|
||||||
|
$total = $this->accompanyingPeriodRepository->countBy(['user' => $this->getUser()]);
|
||||||
|
$pagination = $this->paginatorFactory->create($total);
|
||||||
|
$accompanyingPeriods = $this->accompanyingPeriodRepository->findBy(['user' => $this->getUser()],
|
||||||
|
['openingDate' => 'DESC'], $pagination->getItemsPerPage(), $pagination->getCurrentPageFirstItemNumber());
|
||||||
|
|
||||||
|
return $this->render('@ChillPerson/AccompanyingPeriod/user_periods_list.html.twig', [
|
||||||
|
'accompanyingPeriods' => $accompanyingPeriods,
|
||||||
|
'pagination' => $pagination,
|
||||||
|
]);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -33,6 +33,7 @@ use Symfony\Component\Validator\Constraints as Assert;
|
|||||||
class HouseholdComposition implements TrackCreationInterface, TrackUpdateInterface
|
class HouseholdComposition implements TrackCreationInterface, TrackUpdateInterface
|
||||||
{
|
{
|
||||||
use TrackCreationTrait;
|
use TrackCreationTrait;
|
||||||
|
|
||||||
use TrackUpdateTrait;
|
use TrackUpdateTrait;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -784,12 +784,18 @@ class Person implements HasCenterInterface, TrackCreationInterface, TrackUpdateI
|
|||||||
* If the `$at` parameter is now, use the method `getCurrentPersonAddress`, which is optimized
|
* If the `$at` parameter is now, use the method `getCurrentPersonAddress`, which is optimized
|
||||||
* on database side.
|
* on database side.
|
||||||
*
|
*
|
||||||
|
* @deprecated since chill2.0, address is linked to the household. Use @see{Person::getCurrentHouseholdAddress}
|
||||||
|
*
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public function getAddressAt(?DateTime $at = null): ?Address
|
public function getAddressAt(?DateTimeInterface $at = null): ?Address
|
||||||
{
|
{
|
||||||
$at ??= new DateTime('now');
|
$at ??= new DateTime('now');
|
||||||
|
|
||||||
|
if ($at instanceof DateTimeImmutable) {
|
||||||
|
$at = DateTime::createFromImmutable($at);
|
||||||
|
}
|
||||||
|
|
||||||
/** @var ArrayIterator $addressesIterator */
|
/** @var ArrayIterator $addressesIterator */
|
||||||
$addressesIterator = $this->getAddresses()
|
$addressesIterator = $this->getAddresses()
|
||||||
->filter(static fn (Address $address): bool => $address->getValidFrom() <= $at)
|
->filter(static fn (Address $address): bool => $address->getValidFrom() <= $at)
|
||||||
@ -950,6 +956,12 @@ class Person implements HasCenterInterface, TrackCreationInterface, TrackUpdateI
|
|||||||
: null;
|
: null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the household address at the given date.
|
||||||
|
*
|
||||||
|
* if the given date is 'now', use instead @see{getCurrentPersonAddress}, which is optimized on
|
||||||
|
* database side.
|
||||||
|
*/
|
||||||
public function getCurrentHouseholdAddress(?DateTimeImmutable $at = null): ?Address
|
public function getCurrentHouseholdAddress(?DateTimeImmutable $at = null): ?Address
|
||||||
{
|
{
|
||||||
if (
|
if (
|
||||||
|
@ -34,6 +34,7 @@ use Symfony\Component\Validator\Context\ExecutionContextInterface;
|
|||||||
class PersonResource implements TrackCreationInterface, TrackUpdateInterface
|
class PersonResource implements TrackCreationInterface, TrackUpdateInterface
|
||||||
{
|
{
|
||||||
use TrackCreationTrait;
|
use TrackCreationTrait;
|
||||||
|
|
||||||
use TrackUpdateTrait;
|
use TrackUpdateTrait;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -62,6 +62,16 @@ class PersonMenuBuilder implements LocalMenuBuilderInterface
|
|||||||
'order' => 50,
|
'order' => 50,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
$menu->addChild($this->translator->trans('Residential addresses'), [
|
||||||
|
'route' => 'chill_person_residential_address_list',
|
||||||
|
'routeParameters' => [
|
||||||
|
'id' => $parameters['person']->getId(),
|
||||||
|
],
|
||||||
|
])
|
||||||
|
->setExtras([
|
||||||
|
'order' => 60,
|
||||||
|
]);
|
||||||
|
|
||||||
$menu->addChild($this->translator->trans('household.person history'), [
|
$menu->addChild($this->translator->trans('household.person history'), [
|
||||||
'route' => 'chill_person_household_person_history',
|
'route' => 'chill_person_household_person_history',
|
||||||
'routeParameters' => [
|
'routeParameters' => [
|
||||||
|
57
src/Bundle/ChillPersonBundle/Menu/UserMenuBuilder.php
Normal file
57
src/Bundle/ChillPersonBundle/Menu/UserMenuBuilder.php
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
<?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\PersonBundle\Menu;
|
||||||
|
|
||||||
|
use Chill\MainBundle\Routing\LocalMenuBuilderInterface;
|
||||||
|
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;
|
||||||
|
|
||||||
|
class UserMenuBuilder implements LocalMenuBuilderInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var AuthorizationCheckerInterface
|
||||||
|
*/
|
||||||
|
public $authorizationChecker;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var TranslatorInterface
|
||||||
|
*/
|
||||||
|
public $translator;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
AuthorizationCheckerInterface $authorizationChecker
|
||||||
|
) {
|
||||||
|
$this->authorizationChecker = $authorizationChecker;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function buildMenu($menuId, MenuItem $menu, array $parameters)
|
||||||
|
{
|
||||||
|
if ($this->authorizationChecker->isGranted('ROLE_USER')) {
|
||||||
|
$menu->addChild('My accompanying periods', [
|
||||||
|
'route' => 'chill_person_accompanying_period_user',
|
||||||
|
])
|
||||||
|
->setExtras([
|
||||||
|
'order' => 20,
|
||||||
|
'icon' => 'tasks',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function getMenuIds(): array
|
||||||
|
{
|
||||||
|
return ['user'];
|
||||||
|
}
|
||||||
|
}
|
@ -49,6 +49,11 @@ final class AccompanyingPeriodRepository implements ObjectRepository
|
|||||||
return $this->repository->findBy($criteria, $orderBy, $limit, $offset);
|
return $this->repository->findBy($criteria, $orderBy, $limit, $offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function countBy(array $criteria): int
|
||||||
|
{
|
||||||
|
return $this->repository->count($criteria);
|
||||||
|
}
|
||||||
|
|
||||||
public function findOneBy(array $criteria): ?AccompanyingPeriod
|
public function findOneBy(array $criteria): ?AccompanyingPeriod
|
||||||
{
|
{
|
||||||
return $this->findOneBy($criteria);
|
return $this->findOneBy($criteria);
|
||||||
|
@ -2,25 +2,44 @@ import {createApp} from 'vue';
|
|||||||
import SetReferrer from 'ChillPersonAssets/vuejs/_components/AccompanyingPeriod/SetReferrer.vue';
|
import SetReferrer from 'ChillPersonAssets/vuejs/_components/AccompanyingPeriod/SetReferrer.vue';
|
||||||
import {fetchResults} from 'ChillMainAssets/lib/api/apiMethods.js';
|
import {fetchResults} from 'ChillMainAssets/lib/api/apiMethods.js';
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* To start this app, add this container into recordAction passed as argument to
|
||||||
|
* `ChillPerson/AccompanyingPeriod/_list_item.html.twig`:
|
||||||
|
*
|
||||||
|
* ```html+twig
|
||||||
|
* {% if is_granted('CHILL_PERSON_ACCOMPANYING_PERIOD_UPDATE', period) %}
|
||||||
|
* <li>
|
||||||
|
* <span data-set-referrer-app="data-set-referrer-app" data-set-referrer-accompanying-period-id="{{ period.id }}"></span>
|
||||||
|
* </li>
|
||||||
|
* {% endif %}
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* The app will update the referrer displayed into dedicated span
|
||||||
|
*/
|
||||||
|
|
||||||
document.querySelectorAll('[data-set-referrer-app]').forEach(function (el) {
|
document.querySelectorAll('[data-set-referrer-app]').forEach(function (el) {
|
||||||
let
|
let
|
||||||
periodId = Number.parseInt(el.dataset.setReferrerAccompanyingPeriodId);
|
periodId = Number.parseInt(el.dataset.setReferrerAccompanyingPeriodId);
|
||||||
|
|
||||||
const url = `/api/1.0/person/accompanying-course/${periodId}/referrers-suggested.json`;
|
const url = `/api/1.0/person/accompanying-course/${periodId}/referrers-suggested.json`;
|
||||||
|
|
||||||
fetchResults(url).then(suggested => {
|
fetchResults(url).then(suggested => {
|
||||||
|
|
||||||
const app = createApp({
|
const app = createApp({
|
||||||
components: {
|
components: {
|
||||||
SetReferrer,
|
SetReferrer,
|
||||||
},
|
},
|
||||||
template:
|
template:
|
||||||
'<set-referrer :suggested="this.suggested" :periodId="periodId" @referrerSet="onReferrerSet"></set-referrer>',
|
'<set-referrer :suggested="suggested" :periodId="periodId" @referrerSet="onReferrerSet"></set-referrer>',
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
suggested, periodId,
|
periodId, suggested, original: suggested,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
onReferrerSet(ref) {
|
onReferrerSet(ref) {
|
||||||
|
|
||||||
const bloc = document.querySelector(`[data-accompanying-period-id="${this.periodId}"]`);
|
const bloc = document.querySelector(`[data-accompanying-period-id="${this.periodId}"]`);
|
||||||
if (bloc === null) {
|
if (bloc === null) {
|
||||||
console.error('bloc not found');
|
console.error('bloc not found');
|
||||||
@ -37,6 +56,7 @@ document.querySelectorAll('[data-set-referrer-app]').forEach(function (el) {
|
|||||||
label.textContent = ref.text;
|
label.textContent = ref.text;
|
||||||
label.classList.remove('chill-no-data-statement');
|
label.classList.remove('chill-no-data-statement');
|
||||||
|
|
||||||
|
this.suggested = this.original.filter(user => user.id !== ref.id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
export const lightGreen = '#43b29d';
|
||||||
|
export const darkGreen = '#368e7e';
|
||||||
|
export const lightBrown = '#a2ac80';
|
||||||
|
export const darkBrown = '#929d69';
|
||||||
|
export const lightBlue = '#8d9dab';
|
||||||
|
export const darkBlue = '#718596';
|
@ -2,6 +2,7 @@ import { createStore } from 'vuex'
|
|||||||
import { getHouseholdByPerson, getCoursesByPerson, getRelationshipsByPerson } from './api'
|
import { getHouseholdByPerson, getCoursesByPerson, getRelationshipsByPerson } from './api'
|
||||||
import { getHouseholdLabel, getHouseholdWidth, getRelationshipLabel, getRelationshipTitle, getRelationshipDirection, splitId, getGender, getAge } from './vis-network'
|
import { getHouseholdLabel, getHouseholdWidth, getRelationshipLabel, getRelationshipTitle, getRelationshipDirection, splitId, getGender, getAge } from './vis-network'
|
||||||
import {visMessages} from "./i18n";
|
import {visMessages} from "./i18n";
|
||||||
|
import { darkBlue, darkBrown, darkGreen, lightBlue, lightBrown, lightGreen } from './colors';
|
||||||
|
|
||||||
const debug = process.env.NODE_ENV !== 'production'
|
const debug = process.env.NODE_ENV !== 'production'
|
||||||
|
|
||||||
@ -172,8 +173,8 @@ const store = createStore({
|
|||||||
id: 'relationship_' + splitId(link.id,'id')
|
id: 'relationship_' + splitId(link.id,'id')
|
||||||
+ '-person_' + link.fromPerson.id + '-person_' + link.toPerson.id,
|
+ '-person_' + link.fromPerson.id + '-person_' + link.toPerson.id,
|
||||||
arrows: getRelationshipDirection(link),
|
arrows: getRelationshipDirection(link),
|
||||||
color: 'lightblue',
|
color: lightGreen,
|
||||||
font: { color: '#33839d' },
|
font: { color: darkGreen },
|
||||||
dashes: true,
|
dashes: true,
|
||||||
label: getRelationshipLabel(link),
|
label: getRelationshipLabel(link),
|
||||||
title: getRelationshipTitle(link),
|
title: getRelationshipTitle(link),
|
||||||
@ -316,10 +317,10 @@ const store = createStore({
|
|||||||
to: `${household.id}`,
|
to: `${household.id}`,
|
||||||
id: `${household.id}-person_${m.person.id}`,
|
id: `${household.id}-person_${m.person.id}`,
|
||||||
arrows: 'from',
|
arrows: 'from',
|
||||||
color: 'pink',
|
color: lightBrown,
|
||||||
font: { color: '#D04A60' },
|
font: { color: darkBrown },
|
||||||
dashes: (getHouseholdWidth(m) === 1)? [0,4] : false, //edge style: [dash, gap, dash, gap]
|
dashes: (getHouseholdWidth(m) === 1)? [0,4] : false, //edge style: [dash, gap, dash, gap]
|
||||||
label: getHouseholdLabel(m),
|
//label: getHouseholdLabel(m),
|
||||||
width: getHouseholdWidth(m),
|
width: getHouseholdWidth(m),
|
||||||
})
|
})
|
||||||
if (!getters.isPersonLoaded(m.person.id)) {
|
if (!getters.isPersonLoaded(m.person.id)) {
|
||||||
@ -375,8 +376,8 @@ const store = createStore({
|
|||||||
to: `${course.id}`,
|
to: `${course.id}`,
|
||||||
id: `accompanying_period_${splitId(course.id,'id')}-person_${p.person.id}`,
|
id: `accompanying_period_${splitId(course.id,'id')}-person_${p.person.id}`,
|
||||||
arrows: 'from',
|
arrows: 'from',
|
||||||
color: 'orange',
|
color: lightBlue,
|
||||||
font: { color: 'darkorange' },
|
font: { color: darkBlue },
|
||||||
})
|
})
|
||||||
if (!getters.isPersonLoaded(p.person.id)) {
|
if (!getters.isPersonLoaded(p.person.id)) {
|
||||||
dispatch('addMissingPerson', [p.person, course])
|
dispatch('addMissingPerson', [p.person, course])
|
||||||
@ -428,8 +429,8 @@ const store = createStore({
|
|||||||
id: 'relationship_' + splitId(relationship.id,'id')
|
id: 'relationship_' + splitId(relationship.id,'id')
|
||||||
+ '-person_' + relationship.fromPerson.id + '-person_' + relationship.toPerson.id,
|
+ '-person_' + relationship.fromPerson.id + '-person_' + relationship.toPerson.id,
|
||||||
arrows: getRelationshipDirection(relationship),
|
arrows: getRelationshipDirection(relationship),
|
||||||
color: 'lightblue',
|
color: lightGreen,
|
||||||
font: { color: '#33839d' },
|
font: { color: darkGreen },
|
||||||
dashes: true,
|
dashes: true,
|
||||||
label: getRelationshipLabel(relationship),
|
label: getRelationshipLabel(relationship),
|
||||||
title: getRelationshipTitle(relationship),
|
title: getRelationshipTitle(relationship),
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import { visMessages } from './i18n'
|
import { darkGreen, lightBlue, lightBrown, lightGreen } from './colors';
|
||||||
|
import { visMessages } from './i18n';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Vis-network initial data/configuration script
|
* Vis-network initial data/configuration script
|
||||||
@ -15,12 +16,12 @@ window.options = {
|
|||||||
/*
|
/*
|
||||||
*/
|
*/
|
||||||
configure: {
|
configure: {
|
||||||
enabled: true,
|
enabled: false,
|
||||||
filter: 'physics',
|
filter: 'physics',
|
||||||
showButton: true
|
showButton: true
|
||||||
},
|
},
|
||||||
physics: {
|
physics: {
|
||||||
enabled: true,
|
enabled: false,
|
||||||
barnesHut: {
|
barnesHut: {
|
||||||
theta: 0.5,
|
theta: 0.5,
|
||||||
gravitationalConstant: -2000,
|
gravitationalConstant: -2000,
|
||||||
@ -89,7 +90,7 @@ window.options = {
|
|||||||
edges: {
|
edges: {
|
||||||
font: {
|
font: {
|
||||||
color: '#b0b0b0',
|
color: '#b0b0b0',
|
||||||
size: 9,
|
size: 14,
|
||||||
face: 'arial',
|
face: 'arial',
|
||||||
background: 'none',
|
background: 'none',
|
||||||
strokeWidth: 2, // px
|
strokeWidth: 2, // px
|
||||||
@ -112,30 +113,30 @@ window.options = {
|
|||||||
},
|
},
|
||||||
color: {
|
color: {
|
||||||
border: '#b0b0b0',
|
border: '#b0b0b0',
|
||||||
background: 'rgb(193,229,222)',
|
background: lightGreen,
|
||||||
highlight: {
|
highlight: {
|
||||||
border: '#89c9a9',
|
border: '#216458',
|
||||||
background: 'rgb(156,213,203)'
|
background: darkGreen,
|
||||||
},
|
},
|
||||||
hover: {
|
hover: {
|
||||||
border: '#89c9a9',
|
border: '#216458',
|
||||||
background: 'rgb(156,213,203)'
|
background: darkGreen,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
opacity: 0.85,
|
opacity: 0.9,
|
||||||
shadow:{
|
shadow:{
|
||||||
enabled: true,
|
enabled: true,
|
||||||
color: 'rgba(0,0,0,0.5)',
|
color: 'rgba(0,0,0,0.5)',
|
||||||
size:10,
|
size:10,
|
||||||
x:5,
|
x:5,
|
||||||
y:5
|
y:5,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
household: {
|
household: {
|
||||||
color: 'pink'
|
color: lightBrown,
|
||||||
},
|
},
|
||||||
accompanying_period: {
|
accompanying_period: {
|
||||||
color: 'orange',
|
color: lightBlue,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<ul class="list-suggest add-items" v-if="this.suggested.length > 0">
|
<ul class="list-suggest add-items" v-if="suggested.length > 0">
|
||||||
<li v-for="r in this.suggested" @click="setReferrer(r)"><span>{{ r.text }}</span></li>
|
<li v-for="r in suggested" @click="setReferrer(r)"><span>{{ r.text }}</span></li>
|
||||||
</ul>
|
</ul>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -14,13 +14,20 @@ export default {
|
|||||||
suggested: {
|
suggested: {
|
||||||
type: Array,
|
type: Array,
|
||||||
required: false,
|
required: false,
|
||||||
default: [],
|
//default: [],
|
||||||
},
|
},
|
||||||
periodId: {
|
periodId: {
|
||||||
type: Number,
|
type: Number,
|
||||||
required: true
|
required: true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
/*suggested: [
|
||||||
|
{id: 5, text: 'Robert'}, {id: 8, text: 'Monique'},
|
||||||
|
]*/
|
||||||
|
}
|
||||||
|
},
|
||||||
emits: ['referrerSet'],
|
emits: ['referrerSet'],
|
||||||
methods: {
|
methods: {
|
||||||
setReferrer: function(ref) {
|
setReferrer: function(ref) {
|
||||||
|
@ -151,14 +151,14 @@
|
|||||||
{% if accompanyingCourse.requestorPerson is not null %}
|
{% if accompanyingCourse.requestorPerson is not null %}
|
||||||
<h4 class="item-key">{{ 'Requestor'|trans }}</h4>
|
<h4 class="item-key">{{ 'Requestor'|trans }}</h4>
|
||||||
{% if accompanyingCourse.requestorAnonymous %}
|
{% if accompanyingCourse.requestorAnonymous %}
|
||||||
<div class="confidential"><p class="blur">{{ _self.insert_onthefly('person', accompanyingCourse.requestorPerson) }}</p></div>
|
<div class="confidential"><p>{{ _self.insert_onthefly('person', accompanyingCourse.requestorPerson) }}</p></div>
|
||||||
{% else %}
|
{% else %}
|
||||||
{{ _self.insert_onthefly('person', accompanyingCourse.requestorPerson) }}
|
{{ _self.insert_onthefly('person', accompanyingCourse.requestorPerson) }}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% elseif accompanyingCourse.requestorThirdParty is not null %}
|
{% elseif accompanyingCourse.requestorThirdParty is not null %}
|
||||||
<h4 class="item-key">{{ 'Requestor'|trans }}</h4>
|
<h4 class="item-key">{{ 'Requestor'|trans }}</h4>
|
||||||
{% if accompanyingCourse.requestorAnonymous %}
|
{% if accompanyingCourse.requestorAnonymous %}
|
||||||
<div class="confidential"><p class="blur">{{ _self.insert_onthefly('thirdparty', accompanyingCourse.requestorThirdParty) }}</p></div>
|
<div class="confidential"><p>{{ _self.insert_onthefly('thirdparty', accompanyingCourse.requestorThirdParty) }}</p></div>
|
||||||
{% else %}
|
{% else %}
|
||||||
{{ _self.insert_onthefly('thirdparty', accompanyingCourse.requestorThirdParty) }}
|
{{ _self.insert_onthefly('thirdparty', accompanyingCourse.requestorThirdParty) }}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<div class="item-bloc accompanying-period-item{% if itemBlocClass is defined %} {{ itemBlocClass }}{% endif %}" {% if itemAttrs is defined %}{{ itemAttrs }}{% endif %}>
|
<div class="item-bloc accompanying-period-item{% if itemBlocClass is defined %} {{ itemBlocClass|raw }}{% endif %}" data-accompanying-period-id="{{ period.id|e('html_attr') }}">
|
||||||
<div class="item-row">
|
<div class="item-row">
|
||||||
<div class="wrap-header">
|
<div class="wrap-header">
|
||||||
<div class="wh-row">
|
<div class="wh-row">
|
||||||
@ -43,6 +43,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="wh-col">
|
<div class="wh-col">
|
||||||
{% if chill_accompanying_periods.fields.user == 'visible' %}
|
{% if chill_accompanying_periods.fields.user == 'visible' %}
|
||||||
|
{# the tags `data-referrer-text` is used by module `@ChillPerson/mod/AccompanyingPeriod/setReferrer.js` #}
|
||||||
{% if period.user %}
|
{% if period.user %}
|
||||||
<abbr class="referrer" title="{{ 'Referrer'|trans }}">{{ 'Referrer'|trans }}:</abbr>
|
<abbr class="referrer" title="{{ 'Referrer'|trans }}">{{ 'Referrer'|trans }}:</abbr>
|
||||||
<span data-referrer-text="data-referrer-text">{{ period.user|chill_entity_render_box }}</span>
|
<span data-referrer-text="data-referrer-text">{{ period.user|chill_entity_render_box }}</span>
|
||||||
|
@ -0,0 +1,30 @@
|
|||||||
|
{% extends "@ChillMain/layout.html.twig" %}
|
||||||
|
|
||||||
|
{% set activeRouteKey = 'chill_person_accompanying_period_user_list' %}
|
||||||
|
|
||||||
|
{% block title %}{{ 'My accompanying periods'|trans }}{% endblock title %}
|
||||||
|
|
||||||
|
{% macro recordAction(period) %}
|
||||||
|
<li>
|
||||||
|
<a href="{{ path('chill_person_accompanying_course_index', { 'accompanying_period_id': period.id }) }}"
|
||||||
|
class="btn btn-show" title="{{ 'See accompanying period'|trans }}"></a>
|
||||||
|
</li>
|
||||||
|
{% endmacro %}
|
||||||
|
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
|
||||||
|
<div class="col-md-10">
|
||||||
|
<h1>{{ 'My accompanying periods'|trans }}</h1>
|
||||||
|
|
||||||
|
<div class="flex-table accompanyingcourse-list">
|
||||||
|
{% for period in accompanyingPeriods %}
|
||||||
|
{% include '@ChillPerson/AccompanyingPeriod/_list_item.html.twig' with {'period': period, 'recordAction': _self.recordAction(period)} %}
|
||||||
|
{% endfor %}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{{ chill_pagination(pagination) }}
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{% endblock %}
|
@ -78,16 +78,11 @@
|
|||||||
{% set app = person.findParticipationForPeriod(acp) %}
|
{% set app = person.findParticipationForPeriod(acp) %}
|
||||||
<div class="item-row separator">
|
<div class="item-row separator">
|
||||||
<div class="wrap-list periods-list">
|
<div class="wrap-list periods-list">
|
||||||
|
|
||||||
|
|
||||||
<div class="wl-row">
|
<div class="wl-row">
|
||||||
<div class="wl-col title">
|
<div class="wl-col title">
|
||||||
<h3 class="courseid mb-2">
|
<h3 class="courseid mb-2">
|
||||||
<a href="{{ path('chill_person_accompanying_course_index', { 'accompanying_period_id': acp.id }) }}"
|
|
||||||
title="{{ 'See accompanying period'|trans }}" class="btn btn-outline-primary">
|
|
||||||
<i class="fa fa-random fa-fw"></i>
|
<i class="fa fa-random fa-fw"></i>
|
||||||
{{ 'File number'|trans }} {{ acp.id }}
|
{{ 'File number'|trans }} {{ acp.id }}
|
||||||
</a>
|
|
||||||
</h3>
|
</h3>
|
||||||
</div>
|
</div>
|
||||||
<div class="wl-col list">
|
<div class="wl-col list">
|
||||||
@ -104,6 +99,11 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
<div class="ms-auto">
|
<div class="ms-auto">
|
||||||
|
{% if acp.requestorPerson == person %}
|
||||||
|
<span class="as-requestor badge bg-info" title="{{ 'Requestor'|trans|e('html_attr') }}">
|
||||||
|
{{ 'Requestor'|trans({'gender': person.gender}) }}
|
||||||
|
</span>
|
||||||
|
{% endif %}
|
||||||
{% if acp.emergency %}
|
{% if acp.emergency %}
|
||||||
<span class="badge rounded-pill bg-danger">{{- 'Emergency'|trans|upper -}}</span>
|
<span class="badge rounded-pill bg-danger">{{- 'Emergency'|trans|upper -}}</span>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@ -115,6 +115,10 @@
|
|||||||
{% if acp.step == 'DRAFT' %}
|
{% if acp.step == 'DRAFT' %}
|
||||||
<span class="badge bg-secondary" style="font-size: 85%;" title="{{ 'course.draft'|trans }}">{{ 'course.draft'|trans }}</span>
|
<span class="badge bg-secondary" style="font-size: 85%;" title="{{ 'course.draft'|trans }}">{{ 'course.draft'|trans }}</span>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
|
{% if acp.step == 'CLOSED' %}
|
||||||
|
<span class="badge bg-secondary" style="font-size: 85%;" title="{{ 'course.closed'|trans }}">{{ 'course.closed'|trans }}</span>
|
||||||
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -145,23 +149,6 @@
|
|||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{# ????
|
|
||||||
{% if acp.requestorPerson == person %}
|
|
||||||
<div class="wl-row">
|
|
||||||
<div class="wl-col title">
|
|
||||||
<h3>
|
|
||||||
|
|
||||||
</h3>
|
|
||||||
</div>
|
|
||||||
<div class="wl-col list">
|
|
||||||
<span class="as-requestor badge bg-info" title="{{ 'Requestor'|trans|e('html_attr') }}">
|
|
||||||
{{ 'Requestor'|trans({'gender': person.gender}) }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{% endif %}
|
|
||||||
#}
|
|
||||||
|
|
||||||
{% if acp.currentParticipations|length > 1 %}
|
{% if acp.currentParticipations|length > 1 %}
|
||||||
<div class="wl-row">
|
<div class="wl-row">
|
||||||
<div class="wl-col title">
|
<div class="wl-col title">
|
||||||
@ -191,6 +178,15 @@
|
|||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
|
<ul class="record_actions record_actions_column">
|
||||||
|
<li>
|
||||||
|
<a href="{{ path('chill_person_accompanying_course_index', { 'accompanying_period_id': acp.id }) }}"
|
||||||
|
class="btn btn-sm btn-outline-primary" title="{{ 'See accompanying period'|trans }}">
|
||||||
|
<i class="fa fa-random fa-fw"></i>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
{% if (acp.requestorPerson is not null and acp.requestorPerson.id != person.id) or acp.requestorThirdParty is not null %}
|
{% if (acp.requestorPerson is not null and acp.requestorPerson.id != person.id) or acp.requestorThirdParty is not null %}
|
||||||
<div class="wl-row">
|
<div class="wl-row">
|
||||||
<div class="wl-col title">
|
<div class="wl-col title">
|
||||||
|
@ -52,9 +52,7 @@
|
|||||||
{% if resource.comment.comment is not empty %}
|
{% if resource.comment.comment is not empty %}
|
||||||
<div class="item-row separator">
|
<div class="item-row separator">
|
||||||
<section class="chill-entity entity-comment-embeddable">
|
<section class="chill-entity entity-comment-embeddable">
|
||||||
<blockquote class="chill-user-quote">
|
<div>{{ resource.comment|chill_entity_render_box }}<div>
|
||||||
<div>{{ resource.comment.comment }}<div>
|
|
||||||
</blockquote>
|
|
||||||
</section>
|
</section>
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -0,0 +1,37 @@
|
|||||||
|
|
||||||
|
|
||||||
|
{{ form_start(form) }}
|
||||||
|
|
||||||
|
{{ form_row(form.startDate) }}
|
||||||
|
{{ form_row(form.endDate) }}
|
||||||
|
|
||||||
|
{% if form.hostPerson is defined %}
|
||||||
|
{{ form_row(form.hostPerson) }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{% if form.hostThirdParty is defined %}
|
||||||
|
{{ form_row(form.hostThirdParty) }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{% if form.address is defined %}
|
||||||
|
{{ form_row(form.address) }}
|
||||||
|
|
||||||
|
{% block js %}
|
||||||
|
{{ encore_entry_script_tags('mod_input_address') }}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block css %}
|
||||||
|
{{ encore_entry_link_tags('mod_input_address') }}
|
||||||
|
{% endblock %}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{{ form_row(form.comment) }}
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="record_actions sticky-form-buttons">
|
||||||
|
<li>
|
||||||
|
<button class="btn btn-update" type="submit">{{ 'Save'|trans }}</button>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
{{ form_end(form) }}
|
@ -0,0 +1,58 @@
|
|||||||
|
{% extends "@ChillPerson/Person/layout.html.twig" %}
|
||||||
|
|
||||||
|
{% set activeRouteKey = '' %}
|
||||||
|
|
||||||
|
{% block title %}{{ 'Delete residential address'|trans }}{% endblock %}
|
||||||
|
|
||||||
|
{% block personcontent %}
|
||||||
|
<div class="address-new">
|
||||||
|
|
||||||
|
<h1>{{ block('title') }}</h1>
|
||||||
|
{% set a = residentialAddress %}
|
||||||
|
<ul class="list-content fa-ul">
|
||||||
|
{% if a.hostPerson is not null %}
|
||||||
|
<li>
|
||||||
|
<i class="fa fa-li fa-home"></i>
|
||||||
|
<span class="item-key">{{ "Address of"|trans}} </span>
|
||||||
|
<span class="chill-entity entity-person badge-person">{{ a.hostPerson|chill_entity_render_box }}</span>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
{% set address_date = date(a.startDate|date("m/d/Y")) %}
|
||||||
|
{% if a.hostPerson.getCurrentHouseholdAddress(a.endDate) is not null %}
|
||||||
|
<i class="fa fa-li fa-map-marker"></i>
|
||||||
|
{{ a.hostPerson.getCurrentHouseholdAddress(a.endDate)|chill_entity_render_box }}
|
||||||
|
{% endif %}
|
||||||
|
</li>
|
||||||
|
{% elseif a.hostThirdParty is not null %}
|
||||||
|
<li>
|
||||||
|
<i class="fa fa-li fa-home"></i>
|
||||||
|
<span class="item-key">{{ "Address of"|trans}}</span>
|
||||||
|
<span class="chill-entity entity-person badge-person">{{ a.hostThirdParty|chill_entity_render_box }}</span>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
{% if a.hostThirdParty.address is not null %}
|
||||||
|
<i class="fa fa-li fa-map-marker"></i>
|
||||||
|
{{ a.hostThirdParty.address|chill_entity_render_box }}
|
||||||
|
{% endif %}
|
||||||
|
</li>
|
||||||
|
{% else %}
|
||||||
|
<li>
|
||||||
|
{% if a.address is not null %}
|
||||||
|
<i class="fa fa-li fa-map-marker"></i>
|
||||||
|
{{ a.address|chill_entity_render_box }}
|
||||||
|
{% endif %}
|
||||||
|
{% endif %}
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
{{ include('@ChillMain/Util/confirmation_template.html.twig',
|
||||||
|
{
|
||||||
|
'title' : 'Delete residential address ?'|trans,
|
||||||
|
'confirm_question' : 'Are you sure you want to remove this residential address for %name% ?'|trans({'%name%': person|chill_entity_render_string }),
|
||||||
|
'cancel_route' : 'chill_person_residential_address_list',
|
||||||
|
'cancel_parameters' : {'id' : person.Id},
|
||||||
|
'form' : delete_form
|
||||||
|
} ) }}
|
||||||
|
|
||||||
|
</div>
|
||||||
|
{% endblock %}
|
@ -0,0 +1,51 @@
|
|||||||
|
{% extends "@ChillPerson/Person/layout.html.twig" %}
|
||||||
|
|
||||||
|
{% set activeRouteKey = '' %}
|
||||||
|
|
||||||
|
{% block title 'Edit a residential address'|trans %}
|
||||||
|
|
||||||
|
{% block personcontent %}
|
||||||
|
<div class="address-edit">
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<h1>{{ block('title') }}</h1>
|
||||||
|
|
||||||
|
{{ form_start(form) }}
|
||||||
|
|
||||||
|
{{ form_row(form.startDate) }}
|
||||||
|
{{ form_row(form.endDate) }}
|
||||||
|
|
||||||
|
{% if residentialAddress.address is not null %}
|
||||||
|
|
||||||
|
{% if form.address is defined %}
|
||||||
|
{{ form_row(form.address) }}
|
||||||
|
|
||||||
|
{% block js %}
|
||||||
|
{{ encore_entry_script_tags('mod_input_address') }}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block css %}
|
||||||
|
{{ encore_entry_link_tags('mod_input_address') }}
|
||||||
|
{% endblock %}
|
||||||
|
{% endif %}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{{ form_row(form.comment) }}
|
||||||
|
|
||||||
|
<ul class="record_actions sticky-form-buttons">
|
||||||
|
<li class="cancel">
|
||||||
|
<a href="{{ chill_path_add_return_path('chill_person_residential_address_list', {'id': person.id}) }}" class="btn btn-cancel">
|
||||||
|
{{ 'Cancel'|trans|chill_return_path_label }}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<button class="btn btn-update" type="submit">{{ 'Save'|trans }}</button>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
{{ form_end(form) }}
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
</div>
|
||||||
|
{% endblock %}
|
@ -0,0 +1,116 @@
|
|||||||
|
{% extends "@ChillPerson/Person/layout.html.twig" %}
|
||||||
|
|
||||||
|
{% set activeRouteKey = '' %}
|
||||||
|
|
||||||
|
{% block title %}{{ 'Residential addresses history for %name%'|trans({ '%name%': person.firstName ~ ' ' ~ person.lastName } ) }}{% endblock %}
|
||||||
|
|
||||||
|
{% block personcontent %}
|
||||||
|
<div class="person-address">
|
||||||
|
|
||||||
|
<h1>{{ 'Residential addresses history'|trans }}</h1>
|
||||||
|
|
||||||
|
{% if is_granted('CHILL_PERSON_SEE', person) %}
|
||||||
|
|
||||||
|
{% if addresses|length == 0 %}
|
||||||
|
<span class="chill-no-data-statement">{{ 'No address given'|trans }}</span>
|
||||||
|
|
||||||
|
{% else %}
|
||||||
|
<div class="flex-table">
|
||||||
|
{% for a in addresses %}
|
||||||
|
|
||||||
|
{% if a.address is not null %}
|
||||||
|
{% set kind = 'address' %}
|
||||||
|
{% else %}
|
||||||
|
{% set kind = null %}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<div class="item-bloc">
|
||||||
|
<div class="item-row">
|
||||||
|
|
||||||
|
<div class="item-col" style="width: 33%;">
|
||||||
|
<ul class="list-unstyled h3">
|
||||||
|
{% if a.endDate is not null %}
|
||||||
|
<li><span class="item-key">{{'Since'|trans}} : </span>{{ a.startDate|format_date('long') }}</li>
|
||||||
|
{% endif %}
|
||||||
|
<li><span class="item-key">{{'Until'|trans}} : </span><b>{{ a.endDate|format_date('long') }}</b></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="item-col flex-column justify-content-start">
|
||||||
|
<div class="float-button top">
|
||||||
|
<div class="box">
|
||||||
|
<div class="action">
|
||||||
|
{% if is_granted('CHILL_PERSON_UPDATE', person) %}
|
||||||
|
<a href="{{ path('chill_person_residential_address_edit', { 'id' : a.id, 'kind' : kind } ) }}" class="btn btn-update" title="{{ 'Update'|trans|e('html_attr') }}"></a>
|
||||||
|
<a href="{{ path('chill_person_residential_address_delete', { 'id' : a.id, 'kind' : kind } ) }}" class="btn btn-delete" title="{{ 'Delete'|trans|e('html_attr') }}"></a>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
<ul class="list-content fa-ul">
|
||||||
|
{% if a.hostPerson is not null %}
|
||||||
|
<li>
|
||||||
|
<i class="fa fa-li fa-home"></i>
|
||||||
|
<span class="item-key">{{ "Address of"|trans}} </span>
|
||||||
|
<span class="chill-entity entity-person badge-person">{{ a.hostPerson|chill_entity_render_box }}</span>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
{% set address_date = date(a.startDate|date("m/d/Y")) %}
|
||||||
|
{% if a.hostPerson.getCurrentHouseholdAddress(a.endDate) is not null %}
|
||||||
|
<i class="fa fa-li fa-map-marker"></i>
|
||||||
|
{{ a.hostPerson.getCurrentHouseholdAddress(a.endDate)|chill_entity_render_box }}
|
||||||
|
{% endif %}
|
||||||
|
</li>
|
||||||
|
{% elseif a.hostThirdParty is not null %}
|
||||||
|
<li>
|
||||||
|
<i class="fa fa-li fa-home"></i>
|
||||||
|
<span class="item-key">{{ "Address of"|trans}}</span>
|
||||||
|
<span class="chill-entity entity-person badge-person">{{ a.hostThirdParty|chill_entity_render_box }}</span>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
{% if a.hostThirdParty.address is not null %}
|
||||||
|
<i class="fa fa-li fa-map-marker"></i>
|
||||||
|
{{ a.hostThirdParty.address|chill_entity_render_box }}
|
||||||
|
{% endif %}
|
||||||
|
</li>
|
||||||
|
{% else %}
|
||||||
|
<li>
|
||||||
|
{% if a.address is not null %}
|
||||||
|
<i class="fa fa-li fa-map-marker"></i>
|
||||||
|
{{ a.address|chill_entity_render_box }}
|
||||||
|
{% endif %}
|
||||||
|
{% endif %}
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<div class="item-row">
|
||||||
|
{% if not a.comment.isEmpty %}
|
||||||
|
{{ a.comment|chill_entity_render_box }}
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{% endfor %}
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<ul class="record_actions sticky-form-buttons">
|
||||||
|
<li class="cancel">
|
||||||
|
<a href="{{ path('chill_person_view', { 'person_id' : person.id } ) }}" class="btn btn-cancel">
|
||||||
|
{{ 'Back to the person details'|trans }}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{% if is_granted('CHILL_PERSON_UPDATE', person) %}
|
||||||
|
<li>
|
||||||
|
<a class="btn btn-create"
|
||||||
|
href="{{ path('chill_person_residential_address_new', { 'id' : person.id } ) }}">
|
||||||
|
{{ 'Add a residential address'|trans }}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
{% endblock %}
|
@ -0,0 +1,29 @@
|
|||||||
|
{% extends "@ChillPerson/Person/layout.html.twig" %}
|
||||||
|
|
||||||
|
{% set activeRouteKey = '' %}
|
||||||
|
|
||||||
|
{% block title %}{{ 'New residential address'|trans }}{% endblock %}
|
||||||
|
|
||||||
|
{% block personcontent %}
|
||||||
|
<div class="address-new">
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<h1>{{ block('title') }}</h1>
|
||||||
|
|
||||||
|
{# TODO #}
|
||||||
|
{% block form %}
|
||||||
|
{% include '@ChillPerson/ResidentialAddress/_form.html.twig' %}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
</div>
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block js %}
|
||||||
|
{{ encore_entry_script_tags('mod_pickentity_type') }}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block css %}
|
||||||
|
{{ encore_entry_link_tags('mod_pickentity_type') }}
|
||||||
|
{% endblock %}
|
@ -0,0 +1,49 @@
|
|||||||
|
{% extends "@ChillMain/layout.html.twig" %}
|
||||||
|
|
||||||
|
{% block title 'Which kind of residential address would you create ?'|trans %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<div class="col-10 centered">
|
||||||
|
<h1>{{ block('title') }}</h1>
|
||||||
|
|
||||||
|
<div class="container" style="margin-top: 2rem;">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-4 mb-4">
|
||||||
|
<a
|
||||||
|
href="{{ chill_path_forward_return_path('chill_person_residential_address_new', {'id': person.id, 'kind': 'person'}) }}"
|
||||||
|
class="btn btn-outline-chill-green-dark">
|
||||||
|
{{ 'The address of another person'|trans }}
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<p>{{ 'residential_address_person_explanation'|trans }}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-4 mb-4">
|
||||||
|
<a
|
||||||
|
href="{{ chill_path_forward_return_path('chill_person_residential_address_new', {'id': person.id, 'kind': 'thirdparty'}) }}"
|
||||||
|
class="btn btn-outline-chill-green-dark">
|
||||||
|
{{ 'The address of a third party'|trans }}
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<p>{{ 'residential_address_third_party_explanation'|trans }}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-4 mb-4">
|
||||||
|
<a
|
||||||
|
href="{{ chill_path_forward_return_path('chill_person_residential_address_new', {'id': person.id, 'kind': 'address'}) }}"
|
||||||
|
class="btn btn-outline-chill-green-dark">
|
||||||
|
{{ 'A new address'|trans }}
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<p>{{ 'residential_address_new_address_explanation'|trans }}</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{% endblock %}
|
@ -29,6 +29,7 @@ use function count;
|
|||||||
class AccompanyingPeriodResourceNormalizer implements DenormalizerAwareInterface, DenormalizerInterface
|
class AccompanyingPeriodResourceNormalizer implements DenormalizerAwareInterface, DenormalizerInterface
|
||||||
{
|
{
|
||||||
use DenormalizerAwareTrait;
|
use DenormalizerAwareTrait;
|
||||||
|
|
||||||
use ObjectToPopulateTrait;
|
use ObjectToPopulateTrait;
|
||||||
|
|
||||||
private ResourceRepository $repository;
|
private ResourceRepository $repository;
|
||||||
|
@ -33,6 +33,7 @@ use function is_array;
|
|||||||
class AccompanyingPeriodWorkDenormalizer implements ContextAwareDenormalizerInterface, DenormalizerAwareInterface
|
class AccompanyingPeriodWorkDenormalizer implements ContextAwareDenormalizerInterface, DenormalizerAwareInterface
|
||||||
{
|
{
|
||||||
use DenormalizerAwareTrait;
|
use DenormalizerAwareTrait;
|
||||||
|
|
||||||
use ObjectToPopulateTrait;
|
use ObjectToPopulateTrait;
|
||||||
|
|
||||||
public const GROUP_CREATE = 'accompanying_period_work:create';
|
public const GROUP_CREATE = 'accompanying_period_work:create';
|
||||||
|
@ -40,7 +40,9 @@ class PersonJsonNormalizer implements
|
|||||||
NormalizerInterface
|
NormalizerInterface
|
||||||
{
|
{
|
||||||
use DenormalizerAwareTrait;
|
use DenormalizerAwareTrait;
|
||||||
|
|
||||||
use NormalizerAwareTrait;
|
use NormalizerAwareTrait;
|
||||||
|
|
||||||
use ObjectToPopulateTrait;
|
use ObjectToPopulateTrait;
|
||||||
|
|
||||||
private CenterResolverManagerInterface $centerResolverManager;
|
private CenterResolverManagerInterface $centerResolverManager;
|
||||||
|
@ -29,7 +29,9 @@ use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface;
|
|||||||
final class PersonVoterTest extends KernelTestCase
|
final class PersonVoterTest extends KernelTestCase
|
||||||
{
|
{
|
||||||
use PrepareCenterTrait;
|
use PrepareCenterTrait;
|
||||||
|
|
||||||
use PrepareScopeTrait;
|
use PrepareScopeTrait;
|
||||||
|
|
||||||
use PrepareUserTrait;
|
use PrepareUserTrait;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -121,7 +121,6 @@ address_postcode_code: Code postal
|
|||||||
address_country_name: Pays
|
address_country_name: Pays
|
||||||
address_country_code: Code pays
|
address_country_code: Code pays
|
||||||
|
|
||||||
|
|
||||||
'Alreay existing person': 'Dossiers déjà encodés'
|
'Alreay existing person': 'Dossiers déjà encodés'
|
||||||
'Add the person': 'Ajouter la personne'
|
'Add the person': 'Ajouter la personne'
|
||||||
'Add the person and create an accompanying period': "Créer la personne & créer une période d'accompagnement"
|
'Add the person and create an accompanying period': "Créer la personne & créer une période d'accompagnement"
|
||||||
@ -243,6 +242,7 @@ Select a thirdparty: "Choisissez un tiers"
|
|||||||
# pickAPersonType
|
# pickAPersonType
|
||||||
Pick a person: Choisir une personne
|
Pick a person: Choisir une personne
|
||||||
|
|
||||||
|
# Address
|
||||||
No address given: Pas d'adresse renseignée
|
No address given: Pas d'adresse renseignée
|
||||||
The address has been successfully updated: L'adresse a été mise à jour avec succès
|
The address has been successfully updated: L'adresse a été mise à jour avec succès
|
||||||
Update address for %name%: Mettre à jour une adresse pour %name%
|
Update address for %name%: Mettre à jour une adresse pour %name%
|
||||||
@ -257,6 +257,31 @@ The new address was created successfully: La nouvelle adresse a été créée
|
|||||||
Add an address: Ajouter une adresse
|
Add an address: Ajouter une adresse
|
||||||
Back to the person details: Retour aux détails de la personne
|
Back to the person details: Retour aux détails de la personne
|
||||||
|
|
||||||
|
# Residential address
|
||||||
|
Residential addresses history for %name%: Historique des adresses de résidence de %name%
|
||||||
|
Residential addresses history: Historique des adresses de résidence
|
||||||
|
Add a residential address: Ajouter une adresse de résidence
|
||||||
|
Which kind of residential address would you create ?: Quel type d'adresse de résidence voulez-vous créer?
|
||||||
|
The address of another person: L'adresse d'une autre personne
|
||||||
|
The address of a third party: L'adresse d'un tiers
|
||||||
|
A new address: Une nouvelle adresse
|
||||||
|
residential_address_person_explanation: L'adresse sera positionnée auprès d'un usager. Lorsque l'usager déménage, l'adresse de résidence suivra également cet usager
|
||||||
|
residential_address_third_party_explanation: L'adresse sera associée à celle d'un tiers.
|
||||||
|
residential_address_new_address_explanation: Créer une nouvelle adresse. L'adresse sera fixe.
|
||||||
|
New residential address: Nouvelle adresse de résidence
|
||||||
|
Host person: Choisir l'adresse d'un usager
|
||||||
|
Host third party: Choisir l'adresse d'un tiers
|
||||||
|
The new residential address was created successfully: La nouvelle adresse de résidence a été créée
|
||||||
|
Edit a residential address: Modifier l'addresse de résidence
|
||||||
|
The residential address was updated successfully: L'adresse de résidence a été mise à jour
|
||||||
|
Residential addresses: Adresses de résidence
|
||||||
|
Address of: Adresse de
|
||||||
|
Delete residential address: Supprimer l'adresse de résidence
|
||||||
|
Delete residential address ?: Supprimer l'adresse de résidence ?
|
||||||
|
Are you sure you want to remove this residential address for %name% ?: Êtes-vous sûr de vouloir supprimer l'adresse de résidence pour %name% ?
|
||||||
|
Residential address had been deleted: L'adresse de résidence a été supprimée
|
||||||
|
|
||||||
|
|
||||||
#timeline
|
#timeline
|
||||||
Timeline: Historique
|
Timeline: Historique
|
||||||
Closing the accompanying period: Fermeture de la période d'accompagnement
|
Closing the accompanying period: Fermeture de la période d'accompagnement
|
||||||
@ -533,3 +558,6 @@ household_composition:
|
|||||||
|
|
||||||
# docgen
|
# docgen
|
||||||
Linked evaluations: Évaluations associées
|
Linked evaluations: Évaluations associées
|
||||||
|
|
||||||
|
# Accompanying period per user
|
||||||
|
My accompanying periods: Mes parcours
|
||||||
|
@ -28,7 +28,9 @@ use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface;
|
|||||||
final class ReportVoterTest extends KernelTestCase
|
final class ReportVoterTest extends KernelTestCase
|
||||||
{
|
{
|
||||||
use PrepareCenterTrait;
|
use PrepareCenterTrait;
|
||||||
|
|
||||||
use PrepareScopeTrait;
|
use PrepareScopeTrait;
|
||||||
|
|
||||||
use PrepareUserTrait;
|
use PrepareUserTrait;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -99,7 +99,7 @@
|
|||||||
<div class="item-col">
|
<div class="item-col">
|
||||||
{% if options['isConfidential'] %}
|
{% if options['isConfidential'] %}
|
||||||
<div class="confidential">
|
<div class="confidential">
|
||||||
<div class="confidential-content blur">
|
<div class="confidential-content">
|
||||||
<ul class="list-content fa-ul">
|
<ul class="list-content fa-ul">
|
||||||
<li>
|
<li>
|
||||||
{{ thirdparty.getAddress|chill_entity_render_box({
|
{{ thirdparty.getAddress|chill_entity_render_box({
|
||||||
|
Loading…
x
Reference in New Issue
Block a user