From 289264e32333de1cb6570a0acec01c97dadcb937 Mon Sep 17 00:00:00 2001 From: Philipp Fritsche Date: Fri, 5 Mar 2021 20:36:24 +0100 Subject: [PATCH] fix(upload): fire input event when files change --- src/__tests__/upload.js | 26 +++++++++++++++++++++++--- src/upload.js | 7 +++++-- 2 files changed, 28 insertions(+), 5 deletions(-) diff --git a/src/__tests__/upload.js b/src/__tests__/upload.js index d1cbbba7e..f83c5a576 100644 --- a/src/__tests__/upload.js +++ b/src/__tests__/upload.js @@ -192,10 +192,30 @@ test.each([ }, ) -test('should not trigger input event for empty list', () => { - const {element, eventWasFired} = setup('') - userEvent.upload(element, []) +test('should not trigger input event when selected files are the same', () => { + const {element, eventWasFired, clearEventCalls} = setup( + '', + ) + const files = [ + new File(['hello'], 'hello.png', {type: 'image/png'}), + new File(['there'], 'there.png', {type: 'image/png'}), + ] + userEvent.upload(element, []) + expect(eventWasFired('input')).toBe(false) expect(element.files).toHaveLength(0) + + userEvent.upload(element, files) + expect(eventWasFired('input')).toBe(true) + expect(element.files).toHaveLength(2) + + clearEventCalls() + + userEvent.upload(element, files) expect(eventWasFired('input')).toBe(false) + expect(element.files).toHaveLength(2) + + userEvent.upload(element, []) + expect(eventWasFired('input')).toBe(true) + expect(element.files).toHaveLength(0) }) diff --git a/src/upload.js b/src/upload.js index db7eda9d5..0d067c44b 100644 --- a/src/upload.js +++ b/src/upload.js @@ -19,8 +19,11 @@ function upload(element, fileOrFiles, init, {applyAccept = false} = {}) { // focus fires when they make their selection focus(element, init) - // treat empty array as if the user just closed the file upload dialog - if (files.length === 0) { + // do not fire an input event if the file selection does not change + if ( + files.length === input.files.length && + files.every((f, i) => f === input.files.item(i)) + ) { return }