aboutsummaryrefslogtreecommitdiffstats
path: root/web_src/js/modules/sortable.ts
blob: b318386d08e0168ff328069992d2bc44232cbc09 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import type {SortableOptions, SortableEvent} from 'sortablejs';

export async function createSortable(el: Element, opts: {handle?: string} & SortableOptions = {}) {
  // @ts-expect-error: wrong type derived by typescript
  const {Sortable} = await import(/* webpackChunkName: "sortablejs" */'sortablejs');

  return new Sortable(el, {
    animation: 150,
    ghostClass: 'card-ghost',
    onChoose: (e: SortableEvent) => {
      const handle = opts.handle ? e.item.querySelector(opts.handle) : e.item;
      handle.classList.add('tw-cursor-grabbing');
      opts.onChoose?.(e);
    },
    onUnchoose: (e: SortableEvent) => {
      const handle = opts.handle ? e.item.querySelector(opts.handle) : e.item;
      handle.classList.remove('tw-cursor-grabbing');
      opts.onUnchoose?.(e);
    },
    ...opts,
  } satisfies SortableOptions);
}