ckgl/node_modules/vue-draggable-plus/dist/useDraggable.d.ts
2024-12-28 17:30:09 +08:00

39 lines
1.7 KiB
TypeScript

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<T = any> extends SortableEvent {
item: HTMLElement & {
[CLONE_ELEMENT_KEY]: any;
};
data: T;
clonedData: T;
}
type SortableMethod = 'closest' | 'save' | 'toArray' | 'destroy' | 'option';
export interface UseDraggableReturn extends Pick<Sortable, SortableMethod> {
/**
* 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<T> 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<T>(el: RefOrElement, list?: Ref<T[] | undefined>, options?: MaybeRef<UseDraggableOptions<T>>): UseDraggableReturn;
export declare function useDraggable<T>(el: null | undefined, list?: Ref<T[] | undefined>, options?: MaybeRef<UseDraggableOptions<T>>): UseDraggableReturn;
export declare function useDraggable<T>(el: RefOrElement<HTMLElement | null | undefined>, options?: MaybeRef<UseDraggableOptions<T>>): UseDraggableReturn;
export {};