-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
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
[J4.x] [UX] Subform row drag and drop is hard to use #39092
Comments
I was thinking exactly this as I read the problem. Never seen it in the wild but it would solve the ux
|
There is something like it shown here: I also think I have seen it in the wild but can't recall where. |
ah - gmail |
looks like its quite simple to do using the dragula library we have. |
Yes, but subforms appear not to be using dragula from what I can tell. (I'm not sure why.) |
🤦 |
@wilsonge @dgrammatiko do you all know why this is using it's own thing instead of dragula? It looks like it was like this in j3 but not sure when dragula was introduced. Would there be any problems in refactoring this to use dragula? |
Actually, after poking around Dragula I can see that it's not accessible and has no keyboard support. :( bevacqua/dragula#538 Every issue I open gets more complicated than I intend 🙈 |
@crystalenka check #19184 (comment) and maybe follow the whole conversation in that PR. The JS-group was aware of all the issues back in 2017 but I guess 2-3 people were not enough to do the mammoth task of dropping jQuery and making everything accessible. BTW Dracula seems to be abandoned (same goes for the shopify draggable) |
I understand. Me opening issues to address things doesn't discount the hard work done before. Just trying to make it better. :) This seems to be the most complete answer to accessible drag and drop, and it's based on dragula: https://github.com/schne324/dragon-drop However both this and dragula seem like they are no longer maintained. |
This is also an excellent resource and the up/down arrows available make it easier too for people with limited mobility in their hands: https://www.darins.page/articles/designing-a-reorderable-list-component |
Not updated doesn't necessarily = not maintained |
Brian, I know the difference and I'll say again that the project is not maintained. You can see the efforts to bring it back to life from Lea Verou: bevacqua/dragula#689 (comment) (btw I had a PR on her repo but effectively we end up forking it for our own use cases).
Yes, I maintain a private fork of that repo on top of the dragula... |
Either way, the last link I sent has a nice example of reordered lists with the minimal drop indicators etc that I mentioned; the up and down arrows would help a lot also in mitigating this issue. |
Joomla had those a decade ago and people didn't really liked the UX... Also mentioned in the original PR of subforms (quoting Brian here): #19184 (comment) |
Given that the use and implementation of subforms has evolved far from the original, I'm not sure it's fair to quote comments from 5 years ago. We've all learned quite a bit in that time, and the context of use is now different. |
Fair enough, I don't have strong opinions about the up/down buttons in this context (I think for the list views would be counterintuitive but for subforms (edit view) might be ok) About the issue here I have couple comments:
|
Just from a usage approach, I had to implement up/down arrows (which were then used most of the time) especially for large forms (when scrolling is needed) and for mobile usage. |
@wojtekxtx once again you post nonsensical text that is absolutely nothing to do with the issue here |
You talk about fields and filetypes. |
Related #37974 |
@Quy how is that related. Its a completely different issue |
That would be ideal but when using native draggable the "ghost" is actually an image representation of the item being dragged. Other than the background nothing else appears to be "stylable". Everything is controlled by the browser. At 300px it changes behaviour - see https://codepen.io/thetallweeks/pen/WNYeod |
(ps: What am I missing in that all my fields are displayed horizontally when yours are vertically) |
It switches layouts when you have 5 or more fields in a subform.
That is a true bummer. I'm sure there's a solution though... hm.
It varies by browser too—in Safari, the behavior is exactly the same on both elements. |
the only thing I found was this old post from an old old friend https://www.kryogenix.org/code/browser/custom-drag-image.html |
Actually, what he says about |
as i understand |
Adding a +1 to this one. Dragging Subforms really took a step back in usability in J4 compared to J3 :( |
Please test #42334 |
This approach is a bit reductive and I don't feel like it fully addresses the issue. Dragging and dropping is still very bad, and I don't think adding an up and down arrow is enough to call the problem solved... |
Dragging a large piece of Content is not very practical. But if people do not agree, we can reopen this issue. |
This is a usability bug. Technically it's working as designed, but it could be easier and less frustrating.
Steps to reproduce the issue
These steps talk about custom fields, but it also applies to the core subform field.
Expected result
You can clearly see where the row started and where you are putting it in the context of other rows.
Actual result
So. Much. Green. You cannot always clearly see where things are going or where you started, or drag it into positions that are not visible on the screen.
System information (as much as possible)
N/A, this has been an issue for a while.
Additional comments
A possible solution is collapsing rows into "ghost" representative rows while dragging so you can see more at once, and using a more minimal drop indicator instead of a full-height item.
This happens even when you don't have too many fields, especially if one of the fields is an editor field or an accessible media field, so it's not necessarily a matter of too many sub fields in a row.
The text was updated successfully, but these errors were encountered: