devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
208 lines (200 loc) • 7.11 kB
TypeScript
/**
* DevExtreme (ui/draggable.d.ts)
* Version: 19.2.6
* Build date: Thu Jan 30 2020
*
* Copyright (c) 2012 - 2020 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
import DOMComponent, {
DOMComponentOptions
} from '../core/dom_component';
import {
dxElement
} from '../core/element';
import {
template
} from '../core/templates/template';
import {
event
} from '../events';
import dxSortable from './sortable';
/** Warning! This type is used for internal purposes. Do not import it directly. */
export interface DraggableBaseOptions<T = DraggableBase & DOMComponent> extends DOMComponentOptions<T> {
/**
* @docid DraggableBaseOptions.autoScroll
* @type boolean
* @default true
* @prevFileNamespace DevExpress.ui
* @public
*/
autoScroll?: boolean;
/**
* @docid DraggableBaseOptions.boundary
* @type string|Node|jQuery
* @default undefined
* @prevFileNamespace DevExpress.ui
* @public
*/
boundary?: string | Element | JQuery;
/**
* @docid DraggableBaseOptions.container
* @type string|Node|jQuery
* @default undefined
* @prevFileNamespace DevExpress.ui
* @public
*/
container?: string | Element | JQuery;
/**
* @docid DraggableBaseOptions.cursorOffset
* @type string|object
* @prevFileNamespace DevExpress.ui
* @public
*/
cursorOffset?: string | { x?: number, y?: number };
/**
* @docid DraggableBaseOptions.data
* @type any
* @default undefined
* @prevFileNamespace DevExpress.ui
* @public
*/
data?: any;
/**
* @docid DraggableBaseOptions.dragDirection
* @type Enums.DragDirection
* @default "both"
* @prevFileNamespace DevExpress.ui
* @public
*/
dragDirection?: 'both' | 'horizontal' | 'vertical';
/**
* @docid DraggableBaseOptions.group
* @type string
* @default undefined
* @prevFileNamespace DevExpress.ui
* @public
*/
group?: string;
/**
* @docid DraggableBaseOptions.handle
* @type string
* @default ""
* @prevFileNamespace DevExpress.ui
* @public
*/
handle?: string;
/**
* @docid DraggableBaseOptions.scrollSensitivity
* @type number
* @default 60
* @prevFileNamespace DevExpress.ui
* @public
*/
scrollSensitivity?: number;
/**
* @docid DraggableBaseOptions.scrollSpeed
* @type number
* @default 30
* @prevFileNamespace DevExpress.ui
* @public
*/
scrollSpeed?: number;
}
/** Warning! This type is used for internal purposes. Do not import it directly. */
/** */
export interface DraggableBase { }
/** Warning! This type is used for internal purposes. Do not import it directly. */
export interface dxDraggableOptions extends DraggableBaseOptions<dxDraggable> {
/**
* @docid dxDraggableOptions.clone
* @type boolean
* @default false
* @prevFileNamespace DevExpress.ui
* @public
*/
clone?: boolean;
/**
* @docid dxDraggableOptions.dragTemplate
* @type template|function
* @type_function_param1 dragInfo:object
* @type_function_param1_field1 itemData:any
* @type_function_param1_field2 itemElement:dxElement
* @type_function_param2 containerElement:dxElement
* @type_function_return string|Node|jQuery
* @default undefined
* @prevFileNamespace DevExpress.ui
* @public
*/
dragTemplate?: template | ((dragInfo: { itemData?: any, itemElement?: dxElement }, containerElement: dxElement) => string | Element | JQuery);
/**
* @docid dxDraggableOptions.onDragEnd
* @type function(e)
* @extends Action
* @type_function_param1 e:object
* @type_function_param1_field4 event:event
* @type_function_param1_field5 cancel:boolean
* @type_function_param1_field6 itemData:any
* @type_function_param1_field7 itemElement:dxElement
* @type_function_param1_field8 fromComponent:dxSortable|dxDraggable
* @type_function_param1_field9 toComponent:dxSortable|dxDraggable
* @type_function_param1_field10 fromData:any
* @type_function_param1_field11 toData:any
* @action
* @prevFileNamespace DevExpress.ui
* @public
*/
onDragEnd?: ((e: { component?: dxDraggable, element?: dxElement, model?: any, event?: event, cancel?: boolean, itemData?: any, itemElement?: dxElement, fromComponent?: dxSortable | dxDraggable, toComponent?: dxSortable | dxDraggable, fromData?: any, toData?: any }) => any);
/**
* @docid dxDraggableOptions.onDragMove
* @type function(e)
* @extends Action
* @type_function_param1 e:object
* @type_function_param1_field4 event:event
* @type_function_param1_field5 cancel:boolean
* @type_function_param1_field6 itemData:any
* @type_function_param1_field7 itemElement:dxElement
* @type_function_param1_field8 fromComponent:dxSortable|dxDraggable
* @type_function_param1_field9 toComponent:dxSortable|dxDraggable
* @type_function_param1_field10 fromData:any
* @type_function_param1_field11 toData:any
* @action
* @prevFileNamespace DevExpress.ui
* @public
*/
onDragMove?: ((e: { component?: dxDraggable, element?: dxElement, model?: any, event?: event, cancel?: boolean, itemData?: any, itemElement?: dxElement, fromComponent?: dxSortable | dxDraggable, toComponent?: dxSortable | dxDraggable, fromData?: any, toData?: any }) => any);
/**
* @docid dxDraggableOptions.onDragStart
* @type function(e)
* @extends Action
* @type_function_param1 e:object
* @type_function_param1_field4 event:event
* @type_function_param1_field5 cancel:boolean
* @type_function_param1_field6 itemData:any
* @type_function_param1_field7 itemElement:dxElement
* @type_function_param1_field8 fromData:any
* @action
* @prevFileNamespace DevExpress.ui
* @public
*/
onDragStart?: ((e: { component?: dxDraggable, element?: dxElement, model?: any, event?: event, cancel?: boolean, itemData?: any, itemElement?: dxElement, fromData?: any }) => any);
}
/** Draggable is a user interface utility that allows widget elements to be dragged and dropped. */
export default class dxDraggable extends DOMComponent implements DraggableBase {
constructor(element: Element, options?: dxDraggableOptions)
constructor(element: JQuery, options?: dxDraggableOptions)
}
declare global {
interface JQuery {
dxDraggable(): JQuery;
dxDraggable(options: "instance"): dxDraggable;
dxDraggable(options: string): any;
dxDraggable(options: string, ...params: any[]): any;
dxDraggable(options: dxDraggableOptions): JQuery;
}
}
/** Warning! This type is used for internal purposes. Do not import it directly. */
export type Options = dxDraggableOptions;
/** @deprecated use Options instead */
/** Warning! This type is used for internal purposes. Do not import it directly. */
export type IOptions = dxDraggableOptions;