Skip to content

Commit

Permalink
fix(dynamic-view): ajusta renderização do multiselect
Browse files Browse the repository at this point in the history
Ajusta renderização de campo com multiplas opções.

Fixes po-ui#2308
  • Loading branch information
wsteixeira authored and anabye committed Dec 5, 2024
1 parent 9562105 commit d77f819
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,36 @@ describe('PoDynamicViewComponent:', () => {
});

describe('setFieldValue:', () => {
it(`should return the labels of the selected options if options exist and a match is found`, () => {
const field = {
value: ['value1'],
optionsMulti: true,
options: [
{ value: 'value1', label: 'label1' },
{ value: 'value2', label: 'label2' },
{ value: 'value3', label: 'label3' }
]
};

field.value = ['value1', 'value2'];
expect(component.setFieldValue(field)).toEqual(['label1', 'label2']);
});

it(`should return the field values if options exist but no match is found'`, () => {
const field = {
value: ['value1'],
optionsMulti: true,
options: [
{ value: 'value1', label: 'label1' },
{ value: 'value2', label: 'label2' },
{ value: 'value3', label: 'label3' }
]
};

field.value = ['value4'];
expect(component.setFieldValue(field)).toEqual(['value4']);
});

it(`should return the label of the selected option if options exist and a match is found`, () => {
const field = {
value: 'value1',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -85,8 +85,15 @@ export class PoDynamicViewComponent extends PoDynamicViewBaseComponent implement

setFieldValue(field) {
if (field.options) {
const selectedOption = field.options.find(option => option.value === field.value);
return selectedOption ? selectedOption.label : field.value;
if (field.optionsMulti) {
const selectedOptions = field.options.filter(
option => Array.isArray(field.value) && field.value.some(value => value === option.value)
);
return selectedOptions.length ? selectedOptions.map(option => option.label) : field.value;
} else {
const selectedOption = field.options.find(option => option.value === field.value);
return selectedOption ? selectedOption.label : field.value;
}
} else if (field.type === 'boolean' && 'booleanTrue' in field && 'booleanFalse' in field) {
return field.value ? field.booleanTrue : field.booleanFalse;
} else {
Expand Down

0 comments on commit d77f819

Please sign in to comment.