Skip to content

Commit

Permalink
FIO-7632: Fixes an issue where HTML tags are added to the HTML5 Selec…
Browse files Browse the repository at this point in the history
…t metadata (#5499)

* FIO-7632: Fixes an issue where HTML tags are added to the HTML5 Select metadata

* Fixed failing tests
  • Loading branch information
alexandraRamanenka authored Feb 7, 2024
1 parent 7e1f0a4 commit 4a0b22b
Show file tree
Hide file tree
Showing 4 changed files with 137 additions and 3 deletions.
3 changes: 2 additions & 1 deletion src/components/select/Select.js
Original file line number Diff line number Diff line change
Expand Up @@ -405,6 +405,7 @@ export default class SelectComponent extends ListComponent {

/* eslint-disable max-statements */
setItems(items, fromSearch) {
this.selectItems = items;
// If the items is a string, then parse as JSON.
if (typeof items == 'string') {
try {
Expand Down Expand Up @@ -958,7 +959,7 @@ export default class SelectComponent extends ListComponent {
this.triggerUpdate(null, true);

if (this.visible) {
this.setItems(this.selectOptions || []);
this.setItems(this.selectItems || []);
}

this.focusableElement = input;
Expand Down
30 changes: 29 additions & 1 deletion src/components/select/Select.unit.js
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,8 @@ import {
comp17,
comp18,
comp19,
comp20
comp20,
comp21,
} from './fixtures';

// eslint-disable-next-line max-statements
Expand Down Expand Up @@ -949,6 +950,33 @@ describe('Select Component', () => {
}).catch(done);
});

it('Should provide correct metadata.selectData for HTML5 Select', (done) => {
const element = document.createElement('div');

Formio.createForm(element, comp21).then(form => {
const select = form.getComponent('animals');
const checkbox = form.getComponent('checkbox');
const value = 'dog';
select.setValue(value);

setTimeout(()=> {
checkbox.setValue(true);
setTimeout(() => {
const submit = form.getComponent('submit');
const clickEvent = new Event('click');
const submitBtn = submit.refs.button;
submitBtn.dispatchEvent(clickEvent);

setTimeout(() => {
const metadata = form.submission.metadata.selectData.animals2;
assert.equal(metadata.label, 'Dog');
done();
}, 200);
}, 300);
}, 200);
}).catch(done);
});

it('OnBlur validation should work properly with Select component', function(done) {
this.timeout(0);
const element = document.createElement('div');
Expand Down
104 changes: 104 additions & 0 deletions src/components/select/fixtures/comp21.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
export default {
title: 'FIO-7632',
name: 'fio7632',
path: 'fio7632',
type: 'form',
display: 'form',
components: [
{
collapsible: false,
key: 'panel',
type: 'panel',
label: 'Panel',
input: false,
tableView: false,
components: [
{
label: 'Animals',
widget: 'html5',
tableView: true,
data: {
values: [
{
label: 'Dog',
value: 'dog',
},
{
label: 'Cat',
value: 'cat',
},
{
label: 'Horse',
value: 'horse',
},
],
},
key: 'animals',
type: 'select',
input: true,
},
{
label: 'Checkbox',
tableView: false,
key: 'checkbox',
type: 'checkbox',
input: true,
},
{
label: 'Animals2',
widget: 'html5',
tableView: true,
data: {
values: [
{
label: 'Dog',
value: 'dog',
},
{
label: 'Cat',
value: 'cat',
},
{
label: 'Horse',
value: 'horse',
},
],
},
calculateValue: 'if (data.checkbox === true) {\n value = data.animals;\n}',
key: 'animals2',
logic: [
{
name: 'disable',
trigger: {
type: 'javascript',
javascript: 'result = row.checkbox === true;',
},
actions: [
{
name: 'disable',
type: 'property',
property: {
label: 'Disabled',
value: 'disabled',
type: 'boolean',
},
state: true,
},
],
},
],
type: 'select',
input: true,
},
{
type: 'button',
label: 'Submit',
key: 'submit',
disableOnInvalid: true,
input: true,
tableView: false,
},
],
},
],
};
3 changes: 2 additions & 1 deletion src/components/select/fixtures/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,4 +18,5 @@ import comp17 from './comp17';
import comp18 from './comp18';
import comp19 from './comp19';
import comp20 from './comp20';
export { comp1, comp2, comp4, comp5, comp6, comp7, comp8, comp9, comp10, comp11, comp12, comp13, comp14, comp15, comp16, comp17, comp18, comp19, comp20 };
import comp21 from './comp21';
export { comp1, comp2, comp4, comp5, comp6, comp7, comp8, comp9, comp10, comp11, comp12, comp13, comp14, comp15, comp16, comp17, comp18, comp19, comp20, comp21 };

0 comments on commit 4a0b22b

Please sign in to comment.