-
Notifications
You must be signed in to change notification settings - Fork 36
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
Keyboard interactions #76
base: main
Are you sure you want to change the base?
Conversation
* Reuse already computed transforms. * Add support for keyboard sensors. * Add support for transitions when using keyboard sensors.
Also leaving these questions / observations that I had on the code and couldn't quite understand while developing this feature:
For example, the hero that appears on the site with the dnd component is using const onDragEnd = ({ draggable, droppable }) => {
if (droppable) {
const child = droppable.node.children[0];
droppable.node.insertBefore(draggable.node, child);
setInDropZone(true);
} else if (draggable.node.parentElement !== draggablesContainer) {
draggablesContainer.append(draggable.node);
setInDropZone(false);
}
}; This is the interaction that sets the element inside of the dropzone. The issue with this approach is that before doing that it removes the |
Thanks for this - I'll take a look at it soon. |
I'll pick this up next now #80 is done. But in the meantime, I realised I hadn't answered your questions so here you go:
An example would be sortables. The droppables are transformed as part of the illusion of moving items. This needs to be distinct from draggable as the 'space' droppable for the dragged item needs to be positioned correctly as it moves.
At the point As an aside, the 'hero' example is outdated and a poor one as it manipulates the dom directly. I updated all the other examples to use Solid's reactive system more, but must have missed that one. It should be more like: export const DragAndDropExample = () => {
const [where, setWhere] = createSignal("outside");
const onDragEnd: DragEventHandler = ({ droppable }) => {
if (droppable) {
setWhere("inside");
} else {
setWhere("outside");
}
};
return (
<DragDropProvider onDragEnd={onDragEnd}>
<DragDropSensors />
<div class="min-h-15">
<Show when={where() === "outside"}>
<Draggable />
</Show>
</div>
<Droppable>
<Show when={where() === "inside"}>
<Draggable />
</Show>
</Droppable>
</DragDropProvider>
);
}; |
Thank you so much for the answers, they are absolutely clear and make a ton of sense! I see that after the merge there's conflicts to solve, so I'll be doing that when I'm available either this weekend or this following week. I've also checked a bit how dnd-kit does their aria attributes support and they use an announcement component that wraps their dnd container with a div that acts as an aria live region, where they display information on the current action inside of a node. It got me thinking on how to handle the same approach on this library, but I believe that for that to happen there's a need of the context of the conclusion of the action, therefore that would have to exist in userland, perhaps it can be achieved as another example on the site, so I'll check that in the future. If it can be generalized, it could be added to the package or as a separate dependency (although I believe accessibility is important and this is one of the few solutions for DND on solidjs, so I would go for adding the few extra bytes on the main package if it means that can be added). There should also be a PR if this is merged to change the dragabbles from divs to buttons as they are focusable elements that will allow for keyboard interactions 😁 |
…eyboard-support
* Added intersection type to avoid unnecessary casts/checks
Fixed the conflicts! |
Hi guys, I tested this and discovered that after moving a draggable with the keyboard other keyboard interactions and things broke, for example input fields losing focus automatically. Apparently adding this check fixes the issue:
|
Hi! Thanks for the cool library 😄
I was setting it up for a personal project and I noticed there weren't any keyboard interactions available, so I tried my best to set them up:
Changes:
resolvedTransform
:keydown
events (only works if the element is focusable, so the examples should be updated to reflect on these changes).transition: transform 0s
when using pointers during the interaction. This allows the user to set transitions on the element for keyboard movement (inspired by dnd-kit).I also accidentally ran into #28 when applying transitions to the elements and found a possible hack-ish solution around it for some cases (didn't get it to work with overlays, sadly, because they unmount before they can execute their transitions). Let me know if you would like to chat about it in another PR.
Caveats: