@progress/kendo-react-sortable 7.2.4-develop.2 → 7.2.4-develop.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/Sortable.js +8 -0
  2. package/Sortable.mjs +396 -0
  3. package/dist/cdn/js/kendo-react-sortable.js +8 -5
  4. package/events/PreventableEvent.js +8 -0
  5. package/events/PreventableEvent.mjs +33 -0
  6. package/events/SortableOnDragEndEvent.js +8 -0
  7. package/events/SortableOnDragEndEvent.mjs +19 -0
  8. package/events/SortableOnDragOverEvent.js +8 -0
  9. package/events/SortableOnDragOverEvent.mjs +19 -0
  10. package/events/SortableOnDragStartEvent.js +8 -0
  11. package/events/SortableOnDragStartEvent.mjs +20 -0
  12. package/events/SortableOnNavigateEvent.js +8 -0
  13. package/events/SortableOnNavigateEvent.mjs +19 -0
  14. package/index.d.mts +472 -5
  15. package/index.d.ts +472 -13
  16. package/index.js +8 -5
  17. package/index.mjs +17 -483
  18. package/messages/index.js +8 -0
  19. package/messages/index.mjs +15 -0
  20. package/package-metadata.js +8 -0
  21. package/package-metadata.mjs +19 -0
  22. package/package.json +3 -3
  23. package/utils/utils.js +8 -0
  24. package/utils/utils.mjs +51 -0
  25. package/Sortable.d.ts +0 -210
  26. package/events/BaseEvent.d.ts +0 -13
  27. package/events/PreventableEvent.d.ts +0 -22
  28. package/events/SortableOnDragEndEvent.d.ts +0 -31
  29. package/events/SortableOnDragOverEvent.d.ts +0 -31
  30. package/events/SortableOnDragStartEvent.d.ts +0 -28
  31. package/events/SortableOnNavigateEvent.d.ts +0 -31
  32. package/interfaces/SortableDefaultProps.d.ts +0 -28
  33. package/interfaces/SortableEmptyItemUIProps.d.ts +0 -13
  34. package/interfaces/SortableItemUIProps.d.ts +0 -41
  35. package/interfaces/SortableProps.d.ts +0 -63
  36. package/messages/index.d.ts +0 -14
  37. package/package-metadata.d.ts +0 -9
  38. package/utils/utils.d.ts +0 -33
