Different approach to creating acpw selector

This commit is contained in:
Julie Lenaerts 2025-02-27 11:25:18 +01:00
parent 555bbca59b
commit d683fe002d
8 changed files with 103 additions and 111 deletions

View File

@ -266,27 +266,6 @@
data-label="{{ form.vars['label']|trans|escape('html_attr') }}"></div> data-label="{{ form.vars['label']|trans|escape('html_attr') }}"></div>
{% endblock %} {% endblock %}
{% block pick_linked_entities_row %}
<div class="row">
<div class="col-md-12">
{{ form_label(form) }}
{{ form_help(form) }}
</div>
</div>
<div class="row justify-content-end">
<div class="col-md-7 col-sm-12">
{{ form_widget(form) }}
</div>
</div>
{% endblock %}
{% block pick_linked_entities_widget %}
<input type="hidden" {{ block('widget_attributes') }} {% if value is not empty %}value="{{ value|escape('html_attr') }}" {% endif %} data-input-uniqid="{{ form.vars['uniqid'] }}"/>
<div data-module="pick-linked-entities"
data-suggested="{{ form.vars['suggested']|json_encode|escape('html_attr') }}"
></div>
{% endblock %}
{% block pick_postal_code_widget %} {% block pick_postal_code_widget %}
{{ form_help(form)}} {{ form_help(form)}}
<input type="hidden" {{ block('widget_attributes') }} {% if value is not empty %}value="{{ value }}" {% endif %} data-input-uniqid="{{ form.vars['uniqid'] }}"/> <input type="hidden" {{ block('widget_attributes') }} {% if value is not empty %}value="{{ value }}" {% endif %} data-input-uniqid="{{ form.vars['uniqid'] }}"/>

View File

@ -11,30 +11,38 @@ declare(strict_types=1);
namespace Chill\PersonBundle\Controller; namespace Chill\PersonBundle\Controller;
use Chill\PersonBundle\Entity\AccompanyingPeriod\AccompanyingPeriodWork;
use Chill\PersonBundle\Form\FindAccompanyingPeriodWorkType; use Chill\PersonBundle\Form\FindAccompanyingPeriodWorkType;
use Chill\PersonBundle\Repository\AccompanyingPeriod\AccompanyingPeriodWorkRepository; use Chill\PersonBundle\Repository\AccompanyingPeriod\AccompanyingPeriodWorkRepository;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\Annotation\Route; use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Serializer\Serializer;
use Symfony\Component\Serializer\SerializerInterface;
use Symfony\Contracts\Translation\TranslatorInterface; use Symfony\Contracts\Translation\TranslatorInterface;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\ParamConverter;
class AccompanyingPeriodWorkDuplicateController extends AbstractController class AccompanyingPeriodWorkDuplicateController extends AbstractController
{ {
public function __construct(private readonly AccompanyingPeriodWorkRepository $accompanyingPeriodWorkRepository, private readonly TranslatorInterface $translator) {} public function __construct(private readonly AccompanyingPeriodWorkRepository $accompanyingPeriodWorkRepository, private readonly TranslatorInterface $translator, private readonly SerializerInterface $serializer) {}
/**
* @ParamConverter("accompanyingPeriodWork", options={"id": "acpw_id"})
*/
#[Route(path: '{_locale}/person/accompanying-period/work/{id}/assign-duplicate', name: 'chill_person_accompanying_period_work_assign_duplicate', methods: ['GET'])] #[Route(path: '{_locale}/person/accompanying-period/work/{id}/assign-duplicate', name: 'chill_person_accompanying_period_work_assign_duplicate', methods: ['GET'])]
public function assignDuplicate(int $id, Request $request) public function assignDuplicate(AccompanyingPeriodWork $acpw, Request $request)
{ {
$acpw1= $this->accompanyingPeriodWorkRepository->find($id); $accompanyingPeriod = $acpw->getAccompanyingPeriod();
$accompanyingPeriod = $acpw1->getAccompanyingPeriod();
if (null === $acpw1) { $acpwList = $this->accompanyingPeriodWorkRepository->findByAccompanyingPeriod($accompanyingPeriod);
throw $this->createNotFoundException("Accompanying period work with id {$id} not".' found on this server');
} $acpwListArray = $this->serializer->normalize($acpwList, 'json', ['groups' => ['read']]);
$acpwListJson = json_encode($acpwListArray);
dump($acpwListJson);
$this->denyAccessUnlessGranted( $this->denyAccessUnlessGranted(
'CHILL_MAIN_ACCOMPANYING_PERIOD_WORK_UPDATE', 'CHILL_MAIN_ACCOMPANYING_PERIOD_WORK_UPDATE',
$acpw1, $acpw,
'You are not allowed to merge this accompanying period work' 'You are not allowed to merge this accompanying period work'
); );
@ -46,23 +54,23 @@ class AccompanyingPeriodWorkDuplicateController extends AbstractController
$acpw2 = $form->get('person')->getData(); $acpw2 = $form->get('person')->getData();
// Validation: Ensure person1 is not the same as person2 // Validation: Ensure person1 is not the same as person2
if ($acpw1->getId() === $acpw2->getId()) { if ($acpw->getId() === $acpw2->getId()) {
$this->addFlash('error', $this->translator->trans('The entities you are trying to merge cannot be the same')); $this->addFlash('error', $this->translator->trans('The entities you are trying to merge cannot be the same'));
return $this->redirectToRoute('chill_person_accompanying_period_work_show', ['id' => $acpw1->getId()]); return $this->redirectToRoute('chill_person_accompanying_period_work_show', ['id' => $acpw->getId()]);
} }
$direction = $form->get('direction')->getData(); $direction = $form->get('direction')->getData();
if ('starting' === $direction) { if ('starting' === $direction) {
$params = [ $params = [
'acpw1_id' => $acpw1->getId(), 'acpw1_id' => $acpw->getId(),
'acpw2_id' => $acpw2->getId(), 'acpw2_id' => $acpw2->getId(),
]; ];
} else { } else {
$params = [ $params = [
'acpw1_id' => $acpw2->getId(), 'acpw1_id' => $acpw2->getId(),
'acpw2_id' => $acpw1->getId(), 'acpw2_id' => $acpw->getId(),
]; ];
} }
@ -70,8 +78,9 @@ class AccompanyingPeriodWorkDuplicateController extends AbstractController
} }
return $this->render('@ChillPerson/AccompanyingPeriodWorkDuplicate/assign_acpw_duplicate.html.twig', [ return $this->render('@ChillPerson/AccompanyingPeriodWorkDuplicate/assign_acpw_duplicate.html.twig', [
'accompanyingCourse' => $acpw1->getAccompanyingPeriod(), 'accompanyingCourse' => $acpw->getAccompanyingPeriod(),
'acpw' => $acpw1, 'acpwListJson' => $acpwListJson,
'acpw' => $acpw,
'form' => $form->createView(), 'form' => $form->createView(),
]); ]);
} }

