uppy
uppy copied to clipboard
Single Image Mode?
Initial checklist
- [X] I understand this is a feature request and questions should be posted in the Community Forum
- [X] I searched issues and couldn’t find anything (or linked relevant results below)
Problem
Trying to use the module to create a component that allows the user to upload a profile image. Just a single file. For some reason, even if the limit is set to 1, the widget still behaves as if it should allow multiple images. Which is caused by a bunch of things:
- Even with
autoOpenFileEditor
set to true, the widget still shows the view with multiple items for a second or two before it actually opens the editor.
data:image/s3,"s3://crabby-images/c7af5/c7af5ddd11fc4bb6f2bd4860f783004990693f17" alt="image"
- After cropping an image and hitting Save, it goes back to that screen instead of skipping it.
I tried using:
.on('complete', onUploadComplete)
.on('file-editor:complete', (payload) => {
onUploadComplete({
successful: [payload],
});
})
... to get around it, but for some reason the widget still shows that for a few seconds.
Solution
When the limit is set to 1 with an image editor that has autoOpenFileEditor set to true, it should open straight up in editor mode, and when saving it should skip the "gallery" screen.
Alternatives
Maybe with some custom CSS, but it'd be super counter intuitive.
Agreed with the proposed solution.
Two things to add:
-
In this particular case (only 1 file allowed &
autoOpenFileEditor = true
) it might make sense to use the Upload button instead of the Save changes button in the editor, so it's clear the file is going to be uploaded immediately after clicking the button. -
If
autoOpenFileEditor
is false, but just one file was uploaded, it's better to show a large preview of that file instead of the gallery. We designed it some time ago, but I think it hasn't been implemented yet:
data:image/s3,"s3://crabby-images/d43e4/d43e42cae044bccbfebaee6c7168a6cfcc7d94a7" alt="image"
data:image/s3,"s3://crabby-images/af3e4/af3e406eae87e837fcf4a66bcdf7e157f4cb8db7" alt="image"
Two things to add:
May be better to hold this off until we figured out 'dashboard mini'. This mode may make more sense for that component. With the current proposed solution, it's still quite a massive dashboard with a single image, while another potential outcome is something slim. Example:
https://user-images.githubusercontent.com/9060226/186122228-7ee8f584-15e3-483e-a062-a21d882cf111.mov
But it could also be possible to have both. Either way, it requires a bit more discussion and vision before we implement.
Here's the custom flow I'm using for my app, which seems like the best UI for the user:
Step 1: Click the field that opens up the image picker.
data:image/s3,"s3://crabby-images/82b50/82b50f6fbbcb21633cff47564fa4abcf42b2c09d" alt="image"
Step 2: Drag & Drop or Click to Choose
data:image/s3,"s3://crabby-images/f1ba8/f1ba84bb4d414e9dba331c8591ef90ab9728277d" alt="image"
Step 3: Crop & Save
data:image/s3,"s3://crabby-images/a0a64/a0a644ea3d7cdf3176886eb6a1e6adaf6e873996" alt="image"
Step 4: Wait for Upload
data:image/s3,"s3://crabby-images/56b08/56b08bf1aecd0655cb9ce1dce394083c09b2373b" alt="image"
No need for extra steps like having users click the Upload button and stuff. What do you think @Murderlon @nqst
I wish it was all possible with minimal plugins / code, cause right now it's a super customized instance of Uppy + Image Editor but feels a bit 'hacky".
Thanks for the context. Like I said I think we need to discuss this internally and see how it fits in our vision of 'dashboard mini'. We'll come back on it.
I've been able to almost get this working (my source code) by adding both autoOpenFileEditor
and an uppy.upload()
to the file-editor:complete
method.
The main outstanding problem is the user can still get to the selected files grid by cancelling on the image editor pane. (I can disable the files grid altogether with showSelectedFiles: false
which would work if there was some way to remove the file from pending files when the user cancels in the editor, but as it stands, returning users to the Dashboard homescreen just leaves them with an "Upload 1 file" button and no way to back out.)
Unfortunately, the "cancel" button in the Dashboard's editor doesn't seem to fire any events I can hook into. If Dashboard fired the same file-editor:cancel
event that the image editor fires when it's being used outside of Dashboard then this last issue could be fixed, and hopefully that's quite a small change to make?
If that event existed, I'd fix it like:
uppy.on('file-editor:cancel', () => {
uppy.cancelAll()
})
Hey @Murderlon , any news on this? Thanks!
The idea of 'dashboard mini' is something I don't see us working on before February, if I'm being very honest. We have some other big projects lined up at the moment.
I see my suggested improvements to the events as a workaround is being discussed in #4045 now so I'll follow that issue for updates. I'd imagine that's a smaller fix than adding "dashboard mini" and my workaround above will be enough for me and hopefully others!
I see my suggested improvements to the events as a workaround is being discussed in #4045 now so I'll follow that issue for updates. I'd imagine that's a smaller fix than adding "dashboard mini" and my workaround above will be enough for me and hopefully others!
Yeah, that event working would be more than enough. I managed to put something together with custom hook states but it's a bit glitchy. Will keep an eye on #4045.