Skip to content

Commit

Permalink
Merge pull request #5834 from formio/FIO-9086-time-component-default-…
Browse files Browse the repository at this point in the history
…value-validation

FIO-9086: time component default value validation
  • Loading branch information
brendanbond authored and lane-formio committed Oct 15, 2024
1 parent 97b76ec commit 6f4278d
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 6 deletions.
6 changes: 0 additions & 6 deletions src/components/time/Time.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,12 +59,6 @@ export default class TimeComponent extends TextFieldComponent {
return value;
}

get validationValue() {
if ((Array.isArray(this.rawData) && !this.rawData.length) || !this.rawData) {
return this.dataValue;
}
return this.rawData;
}

get inputInfo() {
const info = super.inputInfo;
Expand Down
26 changes: 26 additions & 0 deletions src/components/time/Time.unit.js
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,32 @@ describe('Time Component', () => {
}).catch(done);
});

it('Should return error if data in multiple time component is not valid', (done) => {
const formElement = document.createElement('div');
const form = new Webform(formElement);
form.setForm(timeForm2).then(() => {
const component = form.components[1];
Harness.setInputValue(component, 'data[multipleTime]', ['89:19']);
setTimeout(() => {
assert.equal(component.errors[0].message, 'Invalid time', 'Should have an error');
done();
}, 650);
}).catch(done);
});

it('Should not return error if data in multiple time component is not valid', (done) => {
const formElement = document.createElement('div');
const form = new Webform(formElement);
form.setForm(timeForm2).then(() => {
const component = form.components[1];
Harness.setInputValue(component, 'data[multipleTime]', ['10:00:00']);
setTimeout(() => {
assert.equal(component.errors.length, 0, 'Should not have an error');
done();
}, 650);
}).catch(done);
});

it('Should build a time component', (done) => {
Harness.testCreate(TimeComponent, comp3).then((time) => {
assert.deepEqual(time.dataValue, ['10:00:00', '11:00:00'], 'Should be set to default value');
Expand Down
9 changes: 9 additions & 0 deletions src/components/time/fixtures/timeForm2.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,15 @@ export default {
'input': true,
'inputMask': '99:99'
},
{
'label': 'Multiple Time',
'inputType': 'text',
'tableView': true,
'key': 'multipleTime',
'type': 'time',
'input': true,
'inputMask': '99:99'
},
{
'label': 'Submit',
'showValidations': false,
Expand Down

0 comments on commit 6f4278d

Please sign in to comment.