-
Notifications
You must be signed in to change notification settings - Fork 334
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[SPIKE] Explore progressively enhanced file upload component #5305
base: main
Are you sure you want to change the base?
Conversation
📋 StatsFile sizes
Modules
View stats and visualisations on the review app Action run for 980b1c6 |
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
9113f76
to
26b05e1
Compare
26b05e1
to
8fe1f08
Compare
I've started testing this today. But I've only tested with Dragon so far. Unfortunately it doesn't work. Roughly 9 out of 10 times saying "click choose file" or "click button" only focused on the button but didn't open the file dialog. And weirdly 1 out of 10 times it did. But I didn't do anything differently between when it did and when it didn't. When we've figured out why this is happening I will test again, including in other assistive technologies. |
8fe1f08
to
d411a91
Compare
Rebased this whilst I do some local testing |
Just in case it's helpful - we had a styled upload button on the passport service - which has presumably been tested by DAC multiple times. |
@edwardhorsford Do you know if it was tested in Dragon NaturallySpeaking and, if so, whether it exhibited the same issues described by @selfthinker? |
I assume it was tested with it as DAC did the testing. But I don't recall more than that. You could try on the live service to see how it works now... |
This change is mutated by a lot of mess from me trying to make typescript not upset with me
cee7848
to
9cfd3be
Compare
Adding
|
Setting this via the `attributes` parameter raises complaints from the test that lints our HTML output. Should quieten that failing test.
Chromium actively ignores this attribute on file inputs and throws a warning in the console
6ab7ef8
to
f2bccb3
Compare
Adds a mutation observer that looks to see if the `disabled` attribute of the input changes and, if so, updates the button to match
5a0104a
to
fbc34fe
Compare
624cfa9
to
364c7b2
Compare
364c7b2
to
16960ef
Compare
Dragenter is fired only once when the drag first touches the page, whereas dragover fires continuously. As we’re only toggling the visbility of the dropzone, dragenter will suffice for our needs.
I tested this out today and spotted a few issues - apologies if you're already aware of these. Firstly with NVDA (it probably also affects other screen readers but I've only tested NVDA): With a normal With the progressively enhanced file upload, it only reads 'Choose file, button'. I think having the label read out is important, especially if it's more specific than 'Upload a file'. For example it might specify the type of file to upload - 'Upload a photo of your driving licence'. One way to resolve this could be to remove the I'm struggling to think of any other way you could preserve the desired behaviour in both NVDA and Dragon. Making the button Another issue (less serious IMO) is that the real My proposed solution doesn't solve this and I'm not sure how to get round it. Finally (unrelated to NVDA), this enhancement only works if the user interacts with another element on the page first. Chrome blocks the file dialog unless the user has interacted with the page, and apparently clicking the button via Dragon doesn't count: Dragon.enhanced.file.upload.mp4Even then, only certain interactions seem to count. In the video I say 'Click I accept', which successfully checks the checkbox, but when I then try to activate the file upload Chrome blocks it ("File chooser dialog can only be shown with a user activation."). Only when I say the full name of the checkbox ('Click I accept the terms and conditions') does Chrome then allow me to activate the upload. Dragon must be using two different techniques to check the checkbox depending on whether I abbreviate the label or not. This is likely to be quite a significant issue on one-thing-per-page-style services, where the file input may well be the only interactive thing on the page beyond the navigation. |
Hi @matteason, thanks for testing it out! We're aware of a couple of the things you've mentioned. The Being unable to open the file chooser dialog until the user has met transient activation requirements is also something we've dug into. We encountered similar issues with trying to use the Esc key when developing the Exit this Page component. In that instance we just changed the activation key, but there doesn't seem to be any consistent way of avoiding it with the file chooser, and we couldn't find any examples elsewhere that did, leading us to believe this is inherent to how Dragon interacts with webpages. Our intent is to raise an issue report with the developers of Dragon and to continue with the current solution as an imperfect improvement, with the hope that they fix the underlying problem. The need to maintain the association between the label and the button to provide context is a good point, and one that had been overlooked thus far. It'll be something to look into when the work on this resumes, hopefully in the near future. |
@matteason, unfortunately the way all of our GitHub issues belong together is a bit confusing. |
As part of post-audit investigations, a spike into layering a new UI onto the File upload component that should be a bit more friendly to assistive technologies. alphagov/govuk-design-system#4031
Note: This hasn't actually been tested across browsers and ATs yet,
Changes
multiple
,accepts
andcapture
attributes; etc.)Thoughts