-
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
TSX types missing #68
Comments
checkout #63 |
I filed the parallel issue thisbeyond/solid-dnd-site#4 in the repository that holds the under-typed examples. It's not necessarily straightforward to fix this just because the library is in TS: giving users the types they expect is a whole extra development task compared to writing a library that's internally type-safe. |
Running into the same issue here, but I also get a bunch of warning about the "use:" attributes
|
@martinpengellyphillips any way to get around with this? |
Have you looked at #60 yet? I'm general, you should be able to use the exported types from solid-dnd to get what you need (as well as the types from solidjs for things like components). Where specifically are the types not working for you (the screenshot you share is completely untyped)? |
If you don't want to declare directives for draggable, droppable and sortable functions, you can pass them directly into the <div ref={draggable}></div> Of course, if you need the reference in another place too, the syntax becomes less plausible: let ref
<div ref={(element) => {
ref = element;
draggable(element);
}}></div> But this should still work. Perhaps it is worth to add the definitions of those directives to the package itself, because it is a common feature that potentially is and will be used in most projects with DnD? |
Here's how I fixed errors in strict mode: Specifically, the import {
closestCenter,
createSortable,
DragDropProvider,
DragDropSensors,
DragEventHandler,
DragOverlay,
Id,
SortableProvider,
useDragDropContext,
} from "@thisbeyond/solid-dnd";
import { createSignal, For } from "solid-js";
const Sortable = (props: { item: Id }) => {
const sortable = createSortable(props.item);
const context = useDragDropContext();
const state = context && context[0]; // <-- this
return (
<div
ref={sortable}
class="sortable"
classList={{
"opacity-25": sortable.isActiveDraggable,
"transition-transform": !!state?.active.draggable,
}}
>
{props.item}
</div>
);
};
export const SortableVerticalListExample = () => {
const [items, setItems] = createSignal<Id[]>([1, 2, 3]);
const [activeItem, setActiveItem] = createSignal<Id | null>(null);
const ids = () => items();
const onDragStart: DragEventHandler = ({ draggable }) =>
setActiveItem(draggable.id);
const onDragEnd: DragEventHandler = ({ draggable, droppable }) => {
if (draggable && droppable) {
const currentItems = ids();
const fromIndex = currentItems.indexOf(draggable.id);
const toIndex = currentItems.indexOf(droppable.id);
if (fromIndex !== toIndex) {
const updatedItems = currentItems.slice();
updatedItems.splice(toIndex, 0, ...updatedItems.splice(fromIndex, 1));
setItems(updatedItems);
}
}
};
return (
<DragDropProvider
onDragStart={onDragStart}
onDragEnd={onDragEnd}
collisionDetector={closestCenter}
>
<DragDropSensors />
<div class="column self-stretch">
<SortableProvider ids={ids()}>
<For each={items()}>{(item) => <Sortable item={item} />}</For>
</SortableProvider>
</div>
<DragOverlay>
<div class="sortable">{activeItem()}</div>
</DragOverlay>
</DragDropProvider>
);
}; |
Ran into problems and looked at #60 but this example fails to run with typescript strict mode.
With unhealthy amount of
any
I can compileHowever at runtime I'm getting
useDragDropContext is not a function or its return value is not iterable
error and not sure what to do. I know the lib is written in TS show I'd think the .tsx would be straight forward. Could someone ELI5 what I'm missing?The text was updated successfully, but these errors were encountered: