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'
This commit is contained in:
commit
e21f12d96c
15
CHANGELOG.md
15
CHANGELOG.md
@ -11,11 +11,23 @@ and this project adheres to
|
|||||||
## Unreleased
|
## Unreleased
|
||||||
|
|
||||||
<!-- write down unreleased development here -->
|
<!-- write down unreleased development here -->
|
||||||
|
* [main] change address format in case the country is France, in Address render box and address normalizer
|
||||||
* [person] add validator for accompanying period with a test on social issues (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/76)
|
* [person] add validator for accompanying period with a test on social issues (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/76)
|
||||||
* [activity] fix visibility for location
|
* [activity] fix visibility for location
|
||||||
* [origin] fix origin: use correctly the translatable strings
|
* [origin] fix origin: use correctly the translatable strings
|
||||||
|
|
||||||
* /!\ everyone must update the origin table. As there is only one row, execute `update chill_person_accompanying_period_origin set label = jsonb_build_object('fr', 'appel téléphonique');`
|
* /!\ everyone must update the origin table. As there is only one row, execute `update chill_person_accompanying_period_origin set label = jsonb_build_object('fr', 'appel téléphonique');`
|
||||||
|
* [person] redirect bug fixed.
|
||||||
|
* [action] add an unrelated issue within action creation.
|
||||||
|
* [origin] fix origin: use correctly the translatable strings
|
||||||
|
* /!\ everyone must update the origin table. As there is only one row, execute `update chill_person_accompanying_period_origin set label = jsonb_build_object('fr', 'appel téléphonique');`
|
||||||
|
* [main] change order of civilities in civility fixtures (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/191)
|
||||||
|
* [person] set min attr in the minimum of children field (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/191)
|
||||||
|
* [person] add marital status date in person view (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/191)
|
||||||
|
* [person] show number of children + allow set number of children to null (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/191)
|
||||||
|
* [person] show acceptSMS option (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/191)
|
||||||
|
* [person] add death information in person render box in twig and vue render boxes (https://gitlab.com/champs-libres/departement-de-la-vendee/accent-suivi-developpement/-/issues/191)
|
||||||
|
|
||||||
|
|
||||||
## Test releases
|
## Test releases
|
||||||
|
|
||||||
@ -33,6 +45,9 @@ and this project adheres to
|
|||||||
* [activity] create work if a work with same social action is not associated to the activity
|
* [activity] create work if a work with same social action is not associated to the activity
|
||||||
* [visgraph] improve and fix bugs on vis-network relationship graph
|
* [visgraph] improve and fix bugs on vis-network relationship graph
|
||||||
* [bugfix] posting of birth- and deathdate through api fixed.
|
* [bugfix] posting of birth- and deathdate through api fixed.
|
||||||
|
* [suggestions] improve suggestions lists
|
||||||
|
* [badge-entity] design coherency between badge-person and 3 kinds of badge-thirdparty
|
||||||
|
* [AddPersons] suggestions row are clickable, not only checkbox
|
||||||
|
|
||||||
### Test release 2021-11-19 - bis
|
### Test release 2021-11-19 - bis
|
||||||
|
|
||||||
|
@ -409,3 +409,4 @@ Créer un titre enlevable (avec une croix rouge cliquable, l'ancre a est vide)
|
|||||||
<a></a>
|
<a></a>
|
||||||
</div>
|
</div>
|
||||||
```
|
```
|
||||||
|
Les classes `cols` ou `inline` peuvent être ajoutées à côté de `list-suggest` pour modifier la disposition de la liste.
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
</persons-bloc>
|
</persons-bloc>
|
||||||
</div>
|
</div>
|
||||||
<div v-if="getContext === 'accompanyingCourse' && suggestedEntities.length > 0">
|
<div v-if="getContext === 'accompanyingCourse' && suggestedEntities.length > 0">
|
||||||
<ul class="list-suggest add-items">
|
<ul class="list-suggest add-items inline">
|
||||||
<li v-for="p in suggestedEntities" @click="addSuggestedEntity(p)">
|
<li v-for="p in suggestedEntities" @click="addSuggestedEntity(p)">
|
||||||
<span>{{ p.text }}</span>
|
<span>{{ p.text }}</span>
|
||||||
</li>
|
</li>
|
||||||
|
@ -26,8 +26,8 @@ class LoadCivility extends Fixture implements FixtureGroupInterface
|
|||||||
public function load(ObjectManager $manager): void
|
public function load(ObjectManager $manager): void
|
||||||
{
|
{
|
||||||
$civilities = [
|
$civilities = [
|
||||||
['name' => ['fr' => 'Monsieur'], 'abbrev' => ['fr' => 'M.']],
|
|
||||||
['name' => ['fr' => 'Madame'], 'abbrev' => ['fr' => 'Mme']],
|
['name' => ['fr' => 'Madame'], 'abbrev' => ['fr' => 'Mme']],
|
||||||
|
['name' => ['fr' => 'Monsieur'], 'abbrev' => ['fr' => 'M.']],
|
||||||
['name' => ['fr' => 'Docteur'], 'abbrev' => ['fr' => 'Dr']],
|
['name' => ['fr' => 'Docteur'], 'abbrev' => ['fr' => 'Dr']],
|
||||||
['name' => ['fr' => 'Professeur'], 'abbrev' => ['fr' => 'Pr']],
|
['name' => ['fr' => 'Professeur'], 'abbrev' => ['fr' => 'Pr']],
|
||||||
['name' => ['fr' => 'Madame la Directrice'], 'abbrev' => ['fr' => 'Mme']],
|
['name' => ['fr' => 'Madame la Directrice'], 'abbrev' => ['fr' => 'Mme']],
|
||||||
|
@ -186,7 +186,7 @@ class User implements AdvancedUserInterface
|
|||||||
/**
|
/**
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public function getEmail()
|
public function getEmail(): ?string
|
||||||
{
|
{
|
||||||
return $this->email;
|
return $this->email;
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,15 @@ ul.list-suggest {
|
|||||||
text-align: start;
|
text-align: start;
|
||||||
margin-bottom: 3px;
|
margin-bottom: 3px;
|
||||||
}
|
}
|
||||||
|
&.cols {
|
||||||
|
columns: 3;
|
||||||
|
}
|
||||||
|
&.inline {
|
||||||
|
li {
|
||||||
|
display: inline-block;
|
||||||
|
margin-right: 0.2em;
|
||||||
|
}
|
||||||
|
}
|
||||||
&.add-items {
|
&.add-items {
|
||||||
li {
|
li {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
@ -34,6 +43,9 @@ ul.list-suggest {
|
|||||||
content: "\f067"; // fa-plus
|
content: "\f067"; // fa-plus
|
||||||
color: var(--bs-success);
|
color: var(--bs-success);
|
||||||
}
|
}
|
||||||
|
& span:hover {
|
||||||
|
color: $chill-l-gray;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
&.remove-items {
|
&.remove-items {
|
||||||
|
@ -0,0 +1,42 @@
|
|||||||
|
<template>
|
||||||
|
|
||||||
|
<span v-if="entity.type === 'person'" class="badge rounded-pill bg-person">
|
||||||
|
{{ $t('renderbox.person') }}
|
||||||
|
</span>
|
||||||
|
|
||||||
|
<span v-if="entity.type === 'thirdparty'" class="badge rounded-pill bg-thirdparty">
|
||||||
|
|
||||||
|
<template v-if="options.displayLong !== true">
|
||||||
|
{{ $t('renderbox.type.thirdparty')}}
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<i class="fa fa-fw fa-user" v-if="entity.kind === 'child'"></i>
|
||||||
|
<i class="fa fa-fw fa-hospital-o" v-else-if="entity.kind === 'company'"></i>
|
||||||
|
<i class="fa fa-fw fa-user-md" v-else></i>
|
||||||
|
|
||||||
|
<template v-if="options.displayLong === true">
|
||||||
|
<span v-if="entity.kind === 'child'">{{ $t('tparty.child')}}</span>
|
||||||
|
<span v-else-if="entity.kind === 'company'">{{ $t('tparty.company')}}</span>
|
||||||
|
<span v-else>{{ $t('tparty.contact')}}</span>
|
||||||
|
</template>
|
||||||
|
</span>
|
||||||
|
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: "BadgeEntity",
|
||||||
|
props: ['options', 'entity'],
|
||||||
|
i18n: {
|
||||||
|
messages: {
|
||||||
|
fr: {
|
||||||
|
tparty: {
|
||||||
|
child: "Personne de contact",
|
||||||
|
company: "Personne morale",
|
||||||
|
contact: "Personne physique",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
@ -12,13 +12,11 @@
|
|||||||
* extended_infos bool add extra informations (step, floor, etc.)
|
* extended_infos bool add extra informations (step, floor, etc.)
|
||||||
|
|
||||||
#}
|
#}
|
||||||
{% macro raw(address, options) %}
|
|
||||||
|
{% macro raw(address, options, streetLine) %}
|
||||||
|
|
||||||
{% if address.street is not empty %}
|
{% if address.street is not empty %}
|
||||||
<p class="street">{{ address.street }}
|
<p>{{ streetLine }}</p>
|
||||||
{% if address.streetNumber is not empty %}
|
|
||||||
<span class="streetnumber">{{ address.streetNumber }}</span>
|
|
||||||
{% endif %}
|
|
||||||
</p>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if options['extended_infos'] %}
|
{% if options['extended_infos'] %}
|
||||||
{{ _self.extended(address, options) }}
|
{{ _self.extended(address, options) }}
|
||||||
@ -56,7 +54,7 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
{% endmacro %}
|
{% endmacro %}
|
||||||
|
|
||||||
{% macro inline(address, options) %}
|
{% macro inline(address, options, streetLine) %}
|
||||||
{% 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 %}
|
||||||
<p class="postcode">
|
<p class="postcode">
|
||||||
@ -70,7 +68,7 @@
|
|||||||
</span>
|
</span>
|
||||||
{% else %}
|
{% else %}
|
||||||
<span class="address{% if options['multiline'] %} multiline{% endif %}{% if options['with_delimiter'] %} delimiter{% endif %}">
|
<span class="address{% if options['multiline'] %} multiline{% endif %}{% if options['with_delimiter'] %} delimiter{% endif %}">
|
||||||
{{ _self.raw(address, options) }}
|
{{ _self.raw(address, options, streetLine) }}
|
||||||
</span>
|
</span>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{{ _self.validity(address, options) }}
|
{{ _self.validity(address, options) }}
|
||||||
@ -99,7 +97,7 @@
|
|||||||
{% 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 %}
|
||||||
{{ _self.inline(address, options) }}
|
{{ _self.inline(address, options, streetLine) }}
|
||||||
</li>
|
</li>
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
|
|
||||||
@ -108,7 +106,7 @@
|
|||||||
{% 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 %}
|
||||||
{{ _self.inline(address, options) }}
|
{{ _self.inline(address, options, streetLine) }}
|
||||||
</span>
|
</span>
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
|
|
||||||
@ -133,7 +131,7 @@
|
|||||||
{% 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 %}
|
||||||
{{ _self.raw(address, options) }}
|
{{ _self.raw(address, options, streetLine) }}
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{{ _self.validity(address, options) }}
|
{{ _self.validity(address, options) }}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{{ form_start(form) }}
|
{{ form_start(form) }}
|
||||||
<div class="chill_filter_order container">
|
<div class="chill_filter_order container my-4">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
{% if form.vars.has_search_box %}
|
{% if form.vars.has_search_box %}
|
||||||
<div class="col-md-12">
|
<div class="col-md-12">
|
||||||
|
@ -52,9 +52,19 @@ class AddressNormalizer implements ContextAwareNormalizerInterface, NormalizerAw
|
|||||||
public function normalize($address, ?string $format = null, array $context = [])
|
public function normalize($address, ?string $format = null, array $context = [])
|
||||||
{
|
{
|
||||||
if ($address instanceof Address) {
|
if ($address instanceof Address) {
|
||||||
|
$text = $address->isNoAddress() ? '' : $address->getStreet() . ', ' . $address->getStreetNumber();
|
||||||
|
|
||||||
|
if (null !== $address->getPostCode()->getCountry()->getCountryCode()) {
|
||||||
|
if ($address->getPostCode()->getCountry()->getCountryCode() === 'FR') {
|
||||||
|
$text = $address->isNoAddress() ? '' : $address->getStreetNumber() . ', ' . $address->getStreet();
|
||||||
|
} else {
|
||||||
|
$text = $address->isNoAddress() ? '' : $address->getStreetNumber() . ', ' . $address->getStreet();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$data = [
|
$data = [
|
||||||
'address_id' => $address->getId(),
|
'address_id' => $address->getId(),
|
||||||
'text' => $address->isNoAddress() ? '' : $address->getStreetNumber() . ', ' . $address->getStreet(),
|
'text' => $text,
|
||||||
'street' => $address->getStreet(),
|
'street' => $address->getStreet(),
|
||||||
'streetNumber' => $address->getStreetNumber(),
|
'streetNumber' => $address->getStreetNumber(),
|
||||||
'postcode' => [
|
'postcode' => [
|
||||||
|
@ -46,6 +46,7 @@ class AddressRender implements ChillEntityRenderInterface
|
|||||||
return $this->templating
|
return $this->templating
|
||||||
->render('@ChillMain/Entity/address.html.twig', [
|
->render('@ChillMain/Entity/address.html.twig', [
|
||||||
'address' => $addr,
|
'address' => $addr,
|
||||||
|
'streetLine' => $this->renderStreetLine($addr),
|
||||||
'render' => $options['render'] ?? 'bloc',
|
'render' => $options['render'] ?? 'bloc',
|
||||||
'options' => $options,
|
'options' => $options,
|
||||||
]);
|
]);
|
||||||
@ -59,13 +60,7 @@ class AddressRender implements ChillEntityRenderInterface
|
|||||||
{
|
{
|
||||||
$lines = [];
|
$lines = [];
|
||||||
|
|
||||||
if (!empty($addr->getStreet())) {
|
$lines[0] = $this->renderStreetLine($addr);
|
||||||
$lines[0] = $addr->getStreet();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($addr->getStreetNumber())) {
|
|
||||||
$lines[0] .= ', ' . $addr->getStreetNumber();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($addr->getPostcode())) {
|
if (!empty($addr->getPostcode())) {
|
||||||
$lines[1] = strtr('{postcode} {label}', [
|
$lines[1] = strtr('{postcode} {label}', [
|
||||||
@ -81,4 +76,33 @@ class AddressRender implements ChillEntityRenderInterface
|
|||||||
{
|
{
|
||||||
return $entity instanceof Address;
|
return $entity instanceof Address;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function renderStreetLine($addr): string
|
||||||
|
{
|
||||||
|
if (!empty($addr->getStreet())) {
|
||||||
|
$street = $addr->getStreet();
|
||||||
|
} else {
|
||||||
|
$street = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($addr->getStreetNumber())) {
|
||||||
|
$streetNumber = $addr->getStreetNumber();
|
||||||
|
} else {
|
||||||
|
$streetNumber = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$res = trim($street . ', ' . $streetNumber, ', ');
|
||||||
|
|
||||||
|
if (null !== $addr->getPostCode()->getCountry()->getCountryCode()) {
|
||||||
|
if ($addr->getPostCode()->getCountry()->getCountryCode() === 'FR') {
|
||||||
|
$res = trim($streetNumber . ', ' . $street, ', ');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (',' === $res) {
|
||||||
|
$res = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,8 @@ use Symfony\Component\HttpFoundation\Response;
|
|||||||
use Symfony\Component\Routing\Annotation\Route;
|
use Symfony\Component\Routing\Annotation\Route;
|
||||||
use Symfony\Component\Serializer\Exception\RuntimeException;
|
use Symfony\Component\Serializer\Exception\RuntimeException;
|
||||||
use Symfony\Component\Serializer\Normalizer\AbstractNormalizer;
|
use Symfony\Component\Serializer\Normalizer\AbstractNormalizer;
|
||||||
|
use Symfony\Component\Validator\ConstraintViolationList;
|
||||||
|
use Symfony\Component\Validator\ConstraintViolationListInterface;
|
||||||
use Symfony\Component\Validator\Validator\ValidatorInterface;
|
use Symfony\Component\Validator\Validator\ValidatorInterface;
|
||||||
use Symfony\Component\Workflow\Registry;
|
use Symfony\Component\Workflow\Registry;
|
||||||
use function array_values;
|
use function array_values;
|
||||||
@ -294,4 +296,17 @@ final class AccompanyingCourseApiController extends ApiController
|
|||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function validate(string $action, Request $request, string $_format, $entity, array $more = []): ConstraintViolationListInterface
|
||||||
|
{
|
||||||
|
if ('work' !== $action) {
|
||||||
|
return parent::validate($action, $request, $_format, $entity, $more);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Request::METHOD_POST === $request->getMethod()) {
|
||||||
|
return $this->getValidator()->validate($more[0], null);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ConstraintViolationList([]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -186,7 +186,7 @@ class HouseholdMemberController extends ApiController
|
|||||||
$_format,
|
$_format,
|
||||||
['groups' => ['read']]
|
['groups' => ['read']]
|
||||||
);
|
);
|
||||||
} catch (Exception\InvalidArgumentException | Exception\UnexpectedValueException $e) {
|
} catch (Exception\InvalidArgumentException|Exception\UnexpectedValueException $e) {
|
||||||
throw new BadRequestException("Deserialization error: {$e->getMessage()}", 45896, $e);
|
throw new BadRequestException("Deserialization error: {$e->getMessage()}", 45896, $e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -222,9 +222,7 @@ final class PersonController extends AbstractController
|
|||||||
'label' => 'Add the person',
|
'label' => 'Add the person',
|
||||||
])->add('createPeriod', SubmitType::class, [
|
])->add('createPeriod', SubmitType::class, [
|
||||||
'label' => 'Add the person and create an accompanying period',
|
'label' => 'Add the person and create an accompanying period',
|
||||||
])->add('createHousehold', SubmitType::class, [
|
]);
|
||||||
'label' => 'Add the person and create an household',
|
|
||||||
]); // TODO createHousehold form action
|
|
||||||
|
|
||||||
$form->handleRequest($request);
|
$form->handleRequest($request);
|
||||||
|
|
||||||
|
@ -79,6 +79,7 @@ class ChillPersonExtension extends Extension implements PrependExtensionInterfac
|
|||||||
$loader->load('services/serializer.yaml');
|
$loader->load('services/serializer.yaml');
|
||||||
$loader->load('services/security.yaml');
|
$loader->load('services/security.yaml');
|
||||||
$loader->load('services/doctrineEventListener.yaml');
|
$loader->load('services/doctrineEventListener.yaml');
|
||||||
|
$loader->load('services/accompanyingPeriodConsistency.yaml');
|
||||||
|
|
||||||
if ($container->getParameter('chill_person.accompanying_period') !== 'hidden') {
|
if ($container->getParameter('chill_person.accompanying_period') !== 'hidden') {
|
||||||
$loader->load('services/exports_accompanying_period.yaml');
|
$loader->load('services/exports_accompanying_period.yaml');
|
||||||
|
@ -80,6 +80,7 @@ class Configuration implements ConfigurationInterface
|
|||||||
->append($this->addFieldNode('memo'))
|
->append($this->addFieldNode('memo'))
|
||||||
->append($this->addFieldNode('number_of_children'))
|
->append($this->addFieldNode('number_of_children'))
|
||||||
->append($this->addFieldNode('acceptEmail'))
|
->append($this->addFieldNode('acceptEmail'))
|
||||||
|
->append($this->addFieldNode('deathdate'))
|
||||||
->arrayNode('alt_names')
|
->arrayNode('alt_names')
|
||||||
->defaultValue([])
|
->defaultValue([])
|
||||||
->arrayPrototype()
|
->arrayPrototype()
|
||||||
|
@ -14,10 +14,12 @@ namespace Chill\PersonBundle\Entity\AccompanyingPeriod;
|
|||||||
use Chill\MainBundle\Doctrine\Model\TrackCreationInterface;
|
use Chill\MainBundle\Doctrine\Model\TrackCreationInterface;
|
||||||
use Chill\MainBundle\Doctrine\Model\TrackUpdateInterface;
|
use Chill\MainBundle\Doctrine\Model\TrackUpdateInterface;
|
||||||
use Chill\MainBundle\Entity\User;
|
use Chill\MainBundle\Entity\User;
|
||||||
|
use Chill\PersonBundle\AccompanyingPeriod\SocialIssueConsistency\AccompanyingPeriodLinkedWithSocialIssuesEntityInterface;
|
||||||
use Chill\PersonBundle\Entity\AccompanyingPeriod;
|
use Chill\PersonBundle\Entity\AccompanyingPeriod;
|
||||||
use Chill\PersonBundle\Entity\Person;
|
use Chill\PersonBundle\Entity\Person;
|
||||||
use Chill\PersonBundle\Entity\SocialWork\Result;
|
use Chill\PersonBundle\Entity\SocialWork\Result;
|
||||||
use Chill\PersonBundle\Entity\SocialWork\SocialAction;
|
use Chill\PersonBundle\Entity\SocialWork\SocialAction;
|
||||||
|
use Chill\PersonBundle\Entity\SocialWork\SocialIssue;
|
||||||
use Chill\ThirdPartyBundle\Entity\ThirdParty;
|
use Chill\ThirdPartyBundle\Entity\ThirdParty;
|
||||||
use DateTimeImmutable;
|
use DateTimeImmutable;
|
||||||
use DateTimeInterface;
|
use DateTimeInterface;
|
||||||
@ -28,7 +30,7 @@ use LogicException;
|
|||||||
use Symfony\Component\Serializer\Annotation as Serializer;
|
use Symfony\Component\Serializer\Annotation as Serializer;
|
||||||
use Symfony\Component\Validator\Constraints as Assert;
|
use Symfony\Component\Validator\Constraints as Assert;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ORM\Entity
|
* @ORM\Entity
|
||||||
* @ORM\Table(name="chill_person_accompanying_period_work")
|
* @ORM\Table(name="chill_person_accompanying_period_work")
|
||||||
* @Serializer\DiscriminatorMap(
|
* @Serializer\DiscriminatorMap(
|
||||||
@ -38,8 +40,8 @@ use Symfony\Component\Validator\Constraints as Assert;
|
|||||||
* }
|
* }
|
||||||
* )
|
* )
|
||||||
*/
|
*/
|
||||||
class AccompanyingPeriodWork implements TrackCreationInterface, TrackUpdateInterface
|
class AccompanyingPeriodWork implements AccompanyingPeriodLinkedWithSocialIssuesEntityInterface, TrackCreationInterface, TrackUpdateInterface
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @ORM\ManyToOne(targetEntity=AccompanyingPeriod::class)
|
* @ORM\ManyToOne(targetEntity=AccompanyingPeriod::class)
|
||||||
* @Serializer\Groups({"read"})
|
* @Serializer\Groups({"read"})
|
||||||
@ -320,6 +322,11 @@ use Symfony\Component\Validator\Constraints as Assert;
|
|||||||
return $this->socialAction;
|
return $this->socialAction;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getSocialIssues(): Collection
|
||||||
|
{
|
||||||
|
return new ArrayCollection([$this->getSocialAction()->getIssue()]);
|
||||||
|
}
|
||||||
|
|
||||||
public function getStartDate(): ?DateTimeInterface
|
public function getStartDate(): ?DateTimeInterface
|
||||||
{
|
{
|
||||||
return $this->startDate;
|
return $this->startDate;
|
||||||
@ -383,6 +390,13 @@ use Symfony\Component\Validator\Constraints as Assert;
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function removeSocialIssue(SocialIssue $issue): AccompanyingPeriodLinkedWithSocialIssuesEntityInterface
|
||||||
|
{
|
||||||
|
$this->getSocialIssues()->removeElement($issue);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function removeThirdParty(ThirdParty $thirdParty): self
|
public function removeThirdParty(ThirdParty $thirdParty): self
|
||||||
{
|
{
|
||||||
$this->thirdParties->removeElement($thirdParty);
|
$this->thirdParties->removeElement($thirdParty);
|
||||||
@ -482,4 +496,4 @@ use Symfony\Component\Validator\Constraints as Assert;
|
|||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -244,6 +244,8 @@ class Person implements HasCenterInterface, TrackCreationInterface, TrackUpdateI
|
|||||||
* @Assert\Date(
|
* @Assert\Date(
|
||||||
* groups={"general", "creation"}
|
* groups={"general", "creation"}
|
||||||
* )
|
* )
|
||||||
|
* @Assert\GreaterThan(propertyPath="birthDate")
|
||||||
|
* @Assert\LessThanOrEqual("today")
|
||||||
*/
|
*/
|
||||||
private ?DateTimeImmutable $deathdate = null;
|
private ?DateTimeImmutable $deathdate = null;
|
||||||
|
|
||||||
@ -1774,7 +1776,7 @@ class Person implements HasCenterInterface, TrackCreationInterface, TrackUpdateI
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setNumberOfChildren(int $numberOfChildren): self
|
public function setNumberOfChildren(?int $numberOfChildren): self
|
||||||
{
|
{
|
||||||
$this->numberOfChildren = $numberOfChildren;
|
$this->numberOfChildren = $numberOfChildren;
|
||||||
|
|
||||||
|
@ -93,6 +93,7 @@ class PersonType extends AbstractType
|
|||||||
])
|
])
|
||||||
->add('numberOfChildren', IntegerType::class, [
|
->add('numberOfChildren', IntegerType::class, [
|
||||||
'required' => false,
|
'required' => false,
|
||||||
|
'attr' => ['min' => 0],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
if ($this->configAltNamesHelper->hasAltNames()) {
|
if ($this->configAltNamesHelper->hasAltNames()) {
|
||||||
|
@ -162,6 +162,13 @@ div.activity-list {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
* Specific badge rounded-pill
|
||||||
*/
|
*/
|
||||||
|
.badge {
|
||||||
|
&.bg-person {
|
||||||
|
//@extend .$chill-ll-gray;
|
||||||
|
background-color: $chill-ll-gray;
|
||||||
|
color: $chill-green;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div v-if="suggestedPersons.length > 0">
|
<div v-if="suggestedPersons.length > 0">
|
||||||
<ul class="list-suggest add-items">
|
<ul class="list-suggest add-items inline">
|
||||||
<li v-for="p in suggestedPersons" :key="p.id" @click="addSuggestedPerson(p)">
|
<li v-for="p in suggestedPersons" :key="p.id" @click="addSuggestedPerson(p)">
|
||||||
<span>{{ p.text }}</span>
|
<span>{{ p.text }}</span>
|
||||||
</li>
|
</li>
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
</VueMultiselect>
|
</VueMultiselect>
|
||||||
|
|
||||||
<template v-if="referrersSuggested.length > 0">
|
<template v-if="referrersSuggested.length > 0">
|
||||||
<ul class="list-suggest add-items">
|
<ul class="list-suggest add-items inline">
|
||||||
<li v-for="u in referrersSuggested" @click="updateReferrer(u)">
|
<li v-for="u in referrersSuggested" @click="updateReferrer(u)">
|
||||||
<span>
|
<span>
|
||||||
<user-render-box-badge :user="u"></user-render-box-badge>
|
<user-render-box-badge :user="u"></user-render-box-badge>
|
||||||
|
@ -134,7 +134,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div v-if="accompanyingCourse.requestor === null && suggestedEntities.length > 0">
|
<div v-if="accompanyingCourse.requestor === null && suggestedEntities.length > 0">
|
||||||
<ul class="list-suggest add-items">
|
<ul class="list-suggest add-items inline">
|
||||||
<li v-for="p in suggestedEntities" :key="uniqueId(p)" @click="addSuggestedEntity(p)">
|
<li v-for="p in suggestedEntities" :key="uniqueId(p)" @click="addSuggestedEntity(p)">
|
||||||
<span>{{ p.text }}</span>
|
<span>{{ p.text }}</span>
|
||||||
</li>
|
</li>
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div v-if="suggestedEntities.length > 0">
|
<div v-if="suggestedEntities.length > 0">
|
||||||
<ul class="list-suggest add-items">
|
<ul class="list-suggest add-items inline">
|
||||||
<li v-for="p in suggestedEntities" :key="uniqueId(p)" @click="addSuggestedEntity(p)">
|
<li v-for="p in suggestedEntities" :key="uniqueId(p)" @click="addSuggestedEntity(p)">
|
||||||
<span>{{ p.text }}</span>
|
<span>{{ p.text }}</span>
|
||||||
</li>
|
</li>
|
||||||
|
@ -2,33 +2,81 @@
|
|||||||
<person-render-box render="bloc"
|
<person-render-box render="bloc"
|
||||||
v-if="resource.resource.type === 'person'"
|
v-if="resource.resource.type === 'person'"
|
||||||
:person="resource.resource"
|
:person="resource.resource"
|
||||||
:options="{ addInfo : true, addId : false, addEntity: true, addLink: false, addAltNames: true, addAge : false, hLevel : 3, isConfidential : true }"
|
:options="{
|
||||||
>
|
addInfo : true,
|
||||||
|
addId : false,
|
||||||
|
addEntity: true,
|
||||||
|
addLink: false,
|
||||||
|
addAltNames: true,
|
||||||
|
addAge : false,
|
||||||
|
hLevel : 3,
|
||||||
|
isConfidential : true
|
||||||
|
}">
|
||||||
<template v-slot:record-actions>
|
<template v-slot:record-actions>
|
||||||
<ul class="record_actions">
|
<ul class="record_actions">
|
||||||
<!--
|
<li>
|
||||||
<button-location v-if="hasCurrentHouseholdAddress" :person="resource.resource"></button-location>
|
<on-the-fly
|
||||||
-->
|
:type="resource.resource.type"
|
||||||
<li><on-the-fly :type="resource.resource.type" :id="resource.resource.id" action="show"></on-the-fly></li>
|
:id="resource.resource.id"
|
||||||
<li><on-the-fly :type="resource.resource.type" :id="resource.resource.id" action="edit" @saveFormOnTheFly="saveFormOnTheFly"></on-the-fly></li>
|
action="show">
|
||||||
<li><button class="btn btn-sm btn-remove" :title="$t('action.remove')" @click.prevent="$emit('remove', resource)"></button></li>
|
</on-the-fly>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<on-the-fly
|
||||||
|
:type="resource.resource.type"
|
||||||
|
:id="resource.resource.id"
|
||||||
|
action="edit"
|
||||||
|
@saveFormOnTheFly="saveFormOnTheFly">
|
||||||
|
</on-the-fly>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<button
|
||||||
|
class="btn btn-sm btn-remove"
|
||||||
|
:title="$t('action.remove')"
|
||||||
|
@click.prevent="$emit('remove', resource)">
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
</person-render-box>
|
</person-render-box>
|
||||||
|
|
||||||
<third-party-render-box
|
<third-party-render-box
|
||||||
v-if="resource.resource.type === 'thirdparty'"
|
v-if="resource.resource.type === 'thirdparty'"
|
||||||
:thirdparty="resource.resource"
|
:thirdparty="resource.resource"
|
||||||
:options="{ addLink : false, addId : false, addEntity: true, addInfo: false, hLevel: 3 }"
|
:options="{
|
||||||
>
|
addLink : false,
|
||||||
|
addId : false,
|
||||||
|
addEntity: true,
|
||||||
|
addInfo: false,
|
||||||
|
//addComment: true,
|
||||||
|
hLevel: 3
|
||||||
|
}">
|
||||||
<template v-slot:record-actions>
|
<template v-slot:record-actions>
|
||||||
<ul class="record_actions">
|
<ul class="record_actions">
|
||||||
<li><on-the-fly :type="resource.resource.type" :id="resource.resource.id" action="show"></on-the-fly></li>
|
<li>
|
||||||
<li><on-the-fly :type="resource.resource.type" :id="resource.resource.id" action="edit" @saveFormOnTheFly="saveFormOnTheFly"></on-the-fly></li>
|
<on-the-fly
|
||||||
<li><button class="btn btn-sm btn-remove" :title="$t('action.remove')" @click.prevent="$emit('remove', resource)"></button></li>
|
:type="resource.resource.type"
|
||||||
|
:id="resource.resource.id"
|
||||||
|
action="show">
|
||||||
|
</on-the-fly>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<on-the-fly
|
||||||
|
:type="resource.resource.type"
|
||||||
|
:id="resource.resource.id"
|
||||||
|
action="edit"
|
||||||
|
@saveFormOnTheFly="saveFormOnTheFly">
|
||||||
|
</on-the-fly>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<button
|
||||||
|
class="btn btn-sm btn-remove"
|
||||||
|
:title="$t('action.remove')"
|
||||||
|
@click.prevent="$emit('remove', resource)">
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
</third-party-render-box>
|
</third-party-render-box>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
@ -132,6 +132,10 @@ const appMessages = {
|
|||||||
sure_description: "Une fois le changement confirmé, il ne sera plus possible de le remettre à l'état de brouillon !",
|
sure_description: "Une fois le changement confirmé, il ne sera plus possible de le remettre à l'état de brouillon !",
|
||||||
ok: "Confirmer le parcours"
|
ok: "Confirmer le parcours"
|
||||||
},
|
},
|
||||||
|
action: {
|
||||||
|
choose_other_social_issue: "Veuillez choisir un autre problématique",
|
||||||
|
cancel: "Annuler",
|
||||||
|
},
|
||||||
// catch errors
|
// catch errors
|
||||||
'Error while updating AccompanyingPeriod Course.': "Erreur du serveur lors de la mise à jour du parcours d'accompagnement.",
|
'Error while updating AccompanyingPeriod Course.': "Erreur du serveur lors de la mise à jour du parcours d'accompagnement.",
|
||||||
'Error while retriving AccompanyingPeriod Course.': "Erreur du serveur lors du chargement du parcours d'accompagnement.",
|
'Error while retriving AccompanyingPeriod Course.': "Erreur du serveur lors du chargement du parcours d'accompagnement.",
|
||||||
|
@ -7,13 +7,35 @@
|
|||||||
|
|
||||||
<div id="picking">
|
<div id="picking">
|
||||||
<p>{{ $t('pick_social_issue_linked_with_action') }}</p>
|
<p>{{ $t('pick_social_issue_linked_with_action') }}</p>
|
||||||
|
|
||||||
<div v-for="si in socialIssues">
|
<div v-for="si in socialIssues">
|
||||||
<input type="radio" v-bind:value="si.id" name="socialIssue" v-model="socialIssuePicked"><span class="badge bg-chill-l-gray text-dark">{{ si.text }}</span>
|
<input type="radio" checked v-bind:value="si.id" name="socialIssue" v-model="socialIssuePicked"><span class="badge bg-chill-l-gray text-dark">{{ si.text }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="my-3">
|
||||||
|
<div class="col-8">
|
||||||
|
<vue-multiselect
|
||||||
|
name="otherIssues"
|
||||||
|
label="text"
|
||||||
|
track-by="id"
|
||||||
|
open-direction="bottom"
|
||||||
|
:close-on-select="true"
|
||||||
|
:preserve-search="false"
|
||||||
|
:reset-after="true"
|
||||||
|
:hide-selected="true"
|
||||||
|
:taggable="false"
|
||||||
|
:multiple="false"
|
||||||
|
:searchable="true"
|
||||||
|
:allow-empty="true"
|
||||||
|
:show-labels="false"
|
||||||
|
:loading="issueIsLoading"
|
||||||
|
:placeholder="$t('action.choose_other_social_issue')"
|
||||||
|
:options="socialIssuesOther"
|
||||||
|
@select="addIssueInList">
|
||||||
|
</vue-multiselect>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div v-if="hasSocialIssuePicked">
|
<div v-if="hasSocialIssuePicked">
|
||||||
<h2>{{ $t('pick_an_action') }}</h2>
|
<h2>{{ $t('pick_an_action') }}</h2>
|
||||||
|
<div class="col-8">
|
||||||
<vue-multiselect
|
<vue-multiselect
|
||||||
v-model="socialActionPicked"
|
v-model="socialActionPicked"
|
||||||
label="text"
|
label="text"
|
||||||
@ -24,6 +46,7 @@
|
|||||||
track-by="id"
|
track-by="id"
|
||||||
></vue-multiselect>
|
></vue-multiselect>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div v-if="isLoadingSocialActions">
|
<div v-if="isLoadingSocialActions">
|
||||||
<i class="fa fa-circle-o-notch fa-spin fa-fw"></i>
|
<i class="fa fa-circle-o-notch fa-spin fa-fw"></i>
|
||||||
@ -63,9 +86,9 @@
|
|||||||
<div>
|
<div>
|
||||||
<ul class="record_actions">
|
<ul class="record_actions">
|
||||||
<li class="cancel">
|
<li class="cancel">
|
||||||
<a href="#" class="btn btn-cancel">
|
<button class="btn btn-cancel" @click="goToPrevious">
|
||||||
{{ $t('action.cancel') }}
|
{{ $t('action.cancel') }}
|
||||||
</a>
|
</button>
|
||||||
</li>
|
</li>
|
||||||
<li v-if="hasSocialActionPicked">
|
<li v-if="hasSocialActionPicked">
|
||||||
<button class="btn btn-save" v-show="!isPostingWork" @click="submit">
|
<button class="btn btn-save" v-show="!isPostingWork" @click="submit">
|
||||||
@ -82,43 +105,7 @@
|
|||||||
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<style lang="scss">
|
|
||||||
|
|
||||||
#awc_create_form {
|
|
||||||
display: grid;
|
|
||||||
grid-template-areas:
|
|
||||||
"picking picking"
|
|
||||||
"start_date end_date"
|
|
||||||
"confirm confirm"
|
|
||||||
;
|
|
||||||
grid-template-columns: 50% 50%;
|
|
||||||
column-gap: 1.5rem;
|
|
||||||
|
|
||||||
#picking {
|
|
||||||
grid-area: picking;
|
|
||||||
|
|
||||||
#persons {
|
|
||||||
ul {
|
|
||||||
padding: 0;
|
|
||||||
|
|
||||||
list-style-type: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#start_date {
|
|
||||||
grid-area: start_date;
|
|
||||||
}
|
|
||||||
|
|
||||||
#end_date {
|
|
||||||
grid-area: end_date;
|
|
||||||
}
|
|
||||||
|
|
||||||
#confirm {
|
|
||||||
grid-area: confirm;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapState, mapActions, mapGetters } from 'vuex';
|
import { mapState, mapActions, mapGetters } from 'vuex';
|
||||||
@ -149,13 +136,34 @@ export default {
|
|||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
submit() {
|
submit() {
|
||||||
this.$store.dispatch('submit');
|
this.$store.dispatch('submit')
|
||||||
|
.catch(({name, violations}) => {
|
||||||
|
if (name === 'ValidationException' || name === 'AccessException') {
|
||||||
|
violations.forEach((violation) => this.$toast.open({message: violation}));
|
||||||
|
} else {
|
||||||
|
this.$toast.open({message: 'An error occurred'})
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
addIssueInList(value) {
|
||||||
|
this.$store.commit('addIssueInList', value);
|
||||||
|
this.$store.commit('removeIssueInOther', value);
|
||||||
|
this.$store.dispatch('pickSocialIssue', value.id);
|
||||||
|
},
|
||||||
|
goToPrevious() {
|
||||||
|
let params = new URLSearchParams(window.location.search);
|
||||||
|
if (params.has('returnPath')) {
|
||||||
|
window.location.replace(params.get('returnPath'));
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
},
|
||||||
},
|
},
|
||||||
i18n,
|
i18n,
|
||||||
computed: {
|
computed: {
|
||||||
...mapState([
|
...mapState([
|
||||||
'socialIssues',
|
'socialIssues',
|
||||||
|
'socialIssuesOther',
|
||||||
'socialActionsReachables',
|
'socialActionsReachables',
|
||||||
'errors',
|
'errors',
|
||||||
'personsReachables',
|
'personsReachables',
|
||||||
@ -170,12 +178,12 @@ export default {
|
|||||||
personsPicked: {
|
personsPicked: {
|
||||||
get() {
|
get() {
|
||||||
let s = this.$store.state.personsPicked.map(p => p.id);
|
let s = this.$store.state.personsPicked.map(p => p.id);
|
||||||
console.log('persons picked', s);
|
// console.log('persons picked', s);
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
},
|
},
|
||||||
set(v) {
|
set(v) {
|
||||||
console.log('persons picked', v);
|
// console.log('persons picked', v);
|
||||||
this.$store.commit('setPersonsPickedIds', v);
|
this.$store.commit('setPersonsPickedIds', v);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -235,3 +243,41 @@ span.badge {
|
|||||||
margin-left: 1em;
|
margin-left: 1em;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
<style lang="scss">
|
||||||
|
|
||||||
|
#awc_create_form {
|
||||||
|
display: grid;
|
||||||
|
grid-template-areas:
|
||||||
|
"picking picking"
|
||||||
|
"start_date end_date"
|
||||||
|
"confirm confirm"
|
||||||
|
;
|
||||||
|
grid-template-columns: 50% 50%;
|
||||||
|
column-gap: 1.5rem;
|
||||||
|
|
||||||
|
#picking {
|
||||||
|
grid-area: picking;
|
||||||
|
|
||||||
|
#persons {
|
||||||
|
ul {
|
||||||
|
padding: 0;
|
||||||
|
|
||||||
|
list-style-type: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#start_date {
|
||||||
|
grid-area: start_date;
|
||||||
|
}
|
||||||
|
|
||||||
|
#end_date {
|
||||||
|
grid-area: end_date;
|
||||||
|
}
|
||||||
|
|
||||||
|
#confirm {
|
||||||
|
grid-area: confirm;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
@ -2,7 +2,8 @@
|
|||||||
import { createStore } from 'vuex';
|
import { createStore } from 'vuex';
|
||||||
import { datetimeToISO } from 'ChillMainAssets/chill/js/date.js';
|
import { datetimeToISO } from 'ChillMainAssets/chill/js/date.js';
|
||||||
import { findSocialActionsBySocialIssue } from 'ChillPersonAssets/vuejs/_api/SocialWorkSocialAction.js';
|
import { findSocialActionsBySocialIssue } from 'ChillPersonAssets/vuejs/_api/SocialWorkSocialAction.js';
|
||||||
import { create } from 'ChillPersonAssets/vuejs/_api/AccompanyingCourseWork.js';
|
// import { create } from 'ChillPersonAssets/vuejs/_api/AccompanyingCourseWork.js';
|
||||||
|
import { makeFetch } from 'ChillMainAssets/lib/api/apiMethods';
|
||||||
|
|
||||||
const debug = process.env.NODE_ENV !== 'production';
|
const debug = process.env.NODE_ENV !== 'production';
|
||||||
|
|
||||||
@ -12,6 +13,7 @@ const store = createStore({
|
|||||||
accompanyingCourse: window.accompanyingCourse,
|
accompanyingCourse: window.accompanyingCourse,
|
||||||
socialIssues: window.accompanyingCourse.socialIssues,
|
socialIssues: window.accompanyingCourse.socialIssues,
|
||||||
socialIssuePicked: null,
|
socialIssuePicked: null,
|
||||||
|
socialIssuesOther: [],
|
||||||
socialActionsReachables: [],
|
socialActionsReachables: [],
|
||||||
socialActionPicked: null,
|
socialActionPicked: null,
|
||||||
personsPicked: window.accompanyingCourse.participations.filter(p => p.endDate == null)
|
personsPicked: window.accompanyingCourse.participations.filter(p => p.endDate == null)
|
||||||
@ -26,7 +28,6 @@ const store = createStore({
|
|||||||
},
|
},
|
||||||
getters: {
|
getters: {
|
||||||
hasSocialActionPicked(state) {
|
hasSocialActionPicked(state) {
|
||||||
console.log(state.socialActionPicked);
|
|
||||||
return null !== state.socialActionPicked;
|
return null !== state.socialActionPicked;
|
||||||
},
|
},
|
||||||
hasSocialIssuePicked(state) {
|
hasSocialIssuePicked(state) {
|
||||||
@ -73,27 +74,43 @@ const store = createStore({
|
|||||||
},
|
},
|
||||||
mutations: {
|
mutations: {
|
||||||
setSocialActionsReachables(state, actions) {
|
setSocialActionsReachables(state, actions) {
|
||||||
console.log('set social action reachables');
|
// console.log('set social action reachables');
|
||||||
console.log(actions);
|
// console.log(actions);
|
||||||
|
|
||||||
state.socialActionsReachables = actions;
|
state.socialActionsReachables = actions;
|
||||||
},
|
},
|
||||||
setSocialAction(state, socialAction) {
|
setSocialAction(state, socialAction) {
|
||||||
console.log('socialAction', socialAction);
|
// console.log('socialAction', socialAction);
|
||||||
state.socialActionPicked = socialAction;
|
state.socialActionPicked = socialAction;
|
||||||
},
|
},
|
||||||
setSocialIssue(state, socialIssueId) {
|
setSocialIssue(state, socialIssueId) {
|
||||||
console.log('set social issue', socialIssueId);
|
// console.log('set social issue', socialIssueId);
|
||||||
if (socialIssueId === null) {
|
if (socialIssueId === null) {
|
||||||
state.socialIssuePicked = null;
|
state.socialIssuePicked = null;
|
||||||
} else {
|
} else {
|
||||||
let mapped = state.socialIssues
|
let mapped = state.socialIssues
|
||||||
.find(e => e.id === socialIssueId);
|
.find(e => e.id === socialIssueId);
|
||||||
console.log('mapped', mapped);
|
|
||||||
state.socialIssuePicked = mapped;
|
state.socialIssuePicked = mapped;
|
||||||
console.log('social issue setted', state.socialIssuePicked);
|
// console.log('social issue setted', state.socialIssuePicked);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
addIssueInList(state, issue) {
|
||||||
|
//console.log('add issue list', issue.id);
|
||||||
|
state.socialIssues.push(issue);
|
||||||
|
},
|
||||||
|
updateIssuesOther(state, payload) {
|
||||||
|
//console.log('update issues other');
|
||||||
|
state.socialIssuesOther = payload;
|
||||||
|
},
|
||||||
|
removeIssueInOther(state, issue) {
|
||||||
|
//console.log('remove issue other', issue.id);
|
||||||
|
state.socialIssuesOther = state.socialIssuesOther.filter(
|
||||||
|
(i) => i.id !== issue.id
|
||||||
|
);
|
||||||
|
},
|
||||||
|
updateSelected(state, payload) {
|
||||||
|
state.socialIssueSelected = payload;
|
||||||
|
},
|
||||||
setIsLoadingSocialActions(state, s) {
|
setIsLoadingSocialActions(state, s) {
|
||||||
state.isLoadingSocialActions = s;
|
state.isLoadingSocialActions = s;
|
||||||
},
|
},
|
||||||
@ -131,8 +148,6 @@ const store = createStore({
|
|||||||
|
|
||||||
findSocialActionsBySocialIssue(socialIssueId).then(
|
findSocialActionsBySocialIssue(socialIssueId).then(
|
||||||
(response) => {
|
(response) => {
|
||||||
console.log(response);
|
|
||||||
console.log(response.results);
|
|
||||||
commit('setSocialIssue', socialIssueId);
|
commit('setSocialIssue', socialIssueId);
|
||||||
commit('setSocialActionsReachables', response.results);
|
commit('setSocialActionsReachables', response.results);
|
||||||
commit('setIsLoadingSocialActions', false);
|
commit('setIsLoadingSocialActions', false);
|
||||||
@ -142,34 +157,34 @@ const store = createStore({
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
submit({ commit, getters, state }) {
|
submit({ commit, getters, state }) {
|
||||||
console.log('submit');
|
let payload = getters.buildPayloadCreate;
|
||||||
let
|
const url = `/api/1.0/person/accompanying-course/${state.accompanyingCourse.id}/work.json`;
|
||||||
payload = getters.buildPayloadCreate,
|
|
||||||
errors = [];
|
|
||||||
|
|
||||||
commit('setPostingWork');
|
commit('setPostingWork');
|
||||||
|
|
||||||
create(state.accompanyingCourse.id, payload)
|
makeFetch('POST', url, payload)
|
||||||
.then( ({status, data}) => {
|
.then((response) => {
|
||||||
console.log('created return', { status, data});
|
window.location.assign(`/fr/person/accompanying-period/work/${response.id}/edit`)
|
||||||
if (status === 200) {
|
})
|
||||||
console.log('created, nothing to do here any more. Bye-bye!');
|
.catch((error) => {
|
||||||
window.location.assign(`/fr/person/accompanying-period/work/${data.id}/edit`);
|
throw error;
|
||||||
} else if (status === 422) {
|
|
||||||
console.log(data);
|
|
||||||
for (let i in data.violations) {
|
|
||||||
console.log(i);
|
|
||||||
console.log(data.violations[i].title);
|
|
||||||
errors.push(data.violations[i].title);
|
|
||||||
}
|
|
||||||
console.log('errors after reseponse handling', errors);
|
|
||||||
console.log({errors, cancel_posting: true});
|
|
||||||
commit('addErrors', { errors, cancel_posting: true });
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
fetchOtherSocialIssues({commit}) {
|
||||||
|
const url = `/api/1.0/person/social-work/social-issue.json`;
|
||||||
|
return makeFetch('GET', url)
|
||||||
|
.then((response) => {
|
||||||
|
commit('updateIssuesOther', response.results);
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
throw error;
|
||||||
|
})
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
store.dispatch('fetchOtherSocialIssues');
|
||||||
|
|
||||||
export { store };
|
export { store };
|
||||||
|
@ -15,7 +15,12 @@
|
|||||||
<confirmation v-if="step === 'confirm'"></confirmation>
|
<confirmation v-if="step === 'confirm'"></confirmation>
|
||||||
|
|
||||||
<ul class="record_actions sticky-form-buttons">
|
<ul class="record_actions sticky-form-buttons">
|
||||||
<li class="cancel" v-if="step !== 'concerned' || hasReturnPath">
|
<li class="cancel" v-if="step !== 'concerned'">
|
||||||
|
<button class="btn btn-cancel" @click="goToPrevious">
|
||||||
|
{{ $t('household_members_editor.app.previous') }}
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<li class="cancel" v-else-if="hasReturnPath">
|
||||||
<button class="btn btn-cancel" @click="goToPrevious">
|
<button class="btn btn-cancel" @click="goToPrevious">
|
||||||
{{ $t('household_members_editor.app.cancel') }}
|
{{ $t('household_members_editor.app.cancel') }}
|
||||||
</button>
|
</button>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="flex-table" v-if="hasHousehold">
|
<div class="flex-table mb-5" v-if="hasHousehold">
|
||||||
<div class="item-bloc">
|
<div class="item-bloc">
|
||||||
<household-render-box :household="fakeHouseholdWithConcerned"></household-render-box>
|
<household-render-box :household="fakeHouseholdWithConcerned"></household-render-box>
|
||||||
</div>
|
</div>
|
||||||
|
@ -51,6 +51,7 @@ const appMessages = {
|
|||||||
},
|
},
|
||||||
app: {
|
app: {
|
||||||
next: 'Suivant',
|
next: 'Suivant',
|
||||||
|
previous: 'Précédent',
|
||||||
cancel: 'Annuler',
|
cancel: 'Annuler',
|
||||||
save: 'Enregistrer',
|
save: 'Enregistrer',
|
||||||
steps: {
|
steps: {
|
||||||
|
@ -1,30 +1,30 @@
|
|||||||
const create = (accompanying_period_id, payload) => {
|
// const create = (accompanying_period_id, payload) => {
|
||||||
const url = `/api/1.0/person/accompanying-course/${accompanying_period_id}/work.json`;
|
// const url = `/api/1.0/person/accompanying-course/${accompanying_period_id}/work.json`;
|
||||||
let status;
|
// let status;
|
||||||
console.log('create', payload);
|
// console.log('create', payload);
|
||||||
|
|
||||||
return fetch(url, {
|
// return fetch(url, {
|
||||||
method: 'POST',
|
// method: 'POST',
|
||||||
headers: {
|
// headers: {
|
||||||
'Content-Type': 'application/json',
|
// 'Content-Type': 'application/json',
|
||||||
},
|
// },
|
||||||
body: JSON.stringify(payload),
|
// body: JSON.stringify(payload),
|
||||||
})
|
// })
|
||||||
.then(response => {
|
// .then(response => {
|
||||||
if (response.ok || response.status === 422) {
|
// if (response.ok || response.status === 422) {
|
||||||
status = response.status;
|
// status = response.status;
|
||||||
|
|
||||||
return response.json();
|
// return response.json();
|
||||||
}
|
// }
|
||||||
|
|
||||||
throw new Error("Error while retrieving social actions: " + response.status +
|
// throw new Error("Error while retrieving social actions: " + response.status +
|
||||||
" " + response.statusText);
|
// " " + response.statusText);
|
||||||
})
|
// })
|
||||||
.then(data => {
|
// .then(data => {
|
||||||
return new Promise((resolve, reject) => {
|
// return new Promise((resolve, reject) => {
|
||||||
resolve({ status, data });
|
// resolve({ status, data });
|
||||||
});
|
// });
|
||||||
});
|
// });
|
||||||
};
|
// };
|
||||||
|
|
||||||
export { create };
|
// export { create };
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="list-item" :class="{ checked: isChecked }">
|
<div class="list-item" :class="{ checked: isChecked }">
|
||||||
|
|
||||||
|
<label>
|
||||||
<div>
|
<div>
|
||||||
<input
|
<input
|
||||||
v-bind:type="type"
|
v-bind:type="type"
|
||||||
@ -24,6 +25,7 @@
|
|||||||
v-if="item.result.type === 'user'"
|
v-if="item.result.type === 'user'"
|
||||||
v-bind:item="item">
|
v-bind:item="item">
|
||||||
</suggestion-user>
|
</suggestion-user>
|
||||||
|
</label>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -78,6 +80,9 @@ export default {
|
|||||||
background-color: #ececec;
|
background-color: #ececec;
|
||||||
border-bottom: 1px dotted #8b8b8b;
|
border-bottom: 1px dotted #8b8b8b;
|
||||||
}
|
}
|
||||||
|
label {
|
||||||
|
display: inline-flex;
|
||||||
|
width: 100%;
|
||||||
div.container {
|
div.container {
|
||||||
& > input {
|
& > input {
|
||||||
margin-right: 0.8em;
|
margin-right: 0.8em;
|
||||||
@ -106,4 +111,5 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="container">
|
<div class="container">
|
||||||
|
|
||||||
<span class="name">
|
<span class="name">
|
||||||
{{ item.result.text }}
|
{{ item.result.text }}
|
||||||
</span>
|
</span>
|
||||||
@ -11,29 +10,30 @@
|
|||||||
{{ item.result.current_household_address.text }} -
|
{{ item.result.current_household_address.text }} -
|
||||||
{{ item.result.current_household_address.postcode.name }}
|
{{ item.result.current_household_address.postcode.name }}
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="right_actions">
|
|
||||||
|
|
||||||
<span class="badge rounded-pill bg-secondary" :title="item.key">
|
<div class="right_actions">
|
||||||
{{ $t('item.type_person') }}
|
<badge-entity
|
||||||
</span>
|
:entity="item.result"
|
||||||
|
:options="{ displayLong: true }">
|
||||||
|
</badge-entity>
|
||||||
<on-the-fly
|
<on-the-fly
|
||||||
type="person"
|
type="person"
|
||||||
v-bind:id="item.result.id"
|
v-bind:id="item.result.id"
|
||||||
action="show">
|
action="show">
|
||||||
</on-the-fly>
|
</on-the-fly>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import OnTheFly from 'ChillMainAssets/vuejs/OnTheFly/components/OnTheFly.vue';
|
import OnTheFly from 'ChillMainAssets/vuejs/OnTheFly/components/OnTheFly.vue';
|
||||||
|
import BadgeEntity from 'ChillMainAssets/vuejs/_components/BadgeEntity.vue';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'SuggestionPerson',
|
name: 'SuggestionPerson',
|
||||||
components: {
|
components: {
|
||||||
OnTheFly,
|
OnTheFly,
|
||||||
|
BadgeEntity
|
||||||
},
|
},
|
||||||
props: ['item'],
|
props: ['item'],
|
||||||
computed: {
|
computed: {
|
||||||
|
@ -17,33 +17,23 @@
|
|||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="right_actions">
|
<div class="right_actions">
|
||||||
|
<badge-entity
|
||||||
<span class="badge bg-thirdparty-child" v-if="item.result.kind == 'child'">
|
:entity="item.result"
|
||||||
{{ $t('thirdparty.child')}}
|
:options="{ displayLong: true }">
|
||||||
</span>
|
</badge-entity>
|
||||||
<span class="badge bg-thirdparty-company" v-else-if="item.result.kind == 'company'">
|
|
||||||
{{ $t('thirdparty.company')}}
|
|
||||||
</span>
|
|
||||||
<span class="badge bg-thirdparty-contact" v-else="item.result.kind == 'contact'">
|
|
||||||
{{ $t('thirdparty.contact')}}
|
|
||||||
</span>
|
|
||||||
|
|
||||||
<span class="badge rounded-pill bg-secondary" :title="item.key">
|
|
||||||
{{ $t('item.type_thirdparty') }}
|
|
||||||
</span>
|
|
||||||
|
|
||||||
<on-the-fly
|
<on-the-fly
|
||||||
type="thirdparty"
|
type="thirdparty"
|
||||||
v-bind:id="item.result.id"
|
v-bind:id="item.result.id"
|
||||||
action="show">
|
action="show">
|
||||||
</on-the-fly>
|
</on-the-fly>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import OnTheFly from 'ChillMainAssets/vuejs/OnTheFly/components/OnTheFly.vue';
|
import OnTheFly from 'ChillMainAssets/vuejs/OnTheFly/components/OnTheFly.vue';
|
||||||
|
import BadgeEntity from 'ChillMainAssets/vuejs/_components/BadgeEntity.vue';
|
||||||
|
|
||||||
const i18n = {
|
const i18n = {
|
||||||
messages: {
|
messages: {
|
||||||
@ -60,7 +50,8 @@ const i18n = {
|
|||||||
export default {
|
export default {
|
||||||
name: 'SuggestionThirdParty',
|
name: 'SuggestionThirdParty',
|
||||||
components: {
|
components: {
|
||||||
OnTheFly
|
OnTheFly,
|
||||||
|
BadgeEntity
|
||||||
},
|
},
|
||||||
props: ['item'],
|
props: ['item'],
|
||||||
i18n,
|
i18n,
|
||||||
|
@ -18,12 +18,17 @@
|
|||||||
|
|
||||||
<span class="firstname">{{ person.firstName }}</span>
|
<span class="firstname">{{ person.firstName }}</span>
|
||||||
<span class="lastname">{{ person.lastName }}</span>
|
<span class="lastname">{{ person.lastName }}</span>
|
||||||
|
<span v-if="person.deathdate" class="deathdate"> (‡)</span>
|
||||||
<span v-if="person.altNames && options.addAltNames == true" class="altnames">
|
<span v-if="person.altNames && options.addAltNames == true" class="altnames">
|
||||||
<span :class="'altname altname-' + altNameKey">{{ altNameLabel }}</span>
|
<span :class="'altname altname-' + altNameKey">{{ altNameLabel }}</span>
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
<span v-if="options.addId == true" class="id-number" :title="'n° ' + person.id">{{ person.id }}</span>
|
<span v-if="options.addId == true" class="id-number" :title="'n° ' + person.id">{{ person.id }}</span>
|
||||||
<span v-if="options.addEntity == true" class="badge rounded-pill bg-secondary">{{ $t('renderbox.person') }}</span>
|
|
||||||
|
<badge-entity v-if="options.addEntity === true"
|
||||||
|
:entity="person"
|
||||||
|
:options="{ displayLong: options.entityDisplayLong }">
|
||||||
|
</badge-entity>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -139,12 +144,14 @@
|
|||||||
import {dateToISO} from 'ChillMainAssets/chill/js/date.js';
|
import {dateToISO} from 'ChillMainAssets/chill/js/date.js';
|
||||||
import AddressRenderBox from 'ChillMainAssets/vuejs/_components/Entity/AddressRenderBox.vue';
|
import AddressRenderBox from 'ChillMainAssets/vuejs/_components/Entity/AddressRenderBox.vue';
|
||||||
import Confidential from 'ChillMainAssets/vuejs/_components/Confidential.vue';
|
import Confidential from 'ChillMainAssets/vuejs/_components/Confidential.vue';
|
||||||
|
import BadgeEntity from 'ChillMainAssets/vuejs/_components/BadgeEntity.vue';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "PersonRenderBox",
|
name: "PersonRenderBox",
|
||||||
components: {
|
components: {
|
||||||
AddressRenderBox,
|
AddressRenderBox,
|
||||||
Confidential
|
Confidential,
|
||||||
|
BadgeEntity
|
||||||
},
|
},
|
||||||
props: ['person', 'options', 'render', 'returnPath'],
|
props: ['person', 'options', 'render', 'returnPath'],
|
||||||
computed: {
|
computed: {
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
* addAge bool
|
* addAge bool
|
||||||
* addCenter bool
|
* addCenter bool
|
||||||
* hLevel integer
|
* hLevel integer
|
||||||
|
* addDeath bool
|
||||||
* address_multiline bool
|
* address_multiline bool
|
||||||
* customButtons [
|
* customButtons [
|
||||||
'before' Twig\Markup, (injected with macro)
|
'before' Twig\Markup, (injected with macro)
|
||||||
@ -24,7 +25,12 @@
|
|||||||
|
|
||||||
{% macro raw(person, options) %}
|
{% macro raw(person, options) %}
|
||||||
<span class="firstname">{{ person.firstName }}</span>
|
<span class="firstname">{{ person.firstName }}</span>
|
||||||
<span class="lastname">{{ person.lastName }}</span>
|
<span class="lastname">
|
||||||
|
{{ person.lastName }}
|
||||||
|
{%- if options['addDeath'] -%}
|
||||||
|
{% if person.deathdate is not null %} (‡){% endif %}
|
||||||
|
{% endif %}
|
||||||
|
</span>
|
||||||
{%- if options['addAltNames'] -%}
|
{%- if options['addAltNames'] -%}
|
||||||
<span class="altnames">
|
<span class="altnames">
|
||||||
{%- for n in person.altNames -%}
|
{%- for n in person.altNames -%}
|
||||||
@ -82,21 +88,17 @@
|
|||||||
{{ 'Date of death'|trans }}:
|
{{ 'Date of death'|trans }}:
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
{#- must be on one line to avoid spaces with dash -#}
|
{#- must be on one line to avoid spaces with dash -#}
|
||||||
<time datetime="{{ person.deathdate|date('Y-m-d') }}" title="{{ 'Deathdate'|trans }}">{{ person.deathdate|format_date("medium") }}</time>
|
<time datetime="{{ person.deathdate|date('Y-m-d') }}" title="{{ 'deathdate'|trans }}">{{ person.deathdate|format_date("medium") }}</time>
|
||||||
{% if options['addAge'] %}
|
{%- if options['addAge'] -%}
|
||||||
<span class="age">
|
<span class="age">{{ 'years_old'|trans({ 'age': person.age }) }}</span>
|
||||||
({{ 'years_old'|trans({ 'age': person.age }) }})
|
{%- endif -%}
|
||||||
</span>
|
|
||||||
{% endif %}
|
|
||||||
{%- elseif person.birthdate is not null -%}
|
{%- elseif person.birthdate is not null -%}
|
||||||
<time datetime="{{ person.birthdate|date('Y-m-d') }}" title="{{ 'Birthdate'|trans }}">
|
<time datetime="{{ person.birthdate|date('Y-m-d') }}" title="{{ 'Birthdate'|trans }}">
|
||||||
{{ 'Born the date'|trans({'gender': person.gender,
|
{{ 'Born the date'|trans({'gender': person.gender,
|
||||||
'birthdate': person.birthdate|format_date("medium") }) }}
|
'birthdate': person.birthdate|format_date("medium") }) }}
|
||||||
</time>
|
</time>
|
||||||
{%- if options['addAge'] -%}
|
{%- if options['addAge'] -%}
|
||||||
<span class="age">
|
<span class="age">{{- 'years_old'|trans({ 'age': person.age }) -}}</span>
|
||||||
{{- 'years_old'|trans({ 'age': person.age }) -}}
|
|
||||||
</span>
|
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
</p>
|
</p>
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
{% block title 'household.Edit household members'|trans %}
|
{% block title 'household.Edit household members'|trans %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<div class="household-members">
|
<div class="col-md-10 col-xxl household-members">
|
||||||
|
|
||||||
<h1>{{ block('title') }}</h1>
|
<h1>{{ block('title') }}</h1>
|
||||||
<div id="household_members_editor"></div>
|
<div id="household_members_editor"></div>
|
||||||
|
@ -93,9 +93,6 @@
|
|||||||
<li>
|
<li>
|
||||||
{{ form_widget(form.createPeriod, { 'attr': { 'class': 'dropdown-item' }}) }}
|
{{ form_widget(form.createPeriod, { 'attr': { 'class': 'dropdown-item' }}) }}
|
||||||
</li>
|
</li>
|
||||||
<li>
|
|
||||||
{{ form_widget(form.createHousehold, { 'attr': { 'class': 'dropdown-item' }}) }}
|
|
||||||
</li>
|
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
@ -106,5 +103,5 @@
|
|||||||
{% endblock content %}
|
{% endblock content %}
|
||||||
|
|
||||||
{% block js %}
|
{% block js %}
|
||||||
{{ encore_entry_script_tags('mod_disablebuttons') }}
|
{# {{ encore_entry_script_tags('mod_disablebuttons') }} #}
|
||||||
{% endblock js %}
|
{% endblock js %}
|
||||||
|
@ -92,6 +92,13 @@ This view should receive those arguments:
|
|||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
</dd>
|
</dd>
|
||||||
|
|
||||||
|
{%- if chill_person.fields.deathdate == 'visible' -%}
|
||||||
|
{%- if person.deathdate is not null -%}
|
||||||
|
<dt>{{ 'Date of death'|trans }} :</dt>
|
||||||
|
<dd>{{ person.deathdate|format_date('long') }}</dd>
|
||||||
|
{%- endif -%}
|
||||||
|
{%- endif -%}
|
||||||
|
|
||||||
{%- if chill_person.fields.place_of_birth == 'visible' -%}
|
{%- if chill_person.fields.place_of_birth == 'visible' -%}
|
||||||
<dt>{{ 'Place of birth'|trans }} :</dt>
|
<dt>{{ 'Place of birth'|trans }} :</dt>
|
||||||
{% if person.placeOfBirth is not empty %}
|
{% if person.placeOfBirth is not empty %}
|
||||||
@ -111,6 +118,7 @@ This view should receive those arguments:
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
{% endapply %}</dd>
|
{% endapply %}</dd>
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
|
|
||||||
</dl>
|
</dl>
|
||||||
</figure>
|
</figure>
|
||||||
</div>
|
</div>
|
||||||
@ -159,12 +167,27 @@ This view should receive those arguments:
|
|||||||
</dd>
|
</dd>
|
||||||
</dl>
|
</dl>
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
|
{%- if chill_person.fields.number_of_children == 'visible' -%}
|
||||||
|
<dl>
|
||||||
|
<dt>{{'Number of children'|trans}} :</dt>
|
||||||
|
<dd>
|
||||||
|
{% if person.numberOfChildren is not null %}
|
||||||
|
{{ person.numberOfChildren }}
|
||||||
|
{% else %}
|
||||||
|
<span class="chill-no-data-statement">{{ 'No data given'|trans }}</span>
|
||||||
|
{% endif %}
|
||||||
|
</dd>
|
||||||
|
</dl>
|
||||||
|
{%- endif -%}
|
||||||
{%- if chill_person.fields.marital_status == 'visible' -%}
|
{%- if chill_person.fields.marital_status == 'visible' -%}
|
||||||
<dl>
|
<dl>
|
||||||
<dt>{{'Marital status'|trans}} :</dt>
|
<dt>{{'Marital status'|trans}} :</dt>
|
||||||
<dd>
|
<dd>
|
||||||
{% if person.maritalStatus is not null %}
|
{% if person.maritalStatus is not null %}
|
||||||
{{ person.maritalStatus.name|localize_translatable_string }}
|
{{ person.maritalStatus.name|localize_translatable_string }}
|
||||||
|
{% if person.maritalStatusDate is not null %}
|
||||||
|
{{ 'person.from_the'|trans }} {{ person.maritalStatusDate|format_date('long') }}
|
||||||
|
{% endif %}
|
||||||
{% else %}
|
{% else %}
|
||||||
<span class="chill-no-data-statement">{{ 'No data given'|trans }}</span>
|
<span class="chill-no-data-statement">{{ 'No data given'|trans }}</span>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@ -217,6 +240,7 @@ This view should receive those arguments:
|
|||||||
<dl>
|
<dl>
|
||||||
<dt>{{ 'Mobilenumber'|trans }} :</dt>
|
<dt>{{ 'Mobilenumber'|trans }} :</dt>
|
||||||
<dd>{% if person.mobilenumber is not empty %}<a href="tel:{{ person.mobilenumber }}">{{ person.mobilenumber|chill_format_phonenumber }}</a>{% else %}<span class="chill-no-data-statement">{{ 'No data given'|trans }}{% endif %}</dd>
|
<dd>{% if person.mobilenumber is not empty %}<a href="tel:{{ person.mobilenumber }}">{{ person.mobilenumber|chill_format_phonenumber }}</a>{% else %}<span class="chill-no-data-statement">{{ 'No data given'|trans }}{% endif %}</dd>
|
||||||
|
<p>{% if person.acceptSMS %}{{ 'Accept short text message'|trans }}{% endif %}</p>
|
||||||
</dl>
|
</dl>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
|
@ -51,6 +51,7 @@ class PersonRender extends AbstractChillEntityRender
|
|||||||
'hLevel' => $options['hLevel'] ?? 3,
|
'hLevel' => $options['hLevel'] ?? 3,
|
||||||
'customButtons' => $options['customButtons'] ?? [],
|
'customButtons' => $options['customButtons'] ?? [],
|
||||||
'customArea' => $options['customArea'] ?? [],
|
'customArea' => $options['customArea'] ?? [],
|
||||||
|
'addDeath' => $options['addDeath'] ?? true,
|
||||||
];
|
];
|
||||||
|
|
||||||
return
|
return
|
||||||
|
@ -0,0 +1,14 @@
|
|||||||
|
services:
|
||||||
|
accompanying_period_social_issue_consistency_with_action:
|
||||||
|
class: 'Chill\PersonBundle\AccompanyingPeriod\SocialIssueConsistency\AccompanyingPeriodSocialIssueConsistencyEntityListener'
|
||||||
|
tags:
|
||||||
|
-
|
||||||
|
name: 'doctrine.orm.entity_listener'
|
||||||
|
event: 'prePersist'
|
||||||
|
entity: 'Chill\PersonBundle\Entity\AccompanyingPeriod\AccompanyingPeriodWork'
|
||||||
|
lazy: true
|
||||||
|
-
|
||||||
|
name: 'doctrine.orm.entity_listener'
|
||||||
|
event: 'preUpdate'
|
||||||
|
entity: 'Chill\PersonBundle\Entity\AccompanyingPeriod\AccompanyingPeriodWork'
|
||||||
|
lazy: true
|
@ -19,6 +19,7 @@ person:
|
|||||||
woman {et elle-même}
|
woman {et elle-même}
|
||||||
other {et lui·elle-même}
|
other {et lui·elle-même}
|
||||||
}
|
}
|
||||||
|
from_the: depuis le
|
||||||
|
|
||||||
household:
|
household:
|
||||||
Household: Ménage
|
Household: Ménage
|
||||||
|
@ -124,8 +124,8 @@ 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 ET 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"
|
||||||
'Add the person and create an household': "Créer la personne ET créer un ménage"
|
'Add the person and create an household': "Créer la personne & créer un ménage"
|
||||||
Show person: Voir le dossier de la personne
|
Show person: Voir le dossier de la personne
|
||||||
'Confirm the creation': 'Confirmer la création'
|
'Confirm the creation': 'Confirmer la création'
|
||||||
'You will create this person': 'Vous allez créer le dossier suivant'
|
'You will create this person': 'Vous allez créer le dossier suivant'
|
||||||
|
@ -128,6 +128,7 @@ class ThirdParty implements TrackCreationInterface, TrackUpdateInterface
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @ORM\Column(name="comment", type="text", nullable=true)
|
* @ORM\Column(name="comment", type="text", nullable=true)
|
||||||
|
* @Groups({"read"})
|
||||||
*/
|
*/
|
||||||
private ?string $comment = null;
|
private ?string $comment = null;
|
||||||
|
|
||||||
|
@ -1,16 +1,23 @@
|
|||||||
@import 'ChillMainAssets/module/bootstrap/shared';
|
@import 'ChillMainAssets/module/bootstrap/shared';
|
||||||
|
|
||||||
.badge {
|
/// Specific badge rounded-pill
|
||||||
&.bg-thirdparty-company {
|
.badge.rounded-pill {
|
||||||
//@extend .bg-info;
|
&.bg-thirdparty {
|
||||||
background-color: $yellow;
|
//@extend .$chill-ll-gray;
|
||||||
}
|
background-color: $chill-ll-gray;
|
||||||
&.bg-thirdparty-child {
|
color: $chill-pink;
|
||||||
//@extend .bg-chill-blue;
|
}
|
||||||
background-color: $chill-blue;
|
}
|
||||||
}
|
|
||||||
&.bg-thirdparty-contact {
|
/// force first column width in list
|
||||||
//@extedn .bg-secondary;
|
div.thirdparty-list {
|
||||||
background-color: $secondary;
|
div.flex-table {
|
||||||
|
div.item-bloc {
|
||||||
|
div.item-row {
|
||||||
|
div.item-col:first-child {
|
||||||
|
flex-basis: 25%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10,27 +10,16 @@
|
|||||||
<a v-if="this.options.addLink === true" href="#">
|
<a v-if="this.options.addLink === true" href="#">
|
||||||
<span class="name">{{ thirdparty.text }}</span>
|
<span class="name">{{ thirdparty.text }}</span>
|
||||||
</a>
|
</a>
|
||||||
<span class="name">{{ thirdparty.text }}</span>
|
<span class="name" v-else>{{ thirdparty.text }}</span>
|
||||||
|
|
||||||
<span class="badge bg-thirdparty-child" v-if="thirdparty.kind == 'child'">
|
<span v-if="options.addId === true" class="id-number" :title="'n° ' + thirdparty.id">
|
||||||
{{ $t('thirdparty.child')}}
|
{{ thirdparty.id }}
|
||||||
</span>
|
|
||||||
<span class="badge bg-thirdparty-company" v-else-if="thirdparty.kind == 'company'">
|
|
||||||
{{ $t('thirdparty.company')}}
|
|
||||||
</span>
|
|
||||||
<span class="badge bg-thirdparty-contact" v-else>
|
|
||||||
{{ $t('thirdparty.contact')}}
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
<span v-if="options.addId == true" class="id-number" :title="'n° ' + thirdparty.id">{{ thirdparty.id }}</span>
|
<badge-entity v-if="options.addEntity === true"
|
||||||
<span v-if="options.addEntity == true && thirdparty.type === 'thirdparty'" class="badge rounded-pill bg-secondary">{{ $t('renderbox.type.thirdparty') }}</span>
|
:entity="thirdparty"
|
||||||
|
:options="{ displayLong: options.entityDisplayLong }">
|
||||||
</div>
|
</badge-entity>
|
||||||
|
|
||||||
<div v-if="hasParent">
|
|
||||||
<span class="name tparty-parent">
|
|
||||||
> {{ thirdparty.parent.text }}
|
|
||||||
</span>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<p v-if="this.options.addInfo === true" class="moreinfo">
|
<p v-if="this.options.addInfo === true" class="moreinfo">
|
||||||
@ -38,13 +27,38 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div class="item-col">
|
<div class="item-col">
|
||||||
<div class="float-button bottom">
|
<div class="float-button bottom">
|
||||||
<div class="box">
|
<div class="box">
|
||||||
<div class="action">
|
<div class="action">
|
||||||
<slot name="record-actions"></slot>
|
<slot name="record-actions"></slot>
|
||||||
</div>
|
</div>
|
||||||
|
<ul class="list-content fa-ul">
|
||||||
|
<li v-if="hasParent">
|
||||||
|
<i class="fa fa-li fa-hand-o-right"></i>
|
||||||
|
<b class="me-2">{{ $t('child_of') }}</b>
|
||||||
|
<span class="chill-entity badge-thirdparty">{{ thirdparty.parent.text }}</span>
|
||||||
|
<!-- console: [Vue warn]: Failed to resolve component: on-the-fly ...
|
||||||
|
<on-the-fly type="thirdparty" action="show" :id="thirdparty.parent.id"
|
||||||
|
:buttonText="thirdparty.parent.text" :displayBadge="'true' === 'true'"
|
||||||
|
></on-the-fly>
|
||||||
|
-->
|
||||||
|
</li>
|
||||||
|
<!-- TODO hasChildren
|
||||||
|
<li v-if="hasChildren">
|
||||||
|
<i class="fa fa-li fa-hand-o-right"></i>
|
||||||
|
<b class="me-2">{{ $t('children') }}</b>
|
||||||
|
<span v-for="child in thirdparty.activeChildren">
|
||||||
|
<on-the-fly type="thirdparty"
|
||||||
|
action="show"
|
||||||
|
:id="child.id"
|
||||||
|
:buttonText="child.text"
|
||||||
|
displayBadge="'true' === 'true'">
|
||||||
|
</on-the-fly>
|
||||||
|
</span>
|
||||||
|
</li>
|
||||||
|
-->
|
||||||
|
</ul>
|
||||||
<confidential v-if="thirdparty.contactDataAnonymous">
|
<confidential v-if="thirdparty.contactDataAnonymous">
|
||||||
<template v-slot:confidential-content>
|
<template v-slot:confidential-content>
|
||||||
<ul class="list-content fa-ul">
|
<ul class="list-content fa-ul">
|
||||||
@ -77,6 +91,9 @@
|
|||||||
<a :href="'mailto: ' + thirdparty.email">{{ thirdparty.email }}</a>
|
<a :href="'mailto: ' + thirdparty.email">{{ thirdparty.email }}</a>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
<div v-if="options.addComment && !thirdparty.contactDataAnonymous && thirdparty.comment">
|
||||||
|
<blockquote class="chill-user-quote">{{ thirdparty.comment }}</blockquote>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -91,25 +108,24 @@
|
|||||||
import AddressRenderBox from 'ChillMainAssets/vuejs/_components/Entity/AddressRenderBox.vue';
|
import AddressRenderBox from 'ChillMainAssets/vuejs/_components/Entity/AddressRenderBox.vue';
|
||||||
import {dateToISO} from 'ChillMainAssets/chill/js/date.js';
|
import {dateToISO} from 'ChillMainAssets/chill/js/date.js';
|
||||||
import Confidential from 'ChillMainAssets/vuejs/_components/Confidential.vue';
|
import Confidential from 'ChillMainAssets/vuejs/_components/Confidential.vue';
|
||||||
|
import BadgeEntity from 'ChillMainAssets/vuejs/_components/BadgeEntity.vue';
|
||||||
const i18n = {
|
//import OnTheFly from 'ChillMainAssets/vuejs/OnTheFly/components/OnTheFly.vue';
|
||||||
messages: {
|
|
||||||
fr: {
|
|
||||||
tparty: {
|
|
||||||
contact: "Personne physique",
|
|
||||||
company: "Personne morale"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "ThirdPartyRenderBox",
|
name: "ThirdPartyRenderBox",
|
||||||
components: {
|
components: {
|
||||||
AddressRenderBox,
|
AddressRenderBox,
|
||||||
Confidential
|
Confidential,
|
||||||
|
BadgeEntity,
|
||||||
|
//OnTheFly
|
||||||
|
},
|
||||||
|
i18n: {
|
||||||
|
messages: {
|
||||||
|
fr: {
|
||||||
|
children: "Personnes de contact: ",
|
||||||
|
child_of: "Contact de: ",
|
||||||
|
}}
|
||||||
},
|
},
|
||||||
i18n,
|
|
||||||
props: ['thirdparty', 'options'],
|
props: ['thirdparty', 'options'],
|
||||||
computed: {
|
computed: {
|
||||||
isMultiline: function() {
|
isMultiline: function() {
|
||||||
@ -120,8 +136,13 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
hasParent() {
|
hasParent() {
|
||||||
return !(this.$props.thirdparty.parent === null || this.$props.thirdparty.parent === undefined);
|
return !(this.thirdparty.parent === null || this.thirdparty.parent === undefined);
|
||||||
}
|
},
|
||||||
|
/* TODO need backend normalizer to serve children without circular reference
|
||||||
|
hasChildren() {
|
||||||
|
//console.log(this.thirdparty.activeChildren.length > 0)
|
||||||
|
return false
|
||||||
|
} */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
@ -5,7 +5,8 @@
|
|||||||
:thirdparty="thirdparty"
|
:thirdparty="thirdparty"
|
||||||
:options="{
|
:options="{
|
||||||
addInfo: true,
|
addInfo: true,
|
||||||
addEntity: false,
|
addEntity: true,
|
||||||
|
entityDisplayLong: true,
|
||||||
addAltNames: true,
|
addAltNames: true,
|
||||||
addId: true,
|
addId: true,
|
||||||
addLink: false,
|
addLink: false,
|
||||||
@ -13,6 +14,7 @@
|
|||||||
hLevel: 3,
|
hLevel: 3,
|
||||||
addCenter: true,
|
addCenter: true,
|
||||||
addNoData: true,
|
addNoData: true,
|
||||||
|
addComment: true,
|
||||||
isMultiline: true
|
isMultiline: true
|
||||||
}"
|
}"
|
||||||
></third-party-render-box>
|
></third-party-render-box>
|
||||||
@ -24,7 +26,7 @@
|
|||||||
<div class="form-check">
|
<div class="form-check">
|
||||||
<input class="form-check-input mt-0" type="radio" v-model="kind" value="company" id="tpartyKindInstitution">
|
<input class="form-check-input mt-0" type="radio" v-model="kind" value="company" id="tpartyKindInstitution">
|
||||||
<label for="tpartyKindInstitution" class="required">
|
<label for="tpartyKindInstitution" class="required">
|
||||||
<span class="badge bg-thirdparty-company" style="padding-top: 0;">
|
<span class="badge rounded-pill bg-thirdparty-company" style="padding-top: 0;">
|
||||||
{{ $t('tparty.company')}}
|
{{ $t('tparty.company')}}
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
@ -32,7 +34,7 @@
|
|||||||
<div class="form-check">
|
<div class="form-check">
|
||||||
<input class="form-check-input mt-0" type="radio" v-model="kind" value="contact" id="tpartyKindContact">
|
<input class="form-check-input mt-0" type="radio" v-model="kind" value="contact" id="tpartyKindContact">
|
||||||
<label for="tpartyKindContact" class="required">
|
<label for="tpartyKindContact" class="required">
|
||||||
<span class="badge bg-thirdparty-contact" style="padding-top: 0;">
|
<span class="badge rounded-pill bg-thirdparty-contact" style="padding-top: 0;">
|
||||||
{{ $t('tparty.contact')}}
|
{{ $t('tparty.contact')}}
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
|
@ -82,7 +82,19 @@
|
|||||||
<div class="item-row entity-bloc">
|
<div class="item-row entity-bloc">
|
||||||
<div class="item-col">
|
<div class="item-col">
|
||||||
{{ _self.label(thirdparty, options) }}
|
{{ _self.label(thirdparty, options) }}
|
||||||
<span class="badge bg-thirdparty-{{ thirdparty.kind }}">{{ ('thirdparty.' ~ thirdparty.kind)|trans }}</span>
|
{% if thirdparty.kind == 'child' %}
|
||||||
|
<span class="badge rounded-pill bg-thirdparty">
|
||||||
|
<i class="fa fa-fw fa-user"></i>{{ 'thirdparty.child'|trans }}
|
||||||
|
</span>
|
||||||
|
{% elseif thirdparty.kind == 'company' %}
|
||||||
|
<span class="badge rounded-pill bg-thirdparty">
|
||||||
|
<i class="fa fa-fw fa-hospital-o"></i>{{ 'thirdparty.company'|trans }}
|
||||||
|
</span>
|
||||||
|
{% else %}
|
||||||
|
<span class="badge rounded-pill bg-thirdparty">
|
||||||
|
<i class="fa fa-fw fa-user-md"></i>{{ 'thirdparty.contact'|trans }}
|
||||||
|
</span>
|
||||||
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
<div class="item-col">
|
<div class="item-col">
|
||||||
{% if options['isConfidential'] %}
|
{% if options['isConfidential'] %}
|
||||||
@ -160,7 +172,9 @@
|
|||||||
</div>
|
</div>
|
||||||
{% if options['showContacts'] and thirdparty.activeChildren|length > 0 %}
|
{% if options['showContacts'] and thirdparty.activeChildren|length > 0 %}
|
||||||
<div class="item-row">
|
<div class="item-row">
|
||||||
{{ 'thirdparty.Children'|trans }} :
|
<div class="item-col"></div>
|
||||||
|
<div class="item-col">
|
||||||
|
<h5 class="me-2">{{ 'thirdparty.Children'|trans ~ ': ' }}</h5>
|
||||||
{% for c in thirdparty.activeChildren %}
|
{% for c in thirdparty.activeChildren %}
|
||||||
{% include '@ChillMain/OnTheFly/_insert_vue_onthefly.html.twig' with {
|
{% include '@ChillMain/OnTheFly/_insert_vue_onthefly.html.twig' with {
|
||||||
targetEntity: { name: 'thirdparty', id: c.id },
|
targetEntity: { name: 'thirdparty', id: c.id },
|
||||||
@ -170,10 +184,14 @@
|
|||||||
} %}
|
} %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if options['showParent'] and thirdparty.isChild %}
|
{% if options['showParent'] and thirdparty.isChild %}
|
||||||
<div class="item-row">
|
<div class="item-row">
|
||||||
{{ 'thirdparty.Contact of'|trans }} :
|
<div class="item-col"></div>
|
||||||
|
<div class="item-col">
|
||||||
|
<h5 class="me-2">{{ 'thirdparty.Contact of'|trans ~ ': ' }}</h5>
|
||||||
{% include '@ChillMain/OnTheFly/_insert_vue_onthefly.html.twig' with {
|
{% include '@ChillMain/OnTheFly/_insert_vue_onthefly.html.twig' with {
|
||||||
targetEntity: { name: 'thirdparty', id: thirdparty.parent.id },
|
targetEntity: { name: 'thirdparty', id: thirdparty.parent.id },
|
||||||
action: 'show',
|
action: 'show',
|
||||||
@ -181,6 +199,7 @@
|
|||||||
buttonText: thirdparty.parent|chill_entity_render_string
|
buttonText: thirdparty.parent|chill_entity_render_string
|
||||||
} %}
|
} %}
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{%- endif -%}
|
{%- endif -%}
|
||||||
|
@ -6,6 +6,26 @@
|
|||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
{% embed '@ChillMain/CRUD/_index.html.twig' %}
|
{% embed '@ChillMain/CRUD/_index.html.twig' %}
|
||||||
|
|
||||||
|
{% macro rowCustomButtons(tp) %}
|
||||||
|
{% if is_granted('CHILL_3PARTY_3PARTY_UPDATE', tp) %}
|
||||||
|
<li>
|
||||||
|
<a href="{{ chill_path_add_return_path('chill_crud_3party_3party_edit',
|
||||||
|
{ 'id': (tp.isParent ? tp.id : tp.parent.id) }) }}"
|
||||||
|
title="{{ 'Edit'|trans }}"
|
||||||
|
class="btn btn-sm btn-update"></a>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
{% if is_granted('CHILL_3PARTY_3PARTY_SHOW', tp) %}
|
||||||
|
<li>
|
||||||
|
<a href="{{ chill_path_add_return_path('chill_crud_3party_3party_view',
|
||||||
|
{ 'id': (tp.isParent ? tp.id : tp.parent.id) }) }}"
|
||||||
|
title="{{ 'Show'|trans }}"
|
||||||
|
class="btn btn-sm btn-show"></a>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
{% endmacro %}
|
||||||
|
|
||||||
{% block index_header %}
|
{% block index_header %}
|
||||||
<h1>{{ 'List of third parties'|trans }}</h1>
|
<h1>{{ 'List of third parties'|trans }}</h1>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
@ -13,37 +33,25 @@
|
|||||||
{% block table_entities %}
|
{% block table_entities %}
|
||||||
<div class="thirdparty-list my-5">
|
<div class="thirdparty-list my-5">
|
||||||
<div class="row justify-content-center">
|
<div class="row justify-content-center">
|
||||||
<div>
|
|
||||||
|
|
||||||
<label class="counter">
|
<label class="counter text-end">
|
||||||
<span>{{ paginator.totalItems }}</span> {{ 'third parties'|trans }}
|
<span>{{ paginator.totalItems }}</span> {{ 'third parties'|trans }}
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
<div class="flex-table">
|
<div class="flex-table">
|
||||||
{% for tp in third_parties %}
|
{% for tp in third_parties %}
|
||||||
<div class="item-bloc">
|
<div class="item-bloc">
|
||||||
{{ tp|chill_entity_render_box({'render': 'bloc', 'addLink': false, 'showContacts': true, 'isConfidential': (tp.contactDataAnonymous ? true : false) }) }}
|
{{ tp|chill_entity_render_box({
|
||||||
<div class="item-row separator">
|
'render': 'bloc',
|
||||||
<ul class="record_actions">
|
'showContacts': true,
|
||||||
{% if is_granted('CHILL_3PARTY_3PARTY_UPDATE', tp) %}
|
'addLink': true,
|
||||||
<li>
|
'customButtons': { 'replace': _self.rowCustomButtons(tp) },
|
||||||
<a href="{{ chill_path_add_return_path('chill_crud_3party_3party_edit',
|
'isConfidential': (tp.contactDataAnonymous ? true : false)
|
||||||
{ 'id': (tp.isParent ? tp.id : tp.parent.id) }) }}" class="btn btn-sm btn-update"></a>
|
}) }}
|
||||||
</li>
|
|
||||||
{% endif %}
|
|
||||||
{% if is_granted('CHILL_3PARTY_3PARTY_SHOW', tp) %}
|
|
||||||
<li>
|
|
||||||
<a href="{{ chill_path_add_return_path('chill_crud_3party_3party_view',
|
|
||||||
{ 'id': (tp.isParent ? tp.id : tp.parent.id) }) }}" class="btn btn-sm btn-show"></a>
|
|
||||||
</li>
|
|
||||||
{% endif %}
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
{% block crud_content_header %}
|
{% block crud_content_header %}
|
||||||
<h1>
|
<h1>
|
||||||
{{ title_ }}
|
{{ title_ }}
|
||||||
<span class="badge bg-{{ thirdParty.active ? 'success' : 'danger' }}"
|
<span class="badge bg-{{ thirdParty.active ? 'success' : 'danger' }} float-end"
|
||||||
title="{{ (thirdParty.active ? 'shown to users' : 'not shown to users')|trans }}">
|
title="{{ (thirdParty.active ? 'shown to users' : 'not shown to users')|trans }}">
|
||||||
{{ (thirdParty.active ? 'Active' : 'Inactive')|trans }}
|
{{ (thirdParty.active ? 'Active' : 'Inactive')|trans }}
|
||||||
</span>
|
</span>
|
||||||
|
@ -45,6 +45,7 @@ class ThirdPartyNormalizer implements NormalizerAwareInterface, NormalizerInterf
|
|||||||
'parent' => $this->normalizer->normalize($thirdParty->getParent(), $format, $context),
|
'parent' => $this->normalizer->normalize($thirdParty->getParent(), $format, $context),
|
||||||
'civility' => $this->normalizer->normalize($thirdParty->getCivility(), $format, $context),
|
'civility' => $this->normalizer->normalize($thirdParty->getCivility(), $format, $context),
|
||||||
'contactDataAnonymous' => $thirdParty->isContactDataAnonymous(),
|
'contactDataAnonymous' => $thirdParty->isContactDataAnonymous(),
|
||||||
|
'comment' => $thirdParty->getComment(),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user