2024-11-21 06:57:42 -07:00
|
|
|
import type {SortableOptions, SortableEvent} from 'sortablejs';
|
2024-08-10 03:46:48 -06:00
|
|
|
|
2024-11-21 06:57:42 -07:00
|
|
|
export async function createSortable(el: HTMLElement, opts: {handle?: string} & SortableOptions = {}) {
|
|
|
|
// @ts-expect-error: wrong type derived by typescript
|
2023-07-17 12:06:37 -06:00
|
|
|
const {Sortable} = await import(/* webpackChunkName: "sortablejs" */'sortablejs');
|
2024-03-27 17:20:38 -06:00
|
|
|
|
|
|
|
return new Sortable(el, {
|
|
|
|
animation: 150,
|
|
|
|
ghostClass: 'card-ghost',
|
2024-11-21 06:57:42 -07:00
|
|
|
onChoose: (e: SortableEvent) => {
|
2024-03-27 17:20:38 -06:00
|
|
|
const handle = opts.handle ? e.item.querySelector(opts.handle) : e.item;
|
|
|
|
handle.classList.add('tw-cursor-grabbing');
|
|
|
|
opts.onChoose?.(e);
|
|
|
|
},
|
2024-11-21 06:57:42 -07:00
|
|
|
onUnchoose: (e: SortableEvent) => {
|
2024-03-27 17:20:38 -06:00
|
|
|
const handle = opts.handle ? e.item.querySelector(opts.handle) : e.item;
|
|
|
|
handle.classList.remove('tw-cursor-grabbing');
|
|
|
|
opts.onUnchoose?.(e);
|
|
|
|
},
|
|
|
|
...opts,
|
2024-08-10 03:46:48 -06:00
|
|
|
} satisfies SortableOptions);
|
2023-07-17 12:06:37 -06:00
|
|
|
}
|