diff --git a/src/formio/components/Select.stories.js b/src/formio/components/Select.stories.js index 507c0e235..b5f867b36 100644 --- a/src/formio/components/Select.stories.js +++ b/src/formio/components/Select.stories.js @@ -1,3 +1,4 @@ +import {expect, jest} from '@storybook/jest'; import {userEvent, within} from '@storybook/test'; import {withUtrechtDocument} from 'story-utils/decorators'; @@ -131,3 +132,57 @@ export const MultilineOptions = { }, }, }; + +export const WithIntegerValues = { + render: MultipleFormioComponents, + args: { + onSubmit: jest.fn(), + components: [ + { + type: 'select', + key: 'selectWithInt', + label: 'Select with integer values', + data: { + values: [ + { + label: 'Optie 1', + value: '1', + }, + { + label: 'Optie 2', + value: '2', + }, + ], + }, + validate: { + required: true, + }, + }, + { + label: 'Submit', + showValidations: true, + key: 'submit1', + type: 'button', + input: false, + action: 'submit', + }, + ], + }, + + play: async ({canvasElement, args}) => { + args.onSubmit.mockClear(); + + const canvas = within(canvasElement); + const select = await canvas.findByLabelText('Select with integer values'); + await userEvent.click(select); + + const option = await canvas.findByText('Optie 1'); + await userEvent.click(option); + + await userEvent.click(canvas.getByText('Submit')); + + expect(args.onSubmit).toHaveBeenCalledTimes(1); + const submittedData = args.onSubmit.mock.calls[0][0]; + expect(submittedData.data).toEqual({selectWithInt: '1'}); + }, +}; diff --git a/src/formio/components/story-util.js b/src/formio/components/story-util.js index 365034d0e..c0e543bd1 100644 --- a/src/formio/components/story-util.js +++ b/src/formio/components/story-util.js @@ -11,6 +11,7 @@ const RenderFormioForm = ({ submissionData = {}, evalContext = {}, ofContext = {}, + onSubmit = () => {}, }) => { const config = useContext(ConfigContext); const formioTranslations = useContext(FormioTranslations); @@ -20,6 +21,7 @@ const RenderFormioForm = ({