package/index.d.mts CHANGED
@@ -1,5 +1,472 @@
1
- /**-----------------------------------------------------------------------------------------
2
- * Copyright © 2024 Progress Software Corporation. All rights reserved.
3
- * Licensed under commercial license. See LICENSE.md in the package root for more information
4
- *-------------------------------------------------------------------------------------------*/
5
- export * from './index';
1
+ /**
2
+ * @license
3
+ *-------------------------------------------------------------------------------------------
4
+ * Copyright © 2024 Progress Software Corporation. All rights reserved.
5
+ * Licensed under commercial license. See LICENSE.md in the package root for more information
6
+ *-------------------------------------------------------------------------------------------
7
+ */
8
+ import { DraggableDragEvent } from '@progress/kendo-react-common';
9
+ import { DraggableDragStartEvent } from '@progress/kendo-react-common';
10
+ import { DraggableReleaseEvent } from '@progress/kendo-react-common';
11
+ import { JSX as JSX_2 } from 'react/jsx-runtime';
12
+ import PropTypes from 'prop-types';
13
+ import * as React_2 from 'react';
14
+
15
+ /**
16
+ * @hidden
17
+ */
18
+ declare interface BaseEvent<T extends React.Component> {
19
+ /**
20
+ * An event target.
21
+ */
22
+ target: T;
23
+ }
24
+
25
+ /**
26
+ * @hidden
27
+ */
28
+ declare abstract class PreventableEvent {
29
+ private prevented;
30
+ /**
31
+ * Prevents the default action for a specified event.
32
+ * In this way, the source component suppresses the built-in behavior that follows the event.
33
+ */
34
+ preventDefault(): void;
35
+ /**
36
+ * Returns `true` if the event was prevented by any of its subscribers.
37
+ *
38
+ * @returns - Returns `true` if the default action was prevented.
39
+ * Otherwise, returns `false`.
40
+ */
41
+ isDefaultPrevented(): boolean;
42
+ }
43
+
44
+ export declare class Sortable extends React_2.Component<SortableProps, SortableState> {
45
+ /**
46
+ * @hidden
47
+ */
48
+ static defaultProps: SortableDefaultProps;
49
+ /**
50
+ * @hidden
51
+ */
52
+ static propTypes: {
53
+ idField: PropTypes.Validator<string>;
54
+ disabledField: PropTypes.Requireable<string>;
55
+ data: PropTypes.Validator<any[]>;
56
+ tabIndex: PropTypes.Requireable<number>;
57
+ navigation: PropTypes.Requireable<boolean>;
58
+ animation: PropTypes.Requireable<boolean>;
59
+ itemsWrapUI: PropTypes.Requireable<any>;
60
+ itemUI: PropTypes.Validator<(...args: any[]) => any>;
61
+ emptyItemUI: PropTypes.Requireable<(...args: any[]) => any>;
62
+ style: PropTypes.Requireable<object>;
63
+ className: PropTypes.Requireable<string>;
64
+ onDragStart: PropTypes.Requireable<(...args: any[]) => any>;
65
+ onDragOver: PropTypes.Requireable<(...args: any[]) => any>;
66
+ onDragEnd: PropTypes.Requireable<(...args: any[]) => any>;
67
+ onNavigate: PropTypes.Requireable<(...args: any[]) => any>;
68
+ };
69
+ /**
70
+ * @hidden
71
+ */
72
+ state: {
73
+ clientX: number;
74
+ clientY: number;
75
+ isDragging: boolean;
76
+ activeId: string;
77
+ dragCueWidth: number;
78
+ dragCueHeight: number;
79
+ };
80
+ private isRtl;
81
+ private get container();
82
+ private itemRefsMap;
83
+ private oldSizesMap;
84
+ private animatingItemMap;
85
+ private draggableRef;
86
+ private offsetParent;
87
+ private isUnmounted;
88
+ private focusActiveId;
89
+ private isKeyboardNavigated;
90
+ private isDragPrevented;
91
+ constructor(props: SortableProps);
92
+ /**
93
+ * @hidden
94
+ */
95
+ getSnapshotBeforeUpdate(): null;
96
+ /**
97
+ * @hidden
98
+ */
99
+ componentDidUpdate(previousProps: SortableProps): void;
100
+ /**
101
+ * @hidden
102
+ */
103
+ componentDidMount(): void;
104
+ /**
105
+ * @hidden
106
+ */
107
+ componentWillUnmount(): void;
108
+ /**
109
+ * @hidden
110
+ */
111
+ swapItems: (newState: object[], source: number, destination: number) => number;
112
+ /**
113
+ * @hidden
114
+ */
115
+ generateNewState: (prevIndex: number, nextIndex: number) => object[];
116
+ /**
117
+ * @hidden
118
+ */
119
+ closestSortableItem: (target: HTMLElement | null) => {
120
+ element: HTMLElement | null;
121
+ id: string;
122
+ };
123
+ /**
124
+ * @hidden
125
+ */
126
+ isSortable: (target: HTMLElement) => boolean;
127
+ /**
128
+ * @hidden
129
+ */
130
+ closestSortable: (target: HTMLElement | null) => HTMLElement | null;
131
+ /**
132
+ * @hidden
133
+ */
134
+ isSameSortable: (element: HTMLElement) => boolean;
135
+ /**
136
+ * @hidden
137
+ */
138
+ idComparer: (id1: any, id2: any) => boolean;
139
+ /**
140
+ * @hidden
141
+ */
142
+ findItem: (id: string) => object | undefined;
143
+ /**
144
+ * @hidden
145
+ */
146
+ findIndex: (id: string) => number;
147
+ /**
148
+ * @hidden
149
+ */
150
+ isItemDisabled: (item: any) => boolean;
151
+ /**
152
+ * @hidden
153
+ */
154
+ shouldResetActive: () => boolean;
155
+ /**
156
+ * @hidden
157
+ */
158
+ parentOffset(): any;
159
+ /**
160
+ * @hidden
161
+ */
162
+ widgetTarget: (target: any) => boolean;
163
+ /**
164
+ * @hidden
165
+ */
166
+ allowDrag: (target: HTMLElement) => boolean;
167
+ /**
168
+ * @hidden
169
+ */
170
+ onDragStart: (eventData: DraggableDragStartEvent) => void;
171
+ /**
172
+ * @hidden
173
+ */
174
+ onDragOver: (eventData: DraggableDragEvent) => void;
175
+ /**
176
+ * @hidden
177
+ */
178
+ onDragEnd: (eventData: DraggableReleaseEvent) => void;
179
+ /**
180
+ * @hidden
181
+ */
182
+ shouldReorder: (draggerOverElement: HTMLElement | null, clientX: number, clientY: number) => boolean | null;
183
+ /**
184
+ * @hidden
185
+ */
186
+ thresholdRect: (draggerOverElement: HTMLElement | null) => {
187
+ top: number;
188
+ left: number;
189
+ bottom: number;
190
+ right: number;
191
+ } | null;
192
+ /**
193
+ * @hidden
194
+ */
195
+ onItemBlur: () => void;
196
+ /**
197
+ * @hidden
198
+ */
199
+ onItemFocus: (event: React_2.FocusEvent<HTMLDivElement>) => void;
200
+ /**
201
+ * @hidden
202
+ */
203
+ onKeyDown: (event: React_2.KeyboardEvent<HTMLDivElement>) => void;
204
+ /**
205
+ * @hidden
206
+ */
207
+ resetState: (resetActive?: boolean) => void;
208
+ /**
209
+ * @hidden
210
+ */
211
+ renderData: () => JSX_2.Element[];
212
+ /**
213
+ * @hidden
214
+ */
215
+ renderNoData: () => JSX_2.Element | undefined;
216
+ /**
217
+ * @hidden
218
+ */
219
+ renderDragCue: () => JSX_2.Element | undefined;
220
+ /**
221
+ * @hidden
222
+ */
223
+ refAssign: (element: any, id: any) => void;
224
+ /**
225
+ * @hidden
226
+ */
227
+ draggableRefAssign: (ref: any) => void;
228
+ /**
229
+ * @hidden
230
+ */
231
+ render(): JSX_2.Element;
232
+ }
233
+
234
+ /**
235
+ * @hidden
236
+ */
237
+ declare interface SortableDefaultProps {
238
+ /**
239
+ * Specifies the tab index of the Sortable items.
240
+ */
241
+ tabIndex?: number;
242
+ /**
243
+ * Enables or disables the [keyboard navigation]({% slug keyboard_navigation_sortable %}).
244
+ * Defaults to `true`.
245
+ */
246
+ navigation?: boolean;
247
+ /**
248
+ * Enables or disables the reorder animation of the Sortable items.
249
+ * defaults to `true`.
250
+ */
251
+ animation?: boolean;
252
+ /**
253
+ * The component that is rendered when no data is available.
254
+ */
255
+ emptyItemUI?: React.ComponentType<SortableEmptyItemUIProps>;
256
+ }
257
+
258
+ /**
259
+ * Represents the props of the UI component that is rendered when no data is available.
260
+ */
261
+ export declare interface SortableEmptyItemUIProps {
262
+ /**
263
+ * The `noData` localization message.
264
+ */
265
+ message: string;
266
+ }
267
+
268
+ /**
269
+ * Represents the props of the Sortable item UI component.
270
+ */
271
+ export declare interface SortableItemUIProps {
272
+ /**
273
+ * The data object that represents the current Sortable item.
274
+ */
275
+ dataItem: any;
276
+ /**
277
+ * The flag which describes that an item is disabled.
278
+ */
279
+ isDisabled: boolean;
280
+ /**
281
+ * The flag which describes that an item is active.
282
+ */
283
+ isActive: boolean;
284
+ /**
285
+ * The flag which describes that an item is dragged.
286
+ */
287
+ isDragged: boolean;
288
+ /**
289
+ * The flag which describes that an item is rendered inside the drag cue.
290
+ */
291
+ isDragCue: boolean;
292
+ /**
293
+ * The callback function that has to be passed to the `ref` property of the first child element.
294
+ */
295
+ forwardRef?: (element: HTMLElement) => void;
296
+ /**
297
+ * The atributes that have to be passed to the first child element.
298
+ */
299
+ attributes?: any;
300
+ /**
301
+ * The CSS styles that have to be passed to the first child element.
302
+ */
303
+ style: React.CSSProperties;
304
+ }
305
+
306
+ /**
307
+ * The `SortableOnDragEndEvent` event.
308
+ */
309
+ export declare class SortableOnDragEndEvent implements BaseEvent<Sortable> {
310
+ /**
311
+ * The Sortable component.
312
+ */
313
+ target: Sortable;
314
+ /**
315
+ * The previous index of the dragged item.
316
+ */
317
+ prevIndex: number;
318
+ /**
319
+ * The new index of the dragged item.
320
+ */
321
+ nextIndex: number;
322
+ /**
323
+ * The new state of the Sortable data.
324
+ */
325
+ newState: Array<object>;
326
+ /**
327
+ * @hidden
328
+ */
329
+ constructor(target: Sortable, prevIndex: number, nextIndex: number, newState: Array<object>);
330
+ }
331
+
332
+ /**
333
+ * The `SortableOnDragOverEvent` event.
334
+ */
335
+ export declare class SortableOnDragOverEvent implements BaseEvent<Sortable> {
336
+ /**
337
+ * The Sortable component.
338
+ */
339
+ target: Sortable;
340
+ /**
341
+ * The previous index of the dragged item.
342
+ */
343
+ prevIndex: number;
344
+ /**
345
+ * The new index of the dragged item.
346
+ */
347
+ nextIndex: number;
348
+ /**
349
+ * The new state of the Sortable data.
350
+ */
351
+ newState: Array<object>;
352
+ /**
353
+ * @hidden
354
+ */
355
+ constructor(target: Sortable, prevIndex: number, nextIndex: number, newState: Array<object>);
356
+ }
357
+
358
+ /**
359
+ * The `SortableOnDragStartEvent` event.
360
+ */
361
+ export declare class SortableOnDragStartEvent extends PreventableEvent implements BaseEvent<Sortable> {
362
+ /**
363
+ * The Sortable component.
364
+ */
365
+ target: Sortable;
366
+ /**
367
+ * The target element.
368
+ */
369
+ element: HTMLElement;
370
+ /**
371
+ * The previous index of the dragged item.
372
+ */
373
+ prevIndex: number;
374
+ /**
375
+ * @hidden
376
+ */
377
+ constructor(target: Sortable, prevIndex: number, element: HTMLElement);
378
+ }
379
+
380
+ /**
381
+ * The `SortableOnNavigateEvent` event.
382
+ */
383
+ export declare class SortableOnNavigateEvent implements BaseEvent<Sortable> {
384
+ /**
385
+ * The Sortable component.
386
+ */
387
+ target: Sortable;
388
+ /**
389
+ * The previous index of the dragged item.
390
+ */
391
+ prevIndex: number;
392
+ /**
393
+ * The new index of the dragged item.
394
+ */
395
+ nextIndex: number;
396
+ /**
397
+ * The new state of the Sortable data.
398
+ */
399
+ newState: Array<object>;
400
+ /**
401
+ * @hidden
402
+ */
403
+ constructor(target: Sortable, prevIndex: number, nextIndex: number, newState: Array<object>);
404
+ }
405
+
406
+ /**
407
+ * Represents the props of the [KendoReact Sortable component]({% slug overview_sortable %}).
408
+ */
409
+ export declare interface SortableProps extends SortableDefaultProps {
410
+ /**
411
+ * (Required) The Sortable items UI.
412
+ */
413
+ itemUI: React.ComponentType<SortableItemUIProps>;
414
+ /**
415
+ * @hidden
416
+ *
417
+ * Use it to override the sortable items container component.
418
+ *
419
+ * @default 'div''
420
+ */
421
+ itemsWrapUI?: React.ForwardRefExoticComponent<any>;
422
+ /**
423
+ * (Required) The field which uniquely identifies the Sortable items.
424
+ */
425
+ idField: string;
426
+ /**
427
+ * The field which enables or disables an item.
428
+ */
429
+ disabledField?: string;
430
+ /**
431
+ * (Required) The data items of the Sortable.
432
+ */
433
+ data: Array<object>;
434
+ /**
435
+ * Defines the CSS styles which are applied to the Sortable element.
436
+ */
437
+ style?: React.CSSProperties;
438
+ /**
439
+ * Defines the CSS class which is applied to the Sortable element.
440
+ */
441
+ className?: string;
442
+ /**
443
+ * Fires when the user starts dragging an item. This event is preventable.
444
+ */
445
+ onDragStart?: (event: SortableOnDragStartEvent) => void;
446
+ /**
447
+ * Fires when the user is dragging an item over another Sortable item.
448
+ */
449
+ onDragOver?: (event: SortableOnDragOverEvent) => void;
450
+ /**
451
+ * Fires when the user stops dragging an item.
452
+ */
453
+ onDragEnd?: (event: SortableOnDragEndEvent) => void;
454
+ /**
455
+ * Fires when the user is navigates within the Srotable by using the keyboard.
456
+ */
457
+ onNavigate?: (event: SortableOnNavigateEvent) => void;
458
+ }
459
+
460
+ /**
461
+ * @hidden
462
+ */
463
+ declare interface SortableState {
464
+ clientX: number;
465
+ clientY: number;
466
+ isDragging: boolean;
467
+ activeId: string;
468
+ dragCueWidth: number;
469
+ dragCueHeight: number;
470
+ }
471
+
472
+ export { }