import Sortable, { type Options, type SortableEvent } from 'sortablejs'; import { type Ref } from 'vue'; import type { RefOrElement, MaybeRef } from './types'; declare const CLONE_ELEMENT_KEY: unique symbol; export interface DraggableEvent extends SortableEvent { item: HTMLElement & { [CLONE_ELEMENT_KEY]: any; }; data: T; clonedData: T; } type SortableMethod = 'closest' | 'save' | 'toArray' | 'destroy' | 'option'; export interface UseDraggableReturn extends Pick { /** * Start the sortable. * @param {HTMLElement} target - The target element to be sorted. * @default By default the root element of the VueDraggablePlus instance is used */ start: (target?: HTMLElement) => void; pause: () => void; resume: () => void; } export interface UseDraggableOptions extends Options { clone?: (element: T) => T; immediate?: boolean; customUpdate?: (event: SortableEvent) => void; } /** * A custom compositionApi utils that allows you to drag and drop elements in lists. * @param el * @param {Array} list - The list to be dragged * @param {Object} options - The options of the sortable * @returns {Object} - The return of the sortable */ export declare function useDraggable(el: RefOrElement, list?: Ref, options?: MaybeRef>): UseDraggableReturn; export declare function useDraggable(el: null | undefined, list?: Ref, options?: MaybeRef>): UseDraggableReturn; export declare function useDraggable(el: RefOrElement, options?: MaybeRef>): UseDraggableReturn; export {};