diff --git a/packages/form-js-viewer/src/render/components/form-fields/FilePicker.js b/packages/form-js-viewer/src/render/components/form-fields/FilePicker.js index 9b6dad040..cb644d3cd 100644 --- a/packages/form-js-viewer/src/render/components/form-fields/FilePicker.js +++ b/packages/form-js-viewer/src/render/components/form-fields/FilePicker.js @@ -1,8 +1,8 @@ import { formFieldClasses } from '../Util'; import { Label } from '../Label'; import { Errors } from '../Errors'; -import { useRef, useState } from 'preact/hooks'; -import { useSingleLineTemplateEvaluation } from '../../hooks'; +import { useEffect, useRef, useState } from 'preact/hooks'; +import { useService, useSingleLineTemplateEvaluation } from '../../hooks'; const type = 'filepicker'; @@ -28,6 +28,7 @@ export function FilePicker(props) { const fileInputRef = useRef(null); /** @type {[File[],import("preact/hooks").StateUpdater]} */ const [selectedFiles, setSelectedFiles] = useState([]); + const eventBus = useService('eventBus'); const { field, onChange, domId, errors = [], disabled, readonly, required } = props; const { label, multiple = '', accept = '', id } = field; const evaluatedAccept = useSingleLineTemplateEvaluation(accept); @@ -35,6 +36,23 @@ export function FilePicker(props) { useSingleLineTemplateEvaluation(typeof multiple === 'string' ? multiple : multiple.toString()) === 'true'; const errorMessageId = `${domId}-error-message`; + useEffect(() => { + const reset = () => { + setSelectedFiles([]); + onChange({ + value: null, + }); + }; + + eventBus.on('import.done', reset); + eventBus.on('reset', reset); + + return () => { + eventBus.off('import.done', reset); + eventBus.off('reset', reset); + }; + }, [eventBus, onChange]); + return (