Files
Atay-Makhzan/web_src/js/modules/sortable.ts
T

24 lines
948 B
TypeScript
Raw Normal View History

2024-11-21 14:57:42 +01:00
import type {SortableOptions, SortableEvent} from 'sortablejs';
2024-12-19 09:37:12 +01:00
import type SortableType from 'sortablejs';
2026-02-02 01:00:34 +08:00
export async function createSortable(el: HTMLElement, opts: {handle?: string} & SortableOptions = {}): Promise<SortableType> {
// type reassigned because typescript derives the wrong type from this import
2026-03-29 12:24:30 +02:00
const {Sortable} = (await import('sortablejs') as unknown as {Sortable: typeof SortableType});
return new Sortable(el, {
animation: 150,
ghostClass: 'card-ghost',
2024-11-21 14:57:42 +01:00
onChoose: (e: SortableEvent) => {
2025-12-03 03:13:16 +01:00
const handle = opts.handle ? e.item.querySelector(opts.handle)! : e.item;
handle.classList.add('tw-cursor-grabbing');
opts.onChoose?.(e);
},
2024-11-21 14:57:42 +01:00
onUnchoose: (e: SortableEvent) => {
2025-12-03 03:13:16 +01:00
const handle = opts.handle ? e.item.querySelector(opts.handle)! : e.item;
handle.classList.remove('tw-cursor-grabbing');
opts.onUnchoose?.(e);
},
...opts,
} satisfies SortableOptions);
2023-07-17 20:06:37 +02:00
}