View File

@ -31,10 +31,8 @@ class FindAccompanyingPeriodWorkType extends AbstractType
$suggestedAcpw = $this->repository->findByAccompanyingPeriod($accompanyingPeriod); $suggestedAcpw = $this->repository->findByAccompanyingPeriod($accompanyingPeriod);
$builder $builder
->add('acpw', PickLinkedAccompanyingPeriodWorkType::class, [ ->add('acpw', HiddenType::class, [
'label' => 'Accompanying period work', 'label' => 'Accompanying period work',
'suggested' => $suggestedAcpw,
'multiple' => false,
]) ])
->add('direction', HiddenType::class, [ ->add('direction', HiddenType::class, [
'data' => 'starting', 'data' => 'starting',

View File

@ -1,51 +0,0 @@
<?php
namespace Chill\PersonBundle\Form\Type;
use Chill\MainBundle\Form\Type\DataTransformer\EntityToJsonTransformer;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Form\FormInterface;
use Symfony\Component\Form\FormView;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Serializer\Normalizer\DenormalizerInterface;
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
use Symfony\Component\Serializer\SerializerInterface;
class PickLinkedAccompanyingPeriodWorkType extends AbstractType
{
public function __construct(private readonly NormalizerInterface $normalizer) {}
public function buildView(FormView $view, FormInterface $form, array $options)
{
$view->vars['multiple'] = $options['multiple'];
$view->vars['types'] = ['acpw'];
$view->vars['uniqid'] = uniqid('pick_acpw_dyn');
$view->vars['suggested'] = [];
$view->vars['as_id'] = true === $options['as_id'] ? '1' : '0';
$view->vars['submit_on_adding_new_entity'] = false;
foreach ($options['suggested'] as $suggestion) {
$view->vars['suggested'][] = $this->normalizer->normalize($suggestion, 'json', ['groups' => 'read']);
}
}
public function configureOptions(OptionsResolver $resolver)
{
$resolver
->setDefault('multiple', false)
->setAllowedTypes('multiple', ['bool'])
->setDefault('compound', false)
->setDefault('suggested', [])
->setDefault('as_id', false)
->setAllowedTypes('as_id', ['bool'])
->setDefault('submit_on_adding_new_entity', false)
->setAllowedTypes('submit_on_adding_new_entity', ['bool']);
}
public function getBlockPrefix()
{
return 'pick_linked_entities';
}
}

View File

@ -1,10 +1,12 @@
import { createApp } from 'vue'; import { createApp } from 'vue';
import AccompanyingPeriodWorkSelectorModal from "../../vuejs/_components/AccompanyingPeriodWorkSelector/AccompanyingPeriodWorkSelectorModal.vue"; import AccompanyingPeriodWorkSelector from "../../vuejs/_components/DuplicateSelector/AccompanyingPeriodWorkSelector.vue";
document.addEventListener("DOMContentLoaded", () => { document.addEventListener("DOMContentLoaded", () => {
const el = document.getElementById('linked-acpw-selector'); const el = document.getElementById('linked-acpw-selector');
if (el) { if (el) {
const acpwList = JSON.parse(el.dataset.acpwList); createApp(AccompanyingPeriodWorkSelector, {
createApp(AccompanyingPeriodWorkSelectorModal, { acpwList }).mount(el); acpwList: JSON.parse(el.dataset.acpwList)
}).mount(el);
} }
}); });

View File

@ -0,0 +1,33 @@
<template>
<div>
<h3>Select an Accompanying Period Work</h3>
<ul>
<li v-for="acpw in acpwList" :key="acpw.id">
<input
type="radio"
:value="acpw.id"
v-model="selectedAcpw"
/>
<accompanying-period-work-render-box :accompanying-period-work="acpw"/>
</li>
</ul>
<!-- <input type="hidden" name="form[acpw]" :value="selectedAcpw" />-->
</div>
</template>
<script setup lang="ts">
import { ref } from "vue";
import AccompanyingPeriodWorkRenderBox from "../Entity/AccompanyingPeriodWorkRenderBox.vue";
import { AccompanyingPeriodWork } from "../../../types";
const props = defineProps<{ acpwList: AccompanyingPeriodWork[] }>();
const acpwList = props.acpwList;
const selectedAcpw = ref(null);
const selectAcpw = (id) => {
selectedAcpw.value = id;
};
</script>

View File

@ -1,22 +1,42 @@
<template> <template>
<div class="item-row"> <div class="item-row">
<div class="item-col"> <div class="item-col">
<h4 class="badge-title"> <h4 class="badge-title">
<span class="title_action"> <span class="title_action">
{{ accompanyingPeriodWork.socialAction.title.fr }}
</span>
</h4>
</div>
</div> </span>
</h4>
</div>
</div>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import TypeAccompanyingPeriodWork from "ChillPersonAssets/vuejs/_components/AddPersons/TypeAccompanyingPeriodWork.vue"; import { AccompanyingPeriodWork } from "../../../types";
const props = defineProps({ const props = defineProps<{
accompanyingPeriodWork: TypeAccompanyingPeriodWork accompanyingPeriodWork: AccompanyingPeriodWork;
}) }>();
</script> </script>
<style scoped>
.item-row {
display: flex;
padding: 10px;
border: 1px solid #ccc;
border-radius: 8px;
margin-bottom: 10px;
}
.item-col {
flex-grow: 1;
}
.badge-title {
font-size: 1.2em;
font-weight: bold;
}
.title_action {
color: #007bff;
}
</style>

View File

@ -9,8 +9,10 @@
<div class="person-duplicate"> <div class="person-duplicate">
<h1>{{ 'Assign an accompanying period work duplicate'|trans }}</h1> <h1>{{ 'Assign an accompanying period work duplicate'|trans }}</h1>
{{ form_start(form) }} {{ form_start(form) }}
{%- if form.acpw is defined -%}
<div id="linked-acpw-selector" data-acpw-list="{{ acpwListJson|raw }}"></div>
{% endif %}
{{ form_rest(form) }} {{ form_rest(form) }}
<ul class="record_actions sticky-form-buttons"> <ul class="record_actions sticky-form-buttons">
@ -30,9 +32,9 @@
{% endblock %} {% endblock %}
{% block js %} {% block js %}
{{ encore_entry_script_tags('mod_pickentity_type') }} {{ encore_entry_script_tags('mod_duplicate_selector') }}
{% endblock %} {% endblock %}
{% block css %} {% block css %}
{{ encore_entry_link_tags('mod_pickentity_type') }} {{ encore_entry_link_tags('mod_duplicate_selector') }}
{% endblock %} {% endblock %}