Add new option "as_id" to Pick*DynamicType

This option will make the app return a single id of the entity in data, and not the entity json.
This commit is contained in:
Julien Fastré 2023-11-27 13:23:36 +01:00
parent 1a9af6b0b1
commit f11f7498d7
Signed by: julienfastre
GPG Key ID: BDE2190974723FCB
5 changed files with 30 additions and 8 deletions

View File

@ -42,6 +42,7 @@ class PickUserDynamicType extends AbstractType
$view->vars['types'] = ['user']; $view->vars['types'] = ['user'];
$view->vars['uniqid'] = uniqid('pick_user_dyn'); $view->vars['uniqid'] = uniqid('pick_user_dyn');
$view->vars['suggested'] = []; $view->vars['suggested'] = [];
$view->vars['as_id'] = true === $options['as_id'] ? '1' : '0';
foreach ($options['suggested'] as $user) { foreach ($options['suggested'] as $user) {
$view->vars['suggested'][] = $this->normalizer->normalize($user, 'json', ['groups' => 'read']); $view->vars['suggested'][] = $this->normalizer->normalize($user, 'json', ['groups' => 'read']);
@ -54,7 +55,10 @@ class PickUserDynamicType extends AbstractType
->setDefault('multiple', false) ->setDefault('multiple', false)
->setAllowedTypes('multiple', ['bool']) ->setAllowedTypes('multiple', ['bool'])
->setDefault('compound', false) ->setDefault('compound', false)
->setDefault('suggested', []); ->setDefault('suggested', [])
// if set to true, only the id will be set inside the content. The denormalization will not work.
->setDefault('as_id', false)
->setAllowedTypes('as_id', ['bool']);
} }
public function getBlockPrefix() public function getBlockPrefix()

View File

@ -24,7 +24,8 @@ function loadDynamicPicker(element) {
(input.value === '[]' || input.value === '') ? (input.value === '[]' || input.value === '') ?
null : [ JSON.parse(input.value) ] null : [ JSON.parse(input.value) ]
) )
suggested = JSON.parse(el.dataset.suggested) suggested = JSON.parse(el.dataset.suggested),
as_id = parseInt(el.dataset.asId) === 1;
if (!isMultiple) { if (!isMultiple) {
if (input.value === '[]'){ if (input.value === '[]'){
@ -50,7 +51,8 @@ function loadDynamicPicker(element) {
types: JSON.parse(el.dataset.types), types: JSON.parse(el.dataset.types),
picked: picked === null ? [] : picked, picked: picked === null ? [] : picked,
uniqid: el.dataset.uniqid, uniqid: el.dataset.uniqid,
suggested: suggested suggested: suggested,
as_id: as_id,
} }
}, },
computed: { computed: {
@ -69,7 +71,12 @@ function loadDynamicPicker(element) {
return el.type === entity.type && el.id === entity.id; return el.type === entity.type && el.id === entity.id;
})) { })) {
this.picked.push(entity); this.picked.push(entity);
if (!as_id) {
input.value = JSON.stringify(this.picked); input.value = JSON.stringify(this.picked);
} else {
const ids = this.picked.map(el => el.id);
input.value = ids.join(',');
}
console.log(entity) console.log(entity)
} }
} else { } else {
@ -78,7 +85,11 @@ function loadDynamicPicker(element) {
})) { })) {
this.picked.splice(0, this.picked.length); this.picked.splice(0, this.picked.length);
this.picked.push(entity); this.picked.push(entity);
if (!as_id) {
input.value = JSON.stringify(this.picked[0]); input.value = JSON.stringify(this.picked[0]);
} else {
input.value = this.picked.map(el => el.id);
}
} }
} }
}, },

View File

@ -256,7 +256,8 @@
data-types="{{ form.vars['types']|json_encode }}" data-types="{{ form.vars['types']|json_encode }}"
data-multiple="{{ form.vars['multiple'] }}" data-multiple="{{ form.vars['multiple'] }}"
data-uniqid="{{ form.vars['uniqid'] }}" data-uniqid="{{ form.vars['uniqid'] }}"
data-suggested="{{ form.vars['suggested']|json_encode|escape('html_attr') }}"></div> data-suggested="{{ form.vars['suggested']|json_encode|escape('html_attr') }}"
data-as-id="{{ form.vars['as_id'] }}"></div>
{% endblock %} {% endblock %}
{% block pick_postal_code_widget %} {% block pick_postal_code_widget %}

View File

@ -41,6 +41,7 @@ class PickPersonDynamicType extends AbstractType
$view->vars['types'] = ['person']; $view->vars['types'] = ['person'];
$view->vars['uniqid'] = uniqid('pick_user_dyn'); $view->vars['uniqid'] = uniqid('pick_user_dyn');
$view->vars['suggested'] = []; $view->vars['suggested'] = [];
$view->vars['as_id'] = true === $options['as_id'] ? '1' : '0';
foreach ($options['suggested'] as $person) { foreach ($options['suggested'] as $person) {
$view->vars['suggested'][] = $this->normalizer->normalize($person, 'json', ['groups' => 'read']); $view->vars['suggested'][] = $this->normalizer->normalize($person, 'json', ['groups' => 'read']);
@ -53,7 +54,9 @@ class PickPersonDynamicType extends AbstractType
->setDefault('multiple', false) ->setDefault('multiple', false)
->setAllowedTypes('multiple', ['bool']) ->setAllowedTypes('multiple', ['bool'])
->setDefault('compound', false) ->setDefault('compound', false)
->setDefault('suggested', []); ->setDefault('suggested', [])
->setDefault('as_id', false)
->setAllowedTypes('as_id', ['bool']);
} }
public function getBlockPrefix() public function getBlockPrefix()

View File

@ -41,6 +41,7 @@ class PickThirdpartyDynamicType extends AbstractType
$view->vars['types'] = ['thirdparty']; $view->vars['types'] = ['thirdparty'];
$view->vars['uniqid'] = uniqid('pick_user_dyn'); $view->vars['uniqid'] = uniqid('pick_user_dyn');
$view->vars['suggested'] = []; $view->vars['suggested'] = [];
$view->vars['as_id'] = true === $options['as_id'] ? '1' : '0';
foreach ($options['suggested'] as $tp) { foreach ($options['suggested'] as $tp) {
$view->vars['suggested'][] = $this->normalizer->normalize($tp, 'json', ['groups' => 'read']); $view->vars['suggested'][] = $this->normalizer->normalize($tp, 'json', ['groups' => 'read']);
@ -53,7 +54,9 @@ class PickThirdpartyDynamicType extends AbstractType
->setDefault('multiple', false) ->setDefault('multiple', false)
->setAllowedTypes('multiple', ['bool']) ->setAllowedTypes('multiple', ['bool'])
->setDefault('compound', false) ->setDefault('compound', false)
->setDefault('suggested', []); ->setDefault('suggested', [])
->setDefault('as_id', false)
->setAllowedTypes('as_id', ['bool']);
} }
public function getBlockPrefix() public function getBlockPrefix()