@vue-dnd-kit/core 1.0.0 → 1.1.0

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.
package/README.md CHANGED
@@ -67,6 +67,7 @@ The library is built with flexibility as a core principle, allowing you to imple
67
67
  ### Accessibility
68
68
 
69
69
  - ♿ **Keyboard Navigation**
70
+
70
71
  - Start and control drag operations with keyboard
71
72
  - Arrow keys for movement
72
73
  - Space/Enter for selection and dropping
@@ -74,6 +75,7 @@ The library is built with flexibility as a core principle, allowing you to imple
74
75
  - Tab navigation between draggable elements
75
76
 
76
77
  - 🔍 **Screen Reader Support**
78
+
77
79
  - ARIA attributes for drag and drop operations
78
80
  - Descriptive announcements during interactions
79
81
  - Semantic HTML structure
@@ -185,7 +187,6 @@ This will make all the components and composables globally available in your app
185
187
  ```vue
186
188
  <script setup lang="ts">
187
189
  import { ref } from 'vue';
188
- import { DragOverlay } from '@vue-dnd-kit/core';
189
190
  import Draggable from './components/Draggable.vue';
190
191
  import Droppable from './components/Droppable.vue';
191
192
 
@@ -207,8 +208,6 @@ This will make all the components and composables globally available in your app
207
208
  im in drop zone
208
209
  </Draggable>
209
210
  </Droppable>
210
-
211
- <DragOverlay />
212
211
  </div>
213
212
  </template>
214
213
  ```
@@ -303,4 +302,4 @@ This will make all the components and composables globally available in your app
303
302
  ---
304
303
 
305
304
  <p align="center">🎉 Congratulations on the official release! 🎉</p>
306
- <p align="center">Made with ❤️ for the Vue.js community</p>
305
+ <p align="center">Made with ❤️ for the Vue.js community</p>
package/dist/index.d.ts CHANGED
@@ -1889,6 +1889,615 @@ export declare const useDnDStore: () => {
1889
1889
  handleDropZoneIntersection: (action: 'add' | 'remove', element: HTMLElement | Element) => void;
1890
1890
  };
1891
1891
 
1892
+ /**
1893
+ * Hook for creating custom drag container with overlay management.
1894
+ * Provides functionality for controlling drag visualization and element positioning.
1895
+ *
1896
+ * This hook is typically used to create custom drag overlays, layers,
1897
+ * and control how dragged elements are displayed during drag operations.
1898
+ *
1899
+ * @example
1900
+ * ```vue
1901
+ * <script setup lang="ts">
1902
+ * import { computed } from 'vue';
1903
+ * import { useDragContainer } from '../composables/useDragContainer';
1904
+ *
1905
+ * const { elementRef, pointerPosition, isDragging, draggingElements } =
1906
+ * useDragContainer();
1907
+ *
1908
+ * const computedStyle = computed(() => ({
1909
+ * transform: `translate3d(${
1910
+ * (pointerPosition.current.value?.x ?? 0) -
1911
+ * (pointerPosition.offset.pixel.value?.x ?? 0)
1912
+ * }px, ${
1913
+ * (pointerPosition.current.value?.y ?? 0) -
1914
+ * (pointerPosition.offset.pixel.value?.y ?? 0)
1915
+ * }px, 0)`,
1916
+ * }));
1917
+ *</script>
1918
+ *
1919
+ *<template>
1920
+ * <Teleport to="body">
1921
+ * <div
1922
+ * v-if="isDragging"
1923
+ * ref="elementRef"
1924
+ * :style="computedStyle"
1925
+ * class="default-drag-overlay"
1926
+ * >
1927
+ * <div
1928
+ * v-for="(element, index) in draggingElements"
1929
+ * :key="index"
1930
+ * v-html="element.initialHTML"
1931
+ * :style="{
1932
+ * width: `${element.initialRect?.width}px`,
1933
+ * height: `${element.initialRect?.height}px`,
1934
+ * }"
1935
+ * />
1936
+ * </div>
1937
+ * </Teleport>
1938
+ *</template>
1939
+ *
1940
+ *<style scoped>
1941
+ * .default-drag-overlay {
1942
+ * position: fixed;
1943
+ * top: 0;
1944
+ * left: 0;
1945
+ * background-color: rgba(0, 0, 0, 0.5);
1946
+ * transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
1947
+ * z-index: 1000;
1948
+ * }
1949
+ *</style>
1950
+ *
1951
+ * ```
1952
+ *
1953
+ * @returns {Object} Container controls and state
1954
+ * @property {Ref<HTMLElement | null>} elementRef - Reference to be bound to container element
1955
+ * @property {Ref<IDragElement[]>} draggingElements - Currently dragged elements
1956
+ * @property {IPointerPosition} pointerPosition - Current pointer coordinates and offsets
1957
+ * @property {Ref<boolean>} isDragging - Whether drag operation is in progress
1958
+ */
1959
+ export declare const useDragContainer: () => {
1960
+ elementRef: Ref<HTMLElement | null, HTMLElement | null>;
1961
+ draggingElements: Ref<Map<HTMLElement | Element, {
1962
+ initialHTML: string;
1963
+ initialRect?: {
1964
+ height: number;
1965
+ width: number;
1966
+ x: number;
1967
+ y: number;
1968
+ readonly bottom: number;
1969
+ readonly left: number;
1970
+ readonly right: number;
1971
+ readonly top: number;
1972
+ toJSON: () => any;
1973
+ } | undefined;
1974
+ id: string | number;
1975
+ node: HTMLElement | Element | null;
1976
+ groups: string[];
1977
+ layer: FunctionalComponent<any, {}, any, {}> | {
1978
+ new (...args: any[]): any;
1979
+ __isFragment?: undefined;
1980
+ __isTeleport?: undefined;
1981
+ __isSuspense?: undefined;
1982
+ } | {
1983
+ [x: string]: any;
1984
+ setup?: ((this: void, props: LooseRequired<any>, ctx: {
1985
+ attrs: {
1986
+ [x: string]: unknown;
1987
+ };
1988
+ slots: Readonly<{
1989
+ [name: string]: Slot<any> | undefined;
1990
+ }>;
1991
+ emit: ((event: unknown, ...args: any[]) => void) | ((event: string, ...args: any[]) => void);
1992
+ expose: <Exposed extends Record<string, any> = Record<string, any>>(exposed?: Exposed | undefined) => void;
1993
+ }) => any) | undefined;
1994
+ name?: string | undefined;
1995
+ template?: string | object | undefined;
1996
+ render?: Function | undefined;
1997
+ components?: Record<string, Component<any, any, any, ComputedOptions, MethodOptions, {}, any>> | undefined;
1998
+ directives?: Record<string, Directive<any, any, string, string>> | undefined;
1999
+ inheritAttrs?: boolean | undefined;
2000
+ emits?: any;
2001
+ slots?: {} | undefined;
2002
+ expose?: string[] | undefined;
2003
+ serverPrefetch?: (() => void | Promise<any>) | undefined;
2004
+ compilerOptions?: {
2005
+ isCustomElement?: ((tag: string) => boolean) | undefined;
2006
+ whitespace?: "preserve" | "condense" | undefined;
2007
+ comments?: boolean | undefined;
2008
+ delimiters?: [string, string] | undefined;
2009
+ } | undefined;
2010
+ call?: ((this: unknown, ...args: unknown[]) => never) | undefined;
2011
+ __isFragment?: undefined;
2012
+ __isTeleport?: undefined;
2013
+ __isSuspense?: undefined;
2014
+ __defaults?: {} | undefined;
2015
+ compatConfig?: {
2016
+ GLOBAL_MOUNT?: boolean | "suppress-warning" | undefined;
2017
+ GLOBAL_MOUNT_CONTAINER?: boolean | "suppress-warning" | undefined;
2018
+ GLOBAL_EXTEND?: boolean | "suppress-warning" | undefined;
2019
+ GLOBAL_PROTOTYPE?: boolean | "suppress-warning" | undefined;
2020
+ GLOBAL_SET?: boolean | "suppress-warning" | undefined;
2021
+ GLOBAL_DELETE?: boolean | "suppress-warning" | undefined;
2022
+ GLOBAL_OBSERVABLE?: boolean | "suppress-warning" | undefined;
2023
+ GLOBAL_PRIVATE_UTIL?: boolean | "suppress-warning" | undefined;
2024
+ CONFIG_SILENT?: boolean | "suppress-warning" | undefined;
2025
+ CONFIG_DEVTOOLS?: boolean | "suppress-warning" | undefined;
2026
+ CONFIG_KEY_CODES?: boolean | "suppress-warning" | undefined;
2027
+ CONFIG_PRODUCTION_TIP?: boolean | "suppress-warning" | undefined;
2028
+ CONFIG_IGNORED_ELEMENTS?: boolean | "suppress-warning" | undefined;
2029
+ CONFIG_WHITESPACE?: boolean | "suppress-warning" | undefined;
2030
+ CONFIG_OPTION_MERGE_STRATS?: boolean | "suppress-warning" | undefined;
2031
+ INSTANCE_SET?: boolean | "suppress-warning" | undefined;
2032
+ INSTANCE_DELETE?: boolean | "suppress-warning" | undefined;
2033
+ INSTANCE_DESTROY?: boolean | "suppress-warning" | undefined;
2034
+ INSTANCE_EVENT_EMITTER?: boolean | "suppress-warning" | undefined;
2035
+ INSTANCE_EVENT_HOOKS?: boolean | "suppress-warning" | undefined;
2036
+ INSTANCE_CHILDREN?: boolean | "suppress-warning" | undefined;
2037
+ INSTANCE_LISTENERS?: boolean | "suppress-warning" | undefined;
2038
+ INSTANCE_SCOPED_SLOTS?: boolean | "suppress-warning" | undefined;
2039
+ INSTANCE_ATTRS_CLASS_STYLE?: boolean | "suppress-warning" | undefined;
2040
+ OPTIONS_DATA_FN?: boolean | "suppress-warning" | undefined;
2041
+ OPTIONS_DATA_MERGE?: boolean | "suppress-warning" | undefined;
2042
+ OPTIONS_BEFORE_DESTROY?: boolean | "suppress-warning" | undefined;
2043
+ OPTIONS_DESTROYED?: boolean | "suppress-warning" | undefined;
2044
+ WATCH_ARRAY?: boolean | "suppress-warning" | undefined;
2045
+ PROPS_DEFAULT_THIS?: boolean | "suppress-warning" | undefined;
2046
+ V_ON_KEYCODE_MODIFIER?: boolean | "suppress-warning" | undefined;
2047
+ CUSTOM_DIR?: boolean | "suppress-warning" | undefined;
2048
+ ATTR_FALSE_VALUE?: boolean | "suppress-warning" | undefined;
2049
+ ATTR_ENUMERATED_COERCION?: boolean | "suppress-warning" | undefined;
2050
+ TRANSITION_CLASSES?: boolean | "suppress-warning" | undefined;
2051
+ TRANSITION_GROUP_ROOT?: boolean | "suppress-warning" | undefined;
2052
+ COMPONENT_ASYNC?: boolean | "suppress-warning" | undefined;
2053
+ COMPONENT_FUNCTIONAL?: boolean | "suppress-warning" | undefined;
2054
+ COMPONENT_V_MODEL?: boolean | "suppress-warning" | undefined;
2055
+ RENDER_FUNCTION?: boolean | "suppress-warning" | undefined;
2056
+ FILTERS?: boolean | "suppress-warning" | undefined;
2057
+ PRIVATE_APIS?: boolean | "suppress-warning" | undefined;
2058
+ MODE?: 2 | 3 | ((comp: Component<any, any, any, ComputedOptions, MethodOptions, {}, any> | null) => 2 | 3) | undefined;
2059
+ } | undefined;
2060
+ data?: ((this: any, vm: any) => any) | undefined;
2061
+ computed?: ComputedOptions | undefined;
2062
+ methods?: MethodOptions | undefined;
2063
+ watch?: {
2064
+ [x: string]: (string | WatchCallback<any, any> | ({
2065
+ handler: string | WatchCallback<any, any>;
2066
+ } & WatchOptions<boolean>)) | (string | WatchCallback<any, any> | ({
2067
+ handler: string | WatchCallback<any, any>;
2068
+ } & WatchOptions<boolean>))[];
2069
+ } | undefined;
2070
+ provide?: ComponentProvideOptions | undefined;
2071
+ inject?: {} | string[] | undefined;
2072
+ filters?: Record<string, Function> | undefined;
2073
+ mixins?: any[] | undefined;
2074
+ extends?: any;
2075
+ beforeCreate?: (() => void) | undefined;
2076
+ created?: (() => void) | undefined;
2077
+ beforeMount?: (() => void) | undefined;
2078
+ mounted?: (() => void) | undefined;
2079
+ beforeUpdate?: (() => void) | undefined;
2080
+ updated?: (() => void) | undefined;
2081
+ activated?: (() => void) | undefined;
2082
+ deactivated?: (() => void) | undefined;
2083
+ beforeDestroy?: (() => void) | undefined;
2084
+ beforeUnmount?: (() => void) | undefined;
2085
+ destroyed?: (() => void) | undefined;
2086
+ unmounted?: (() => void) | undefined;
2087
+ renderTracked?: ((e: DebuggerEvent) => void) | undefined;
2088
+ renderTriggered?: ((e: DebuggerEvent) => void) | undefined;
2089
+ errorCaptured?: ((err: unknown, instance: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}, {}, {}, string, ComponentProvideOptions>, {}, {}, "", {}, any> | null, info: string) => boolean | void) | undefined;
2090
+ delimiters?: [string, string] | undefined;
2091
+ __differentiator?: string | number | symbol | undefined;
2092
+ __isBuiltIn?: boolean | undefined;
2093
+ __file?: string | undefined;
2094
+ __name?: string | undefined;
2095
+ } | null;
2096
+ defaultLayer: FunctionalComponent<any, {}, any, {}> | {
2097
+ new (...args: any[]): any;
2098
+ __isFragment?: undefined;
2099
+ __isTeleport?: undefined;
2100
+ __isSuspense?: undefined;
2101
+ } | {
2102
+ [x: string]: any;
2103
+ setup?: ((this: void, props: LooseRequired<any>, ctx: {
2104
+ attrs: {
2105
+ [x: string]: unknown;
2106
+ };
2107
+ slots: Readonly<{
2108
+ [name: string]: Slot<any> | undefined;
2109
+ }>;
2110
+ emit: ((event: unknown, ...args: any[]) => void) | ((event: string, ...args: any[]) => void);
2111
+ expose: <Exposed extends Record<string, any> = Record<string, any>>(exposed?: Exposed | undefined) => void;
2112
+ }) => any) | undefined;
2113
+ name?: string | undefined;
2114
+ template?: string | object | undefined;
2115
+ render?: Function | undefined;
2116
+ components?: Record<string, Component<any, any, any, ComputedOptions, MethodOptions, {}, any>> | undefined;
2117
+ directives?: Record<string, Directive<any, any, string, string>> | undefined;
2118
+ inheritAttrs?: boolean | undefined;
2119
+ emits?: any;
2120
+ slots?: {} | undefined;
2121
+ expose?: string[] | undefined;
2122
+ serverPrefetch?: (() => void | Promise<any>) | undefined;
2123
+ compilerOptions?: {
2124
+ isCustomElement?: ((tag: string) => boolean) | undefined;
2125
+ whitespace?: "preserve" | "condense" | undefined;
2126
+ comments?: boolean | undefined;
2127
+ delimiters?: [string, string] | undefined;
2128
+ } | undefined;
2129
+ call?: ((this: unknown, ...args: unknown[]) => never) | undefined;
2130
+ __isFragment?: undefined;
2131
+ __isTeleport?: undefined;
2132
+ __isSuspense?: undefined;
2133
+ __defaults?: {} | undefined;
2134
+ compatConfig?: {
2135
+ GLOBAL_MOUNT?: boolean | "suppress-warning" | undefined;
2136
+ GLOBAL_MOUNT_CONTAINER?: boolean | "suppress-warning" | undefined;
2137
+ GLOBAL_EXTEND?: boolean | "suppress-warning" | undefined;
2138
+ GLOBAL_PROTOTYPE?: boolean | "suppress-warning" | undefined;
2139
+ GLOBAL_SET?: boolean | "suppress-warning" | undefined;
2140
+ GLOBAL_DELETE?: boolean | "suppress-warning" | undefined;
2141
+ GLOBAL_OBSERVABLE?: boolean | "suppress-warning" | undefined;
2142
+ GLOBAL_PRIVATE_UTIL?: boolean | "suppress-warning" | undefined;
2143
+ CONFIG_SILENT?: boolean | "suppress-warning" | undefined;
2144
+ CONFIG_DEVTOOLS?: boolean | "suppress-warning" | undefined;
2145
+ CONFIG_KEY_CODES?: boolean | "suppress-warning" | undefined;
2146
+ CONFIG_PRODUCTION_TIP?: boolean | "suppress-warning" | undefined;
2147
+ CONFIG_IGNORED_ELEMENTS?: boolean | "suppress-warning" | undefined;
2148
+ CONFIG_WHITESPACE?: boolean | "suppress-warning" | undefined;
2149
+ CONFIG_OPTION_MERGE_STRATS?: boolean | "suppress-warning" | undefined;
2150
+ INSTANCE_SET?: boolean | "suppress-warning" | undefined;
2151
+ INSTANCE_DELETE?: boolean | "suppress-warning" | undefined;
2152
+ INSTANCE_DESTROY?: boolean | "suppress-warning" | undefined;
2153
+ INSTANCE_EVENT_EMITTER?: boolean | "suppress-warning" | undefined;
2154
+ INSTANCE_EVENT_HOOKS?: boolean | "suppress-warning" | undefined;
2155
+ INSTANCE_CHILDREN?: boolean | "suppress-warning" | undefined;
2156
+ INSTANCE_LISTENERS?: boolean | "suppress-warning" | undefined;
2157
+ INSTANCE_SCOPED_SLOTS?: boolean | "suppress-warning" | undefined;
2158
+ INSTANCE_ATTRS_CLASS_STYLE?: boolean | "suppress-warning" | undefined;
2159
+ OPTIONS_DATA_FN?: boolean | "suppress-warning" | undefined;
2160
+ OPTIONS_DATA_MERGE?: boolean | "suppress-warning" | undefined;
2161
+ OPTIONS_BEFORE_DESTROY?: boolean | "suppress-warning" | undefined;
2162
+ OPTIONS_DESTROYED?: boolean | "suppress-warning" | undefined;
2163
+ WATCH_ARRAY?: boolean | "suppress-warning" | undefined;
2164
+ PROPS_DEFAULT_THIS?: boolean | "suppress-warning" | undefined;
2165
+ V_ON_KEYCODE_MODIFIER?: boolean | "suppress-warning" | undefined;
2166
+ CUSTOM_DIR?: boolean | "suppress-warning" | undefined;
2167
+ ATTR_FALSE_VALUE?: boolean | "suppress-warning" | undefined;
2168
+ ATTR_ENUMERATED_COERCION?: boolean | "suppress-warning" | undefined;
2169
+ TRANSITION_CLASSES?: boolean | "suppress-warning" | undefined;
2170
+ TRANSITION_GROUP_ROOT?: boolean | "suppress-warning" | undefined;
2171
+ COMPONENT_ASYNC?: boolean | "suppress-warning" | undefined;
2172
+ COMPONENT_FUNCTIONAL?: boolean | "suppress-warning" | undefined;
2173
+ COMPONENT_V_MODEL?: boolean | "suppress-warning" | undefined;
2174
+ RENDER_FUNCTION?: boolean | "suppress-warning" | undefined;
2175
+ FILTERS?: boolean | "suppress-warning" | undefined;
2176
+ PRIVATE_APIS?: boolean | "suppress-warning" | undefined;
2177
+ MODE?: 2 | 3 | ((comp: Component<any, any, any, ComputedOptions, MethodOptions, {}, any> | null) => 2 | 3) | undefined;
2178
+ } | undefined;
2179
+ data?: ((this: any, vm: any) => any) | undefined;
2180
+ computed?: ComputedOptions | undefined;
2181
+ methods?: MethodOptions | undefined;
2182
+ watch?: {
2183
+ [x: string]: (string | WatchCallback<any, any> | ({
2184
+ handler: string | WatchCallback<any, any>;
2185
+ } & WatchOptions<boolean>)) | (string | WatchCallback<any, any> | ({
2186
+ handler: string | WatchCallback<any, any>;
2187
+ } & WatchOptions<boolean>))[];
2188
+ } | undefined;
2189
+ provide?: ComponentProvideOptions | undefined;
2190
+ inject?: {} | string[] | undefined;
2191
+ filters?: Record<string, Function> | undefined;
2192
+ mixins?: any[] | undefined;
2193
+ extends?: any;
2194
+ beforeCreate?: (() => void) | undefined;
2195
+ created?: (() => void) | undefined;
2196
+ beforeMount?: (() => void) | undefined;
2197
+ mounted?: (() => void) | undefined;
2198
+ beforeUpdate?: (() => void) | undefined;
2199
+ updated?: (() => void) | undefined;
2200
+ activated?: (() => void) | undefined;
2201
+ deactivated?: (() => void) | undefined;
2202
+ beforeDestroy?: (() => void) | undefined;
2203
+ beforeUnmount?: (() => void) | undefined;
2204
+ destroyed?: (() => void) | undefined;
2205
+ unmounted?: (() => void) | undefined;
2206
+ renderTracked?: ((e: DebuggerEvent) => void) | undefined;
2207
+ renderTriggered?: ((e: DebuggerEvent) => void) | undefined;
2208
+ errorCaptured?: ((err: unknown, instance: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}, {}, {}, string, ComponentProvideOptions>, {}, {}, "", {}, any> | null, info: string) => boolean | void) | undefined;
2209
+ delimiters?: [string, string] | undefined;
2210
+ __differentiator?: string | number | symbol | undefined;
2211
+ __isBuiltIn?: boolean | undefined;
2212
+ __file?: string | undefined;
2213
+ __name?: string | undefined;
2214
+ } | null;
2215
+ data: {
2216
+ [x: string]: any;
2217
+ source?: any[] | undefined;
2218
+ index?: number | undefined;
2219
+ } | null;
2220
+ events: {
2221
+ onHover?: ((store: IDnDStore) => void) | undefined;
2222
+ onLeave?: ((store: IDnDStore) => void) | undefined;
2223
+ onEnd?: ((store: IDnDStore) => void) | undefined;
2224
+ };
2225
+ }> & Omit<Map<HTMLElement | Element, IDraggingElement>, keyof Map<any, any>>, Map<HTMLElement | Element, IDraggingElement> | (Map<HTMLElement | Element, {
2226
+ initialHTML: string;
2227
+ initialRect?: {
2228
+ height: number;
2229
+ width: number;
2230
+ x: number;
2231
+ y: number;
2232
+ readonly bottom: number;
2233
+ readonly left: number;
2234
+ readonly right: number;
2235
+ readonly top: number;
2236
+ toJSON: () => any;
2237
+ } | undefined;
2238
+ id: string | number;
2239
+ node: HTMLElement | Element | null;
2240
+ groups: string[];
2241
+ layer: FunctionalComponent<any, {}, any, {}> | {
2242
+ new (...args: any[]): any;
2243
+ __isFragment?: undefined;
2244
+ __isTeleport?: undefined;
2245
+ __isSuspense?: undefined;
2246
+ } | {
2247
+ [x: string]: any;
2248
+ setup?: ((this: void, props: LooseRequired<any>, ctx: {
2249
+ attrs: {
2250
+ [x: string]: unknown;
2251
+ };
2252
+ slots: Readonly<{
2253
+ [name: string]: Slot<any> | undefined;
2254
+ }>;
2255
+ emit: ((event: unknown, ...args: any[]) => void) | ((event: string, ...args: any[]) => void);
2256
+ expose: <Exposed extends Record<string, any> = Record<string, any>>(exposed?: Exposed | undefined) => void;
2257
+ }) => any) | undefined;
2258
+ name?: string | undefined;
2259
+ template?: string | object | undefined;
2260
+ render?: Function | undefined;
2261
+ components?: Record<string, Component<any, any, any, ComputedOptions, MethodOptions, {}, any>> | undefined;
2262
+ directives?: Record<string, Directive<any, any, string, string>> | undefined;
2263
+ inheritAttrs?: boolean | undefined;
2264
+ emits?: any;
2265
+ slots?: {} | undefined;
2266
+ expose?: string[] | undefined;
2267
+ serverPrefetch?: (() => void | Promise<any>) | undefined;
2268
+ compilerOptions?: {
2269
+ isCustomElement?: ((tag: string) => boolean) | undefined;
2270
+ whitespace?: "preserve" | "condense" | undefined;
2271
+ comments?: boolean | undefined;
2272
+ delimiters?: [string, string] | undefined;
2273
+ } | undefined;
2274
+ call?: ((this: unknown, ...args: unknown[]) => never) | undefined;
2275
+ __isFragment?: undefined;
2276
+ __isTeleport?: undefined;
2277
+ __isSuspense?: undefined;
2278
+ __defaults?: {} | undefined;
2279
+ compatConfig?: {
2280
+ GLOBAL_MOUNT?: boolean | "suppress-warning" | undefined;
2281
+ GLOBAL_MOUNT_CONTAINER?: boolean | "suppress-warning" | undefined;
2282
+ GLOBAL_EXTEND?: boolean | "suppress-warning" | undefined;
2283
+ GLOBAL_PROTOTYPE?: boolean | "suppress-warning" | undefined;
2284
+ GLOBAL_SET?: boolean | "suppress-warning" | undefined;
2285
+ GLOBAL_DELETE?: boolean | "suppress-warning" | undefined;
2286
+ GLOBAL_OBSERVABLE?: boolean | "suppress-warning" | undefined;
2287
+ GLOBAL_PRIVATE_UTIL?: boolean | "suppress-warning" | undefined;
2288
+ CONFIG_SILENT?: boolean | "suppress-warning" | undefined;
2289
+ CONFIG_DEVTOOLS?: boolean | "suppress-warning" | undefined;
2290
+ CONFIG_KEY_CODES?: boolean | "suppress-warning" | undefined;
2291
+ CONFIG_PRODUCTION_TIP?: boolean | "suppress-warning" | undefined;
2292
+ CONFIG_IGNORED_ELEMENTS?: boolean | "suppress-warning" | undefined;
2293
+ CONFIG_WHITESPACE?: boolean | "suppress-warning" | undefined;
2294
+ CONFIG_OPTION_MERGE_STRATS?: boolean | "suppress-warning" | undefined;
2295
+ INSTANCE_SET?: boolean | "suppress-warning" | undefined;
2296
+ INSTANCE_DELETE?: boolean | "suppress-warning" | undefined;
2297
+ INSTANCE_DESTROY?: boolean | "suppress-warning" | undefined;
2298
+ INSTANCE_EVENT_EMITTER?: boolean | "suppress-warning" | undefined;
2299
+ INSTANCE_EVENT_HOOKS?: boolean | "suppress-warning" | undefined;
2300
+ INSTANCE_CHILDREN?: boolean | "suppress-warning" | undefined;
2301
+ INSTANCE_LISTENERS?: boolean | "suppress-warning" | undefined;
2302
+ INSTANCE_SCOPED_SLOTS?: boolean | "suppress-warning" | undefined;
2303
+ INSTANCE_ATTRS_CLASS_STYLE?: boolean | "suppress-warning" | undefined;
2304
+ OPTIONS_DATA_FN?: boolean | "suppress-warning" | undefined;
2305
+ OPTIONS_DATA_MERGE?: boolean | "suppress-warning" | undefined;
2306
+ OPTIONS_BEFORE_DESTROY?: boolean | "suppress-warning" | undefined;
2307
+ OPTIONS_DESTROYED?: boolean | "suppress-warning" | undefined;
2308
+ WATCH_ARRAY?: boolean | "suppress-warning" | undefined;
2309
+ PROPS_DEFAULT_THIS?: boolean | "suppress-warning" | undefined;
2310
+ V_ON_KEYCODE_MODIFIER?: boolean | "suppress-warning" | undefined;
2311
+ CUSTOM_DIR?: boolean | "suppress-warning" | undefined;
2312
+ ATTR_FALSE_VALUE?: boolean | "suppress-warning" | undefined;
2313
+ ATTR_ENUMERATED_COERCION?: boolean | "suppress-warning" | undefined;
2314
+ TRANSITION_CLASSES?: boolean | "suppress-warning" | undefined;
2315
+ TRANSITION_GROUP_ROOT?: boolean | "suppress-warning" | undefined;
2316
+ COMPONENT_ASYNC?: boolean | "suppress-warning" | undefined;
2317
+ COMPONENT_FUNCTIONAL?: boolean | "suppress-warning" | undefined;
2318
+ COMPONENT_V_MODEL?: boolean | "suppress-warning" | undefined;
2319
+ RENDER_FUNCTION?: boolean | "suppress-warning" | undefined;
2320
+ FILTERS?: boolean | "suppress-warning" | undefined;
2321
+ PRIVATE_APIS?: boolean | "suppress-warning" | undefined;
2322
+ MODE?: 2 | 3 | ((comp: Component<any, any, any, ComputedOptions, MethodOptions, {}, any> | null) => 2 | 3) | undefined;
2323
+ } | undefined;
2324
+ data?: ((this: any, vm: any) => any) | undefined;
2325
+ computed?: ComputedOptions | undefined;
2326
+ methods?: MethodOptions | undefined;
2327
+ watch?: {
2328
+ [x: string]: (string | WatchCallback<any, any> | ({
2329
+ handler: string | WatchCallback<any, any>;
2330
+ } & WatchOptions<boolean>)) | (string | WatchCallback<any, any> | ({
2331
+ handler: string | WatchCallback<any, any>;
2332
+ } & WatchOptions<boolean>))[];
2333
+ } | undefined;
2334
+ provide?: ComponentProvideOptions | undefined;
2335
+ inject?: {} | string[] | undefined;
2336
+ filters?: Record<string, Function> | undefined;
2337
+ mixins?: any[] | undefined;
2338
+ extends?: any;
2339
+ beforeCreate?: (() => void) | undefined;
2340
+ created?: (() => void) | undefined;
2341
+ beforeMount?: (() => void) | undefined;
2342
+ mounted?: (() => void) | undefined;
2343
+ beforeUpdate?: (() => void) | undefined;
2344
+ updated?: (() => void) | undefined;
2345
+ activated?: (() => void) | undefined;
2346
+ deactivated?: (() => void) | undefined;
2347
+ beforeDestroy?: (() => void) | undefined;
2348
+ beforeUnmount?: (() => void) | undefined;
2349
+ destroyed?: (() => void) | undefined;
2350
+ unmounted?: (() => void) | undefined;
2351
+ renderTracked?: ((e: DebuggerEvent) => void) | undefined;
2352
+ renderTriggered?: ((e: DebuggerEvent) => void) | undefined;
2353
+ errorCaptured?: ((err: unknown, instance: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}, {}, {}, string, ComponentProvideOptions>, {}, {}, "", {}, any> | null, info: string) => boolean | void) | undefined;
2354
+ delimiters?: [string, string] | undefined;
2355
+ __differentiator?: string | number | symbol | undefined;
2356
+ __isBuiltIn?: boolean | undefined;
2357
+ __file?: string | undefined;
2358
+ __name?: string | undefined;
2359
+ } | null;
2360
+ defaultLayer: FunctionalComponent<any, {}, any, {}> | {
2361
+ new (...args: any[]): any;
2362
+ __isFragment?: undefined;
2363
+ __isTeleport?: undefined;
2364
+ __isSuspense?: undefined;
2365
+ } | {
2366
+ [x: string]: any;
2367
+ setup?: ((this: void, props: LooseRequired<any>, ctx: {
2368
+ attrs: {
2369
+ [x: string]: unknown;
2370
+ };
2371
+ slots: Readonly<{
2372
+ [name: string]: Slot<any> | undefined;
2373
+ }>;
2374
+ emit: ((event: unknown, ...args: any[]) => void) | ((event: string, ...args: any[]) => void);
2375
+ expose: <Exposed extends Record<string, any> = Record<string, any>>(exposed?: Exposed | undefined) => void;
2376
+ }) => any) | undefined;
2377
+ name?: string | undefined;
2378
+ template?: string | object | undefined;
2379
+ render?: Function | undefined;
2380
+ components?: Record<string, Component<any, any, any, ComputedOptions, MethodOptions, {}, any>> | undefined;
2381
+ directives?: Record<string, Directive<any, any, string, string>> | undefined;
2382
+ inheritAttrs?: boolean | undefined;
2383
+ emits?: any;
2384
+ slots?: {} | undefined;
2385
+ expose?: string[] | undefined;
2386
+ serverPrefetch?: (() => void | Promise<any>) | undefined;
2387
+ compilerOptions?: {
2388
+ isCustomElement?: ((tag: string) => boolean) | undefined;
2389
+ whitespace?: "preserve" | "condense" | undefined;
2390
+ comments?: boolean | undefined;
2391
+ delimiters?: [string, string] | undefined;
2392
+ } | undefined;
2393
+ call?: ((this: unknown, ...args: unknown[]) => never) | undefined;
2394
+ __isFragment?: undefined;
2395
+ __isTeleport?: undefined;
2396
+ __isSuspense?: undefined;
2397
+ __defaults?: {} | undefined;
2398
+ compatConfig?: {
2399
+ GLOBAL_MOUNT?: boolean | "suppress-warning" | undefined;
2400
+ GLOBAL_MOUNT_CONTAINER?: boolean | "suppress-warning" | undefined;
2401
+ GLOBAL_EXTEND?: boolean | "suppress-warning" | undefined;
2402
+ GLOBAL_PROTOTYPE?: boolean | "suppress-warning" | undefined;
2403
+ GLOBAL_SET?: boolean | "suppress-warning" | undefined;
2404
+ GLOBAL_DELETE?: boolean | "suppress-warning" | undefined;
2405
+ GLOBAL_OBSERVABLE?: boolean | "suppress-warning" | undefined;
2406
+ GLOBAL_PRIVATE_UTIL?: boolean | "suppress-warning" | undefined;
2407
+ CONFIG_SILENT?: boolean | "suppress-warning" | undefined;
2408
+ CONFIG_DEVTOOLS?: boolean | "suppress-warning" | undefined;
2409
+ CONFIG_KEY_CODES?: boolean | "suppress-warning" | undefined;
2410
+ CONFIG_PRODUCTION_TIP?: boolean | "suppress-warning" | undefined;
2411
+ CONFIG_IGNORED_ELEMENTS?: boolean | "suppress-warning" | undefined;
2412
+ CONFIG_WHITESPACE?: boolean | "suppress-warning" | undefined;
2413
+ CONFIG_OPTION_MERGE_STRATS?: boolean | "suppress-warning" | undefined;
2414
+ INSTANCE_SET?: boolean | "suppress-warning" | undefined;
2415
+ INSTANCE_DELETE?: boolean | "suppress-warning" | undefined;
2416
+ INSTANCE_DESTROY?: boolean | "suppress-warning" | undefined;
2417
+ INSTANCE_EVENT_EMITTER?: boolean | "suppress-warning" | undefined;
2418
+ INSTANCE_EVENT_HOOKS?: boolean | "suppress-warning" | undefined;
2419
+ INSTANCE_CHILDREN?: boolean | "suppress-warning" | undefined;
2420
+ INSTANCE_LISTENERS?: boolean | "suppress-warning" | undefined;
2421
+ INSTANCE_SCOPED_SLOTS?: boolean | "suppress-warning" | undefined;
2422
+ INSTANCE_ATTRS_CLASS_STYLE?: boolean | "suppress-warning" | undefined;
2423
+ OPTIONS_DATA_FN?: boolean | "suppress-warning" | undefined;
2424
+ OPTIONS_DATA_MERGE?: boolean | "suppress-warning" | undefined;
2425
+ OPTIONS_BEFORE_DESTROY?: boolean | "suppress-warning" | undefined;
2426
+ OPTIONS_DESTROYED?: boolean | "suppress-warning" | undefined;
2427
+ WATCH_ARRAY?: boolean | "suppress-warning" | undefined;
2428
+ PROPS_DEFAULT_THIS?: boolean | "suppress-warning" | undefined;
2429
+ V_ON_KEYCODE_MODIFIER?: boolean | "suppress-warning" | undefined;
2430
+ CUSTOM_DIR?: boolean | "suppress-warning" | undefined;
2431
+ ATTR_FALSE_VALUE?: boolean | "suppress-warning" | undefined;
2432
+ ATTR_ENUMERATED_COERCION?: boolean | "suppress-warning" | undefined;
2433
+ TRANSITION_CLASSES?: boolean | "suppress-warning" | undefined;
2434
+ TRANSITION_GROUP_ROOT?: boolean | "suppress-warning" | undefined;
2435
+ COMPONENT_ASYNC?: boolean | "suppress-warning" | undefined;
2436
+ COMPONENT_FUNCTIONAL?: boolean | "suppress-warning" | undefined;
2437
+ COMPONENT_V_MODEL?: boolean | "suppress-warning" | undefined;
2438
+ RENDER_FUNCTION?: boolean | "suppress-warning" | undefined;
2439
+ FILTERS?: boolean | "suppress-warning" | undefined;
2440
+ PRIVATE_APIS?: boolean | "suppress-warning" | undefined;
2441
+ MODE?: 2 | 3 | ((comp: Component<any, any, any, ComputedOptions, MethodOptions, {}, any> | null) => 2 | 3) | undefined;
2442
+ } | undefined;
2443
+ data?: ((this: any, vm: any) => any) | undefined;
2444
+ computed?: ComputedOptions | undefined;
2445
+ methods?: MethodOptions | undefined;
2446
+ watch?: {
2447
+ [x: string]: (string | WatchCallback<any, any> | ({
2448
+ handler: string | WatchCallback<any, any>;
2449
+ } & WatchOptions<boolean>)) | (string | WatchCallback<any, any> | ({
2450
+ handler: string | WatchCallback<any, any>;
2451
+ } & WatchOptions<boolean>))[];
2452
+ } | undefined;
2453
+ provide?: ComponentProvideOptions | undefined;
2454
+ inject?: {} | string[] | undefined;
2455
+ filters?: Record<string, Function> | undefined;
2456
+ mixins?: any[] | undefined;
2457
+ extends?: any;
2458
+ beforeCreate?: (() => void) | undefined;
2459
+ created?: (() => void) | undefined;
2460
+ beforeMount?: (() => void) | undefined;
2461
+ mounted?: (() => void) | undefined;
2462
+ beforeUpdate?: (() => void) | undefined;
2463
+ updated?: (() => void) | undefined;
2464
+ activated?: (() => void) | undefined;
2465
+ deactivated?: (() => void) | undefined;
2466
+ beforeDestroy?: (() => void) | undefined;
2467
+ beforeUnmount?: (() => void) | undefined;
2468
+ destroyed?: (() => void) | undefined;
2469
+ unmounted?: (() => void) | undefined;
2470
+ renderTracked?: ((e: DebuggerEvent) => void) | undefined;
2471
+ renderTriggered?: ((e: DebuggerEvent) => void) | undefined;
2472
+ errorCaptured?: ((err: unknown, instance: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}, {}, {}, string, ComponentProvideOptions>, {}, {}, "", {}, any> | null, info: string) => boolean | void) | undefined;
2473
+ delimiters?: [string, string] | undefined;
2474
+ __differentiator?: string | number | symbol | undefined;
2475
+ __isBuiltIn?: boolean | undefined;
2476
+ __file?: string | undefined;
2477
+ __name?: string | undefined;
2478
+ } | null;
2479
+ data: {
2480
+ [x: string]: any;
2481
+ source?: any[] | undefined;
2482
+ index?: number | undefined;
2483
+ } | null;
2484
+ events: {
2485
+ onHover?: ((store: IDnDStore) => void) | undefined;
2486
+ onLeave?: ((store: IDnDStore) => void) | undefined;
2487
+ onEnd?: ((store: IDnDStore) => void) | undefined;
2488
+ };
2489
+ }> & Omit<Map<HTMLElement | Element, IDraggingElement>, keyof Map<any, any>>)>;
2490
+ pointerPosition: {
2491
+ start: ShallowRef< IPoint | null, IPoint | null>;
2492
+ current: ShallowRef< IPoint | null, IPoint | null>;
2493
+ offset: {
2494
+ percent: ShallowRef< IPoint | null, IPoint | null>;
2495
+ pixel: ShallowRef< IPoint | null, IPoint | null>;
2496
+ };
2497
+ };
2498
+ isDragging: ComputedRef<boolean>;
2499
+ };
2500
+
1892
2501
  export declare const useDraggable: (options?: IUseDragOptions) => {
1893
2502
  pointerPosition: {
1894
2503
  start: ShallowRef< IPoint_2 | null, IPoint_2 | null>;
@@ -1,2 +1,2 @@
1
- "use strict";var W=Object.defineProperty;var ee=(n,e,t)=>e in n?W(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t;var I=(n,e,t)=>ee(n,typeof e!="symbol"?e+"":e,t);Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const c=require("vue"),H=require("@vueuse/core"),y=class y{};I(y,"remove",(e,t)=>{if(!e||t===void 0)return;const[r]=e.splice(t,1);return r}),I(y,"insert",(e,t,r)=>{!e||t===void 0||e.splice(t,0,r)}),I(y,"move",(e,t,r,a)=>{if(!e||!r||t===void 0||a===void 0)return;const s=y.remove(e,t);y.insert(r,a,s)}),I(y,"swap",(e,t,r,a)=>{if(!e||!r||t===void 0||a===void 0)return;const s=e[t],l=r[a];e[t]=l,r[a]=s}),I(y,"copy",(e,t,r,a)=>{if(!e||t===void 0||!r||a===void 0)return;const s=e[t];y.insert(r,a,s)}),I(y,"applyTransfer",e=>{const t=e.hovered.element.value,r=e.hovered.zone.value;t?e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i;return y.move((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.elementsMap.value.get(t))==null?void 0:v.data)==null?void 0:o.source,(i=(u=e.elementsMap.value.get(t))==null?void 0:u.data)==null?void 0:i.index)}):r&&e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i,f;return y.move((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.zonesMap.value.get(r))==null?void 0:v.data)==null?void 0:o.source,(f=(i=(u=e.zonesMap.value.get(r))==null?void 0:u.data)==null?void 0:i.source)==null?void 0:f.length)})}),I(y,"applyCopy",e=>{const t=e.hovered.element.value,r=e.hovered.zone.value;t?e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i;return y.copy((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.elementsMap.value.get(t))==null?void 0:v.data)==null?void 0:o.source,(i=(u=e.elementsMap.value.get(t))==null?void 0:u.data)==null?void 0:i.index)}):r&&e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i,f;return y.copy((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.zonesMap.value.get(r))==null?void 0:v.data)==null?void 0:o.source,(f=(i=(u=e.zonesMap.value.get(r))==null?void 0:u.data)==null?void 0:i.source)==null?void 0:f.length)})}),I(y,"applySwap",e=>{var a,s,l,v,o,u;const t=e.hovered.element.value,r=e.hovered.zone.value;if(t&&e.draggingElements.value.size===1){const i=e.draggingElements.value.values().next().value;y.swap((a=i==null?void 0:i.data)==null?void 0:a.source,(s=i==null?void 0:i.data)==null?void 0:s.index,(v=(l=e.elementsMap.value.get(t))==null?void 0:l.data)==null?void 0:v.source,(u=(o=e.elementsMap.value.get(t))==null?void 0:o.data)==null?void 0:u.index)}else r&&e.draggingElements.value.forEach(i=>{var f,d,g,h,p,z,M;return y.move((f=i.data)==null?void 0:f.source,(d=i.data)==null?void 0:d.index,(h=(g=e.zonesMap.value.get(r))==null?void 0:g.data)==null?void 0:h.source,(M=(z=(p=e.zonesMap.value.get(r))==null?void 0:p.data)==null?void 0:z.source)==null?void 0:M.length)})}),I(y,"applyRemove",e=>{e.draggingElements.value.forEach(t=>{var r,a;(r=t.data)!=null&&r.source&&((a=t.data)==null?void 0:a.index)!==void 0&&y.remove(t.data.source,t.data.index)})}),I(y,"applyInsert",(e,t)=>{const r=e.hovered.element.value,a=e.hovered.zone.value;r&&t.length>0?t.forEach(s=>{var l,v,o,u;y.insert((v=(l=e.elementsMap.value.get(r))==null?void 0:l.data)==null?void 0:v.source,(u=(o=e.elementsMap.value.get(r))==null?void 0:o.data)==null?void 0:u.index,s)}):a&&t.forEach(s=>{var l,v,o,u,i;y.insert((v=(l=e.zonesMap.value.get(a))==null?void 0:l.data)==null?void 0:v.source,(i=(u=(o=e.zonesMap.value.get(a))==null?void 0:o.data)==null?void 0:u.source)==null?void 0:i.length,s)})});let X=y;const A=H.createGlobalState(()=>{const n=c.ref(new Map),e=c.computed(()=>n.value.size>0),t={component:c.ref(null),ref:c.shallowRef(null)},r=c.ref(new Map),a=c.ref(new Map),s=c.ref(new Map),l=c.ref(new Set),v=c.ref(new Set),o=new IntersectionObserver(K=>{K.forEach(m=>v.value[m.isIntersecting?"add":"delete"](m.target))}),u=new IntersectionObserver(K=>{K.forEach(m=>l.value[m.isIntersecting?"add":"delete"](m.target))}),i=(K,m)=>{K==="add"?o.observe(m):(o.unobserve(m),v.value.delete(m))},f=(K,m)=>{K==="add"?u.observe(m):(u.unobserve(m),l.value.delete(m))};c.onUnmounted(()=>{o.disconnect(),u.disconnect()});const d={start:c.shallowRef(null),current:c.shallowRef(null),offset:{percent:c.shallowRef(null),pixel:c.shallowRef(null)}},{w:g,s:h,a:p,d:z,ctrl:M,shift:_,alt:w,meta:Z}=H.useMagicKeys(),Y={zone:c.shallowRef(null),element:c.shallowRef(null)};return{draggingElements:n,isDragging:e,activeContainer:t,elementsMap:r,selectedElementsMap:a,zonesMap:s,visibleZones:l,visibleElements:v,pointerPosition:d,keyboard:{w:g,s:h,a:p,d:z,ctrl:M,shift:_,alt:w,meta:Z},hovered:Y,handleDragElementIntersection:i,handleDropZoneIntersection:f}}),te=()=>{const n=c.ref(null),{draggingElements:e,pointerPosition:t,isDragging:r,activeContainer:a}=A();return c.onMounted(()=>{a.ref=n}),c.onBeforeUnmount(()=>{a.ref.value=null}),{elementRef:n,draggingElements:e,pointerPosition:t,isDragging:r}},ne=["innerHTML"],re=c.defineComponent({__name:"DefaultOverlay",setup(n){const{elementRef:e,pointerPosition:t,isDragging:r,draggingElements:a}=te(),s=c.computed(()=>{var l,v,o,u;return{transform:`translate3d(${(((l=t.current.value)==null?void 0:l.x)??0)-(((v=t.offset.pixel.value)==null?void 0:v.x)??0)}px, ${(((o=t.current.value)==null?void 0:o.y)??0)-(((u=t.offset.pixel.value)==null?void 0:u.y)??0)}px, 0)`,zIndex:1e3,position:"fixed",top:0,left:0,transition:"0.3s cubic-bezier(0.165, 0.84, 0.44, 1)"}});return(l,v)=>c.unref(r)?(c.openBlock(),c.createElementBlock("div",{key:0,ref_key:"elementRef",ref:e,style:c.normalizeStyle(s.value)},[(c.openBlock(!0),c.createElementBlock(c.Fragment,null,c.renderList(c.unref(a),([o,u])=>{var i,f;return c.openBlock(),c.createElementBlock("div",{key:u.id,innerHTML:u.initialHTML,style:c.normalizeStyle({width:`${(i=u.initialRect)==null?void 0:i.width}px`,height:`${(f=u.initialRect)==null?void 0:f.height}px`})},null,12,ne)}),128))],4)):c.createCommentVNode("",!0)}}),$=c.defineComponent({__name:"DragOverlay",setup(n){const{activeContainer:e}=A(),t=c.computed(()=>e.component.value??re);return(r,a)=>(c.openBlock(),c.createBlock(c.resolveDynamicComponent(t.value)))}}),ae={install(n){n.component("DragOverlay",$);const e=n.mount;n.mount=function(r){const a=e.call(this,r),s=typeof r=="string"?document.querySelector(r):r;if(s&&s instanceof Element&&!s.querySelector("#vue-dnd-kit-overlay")){const l=document.createElement("div");l.id="vue-dnd-kit-overlay",l.style.pointerEvents="none",s.appendChild(l);const v=c.createVNode($);c.render(v,l),n.__VUE_DND_KIT_OVERLAY__={container:l,vnode:v}}return a};const t=n.unmount;n.unmount=function(){return n.__VUE_DND_KIT_OVERLAY__&&(c.render(null,n.__VUE_DND_KIT_OVERLAY__.container),delete n.__VUE_DND_KIT_OVERLAY__),t.call(this)}}},G=(n,e)=>n.x<e.x+e.width&&n.x+n.width>e.x&&n.y<e.y+e.height&&n.y+n.height>e.y,T=n=>{if(!n)return{x:0,y:0,width:0,height:0,bottom:0,left:0,right:0,top:0};const e=n.getBoundingClientRect();return{bottom:e.bottom,left:e.left,right:e.right,top:e.top,x:e.x,y:e.y,width:e.width,height:e.height}},B=n=>({x:n.x+n.width/2,y:n.y+n.height/2}),le=(n,e)=>{const t=T(n);return{pixel:{x:e.x-t.x,y:e.y-t.y},percent:{x:(e.x-t.x)/t.width*100,y:(e.y-t.y)/t.height*100}}},j=(n,e)=>{const t=e.x-n.x,r=e.y-n.y;return Math.sqrt(t*t+r*r)},J=(n,e)=>{const t=Math.max(0,Math.min(n.x+n.width,e.x+e.width)-Math.max(n.x,e.x)),r=Math.max(0,Math.min(n.y+n.height,e.y+e.height)-Math.max(n.y,e.y)),a=t*r,s=n.width*n.height,l=e.width*e.height;return(a/s*100+a/l*100)/2},Q="data-vue-dnd-kit-draggable",D=n=>{n.preventDefault()},oe=n=>{const{elementsMap:e,draggingElements:t,hovered:r,selectedElementsMap:a,isDragging:s,visibleElements:l,handleDragElementIntersection:v}=A(),o=c.ref(null),u=c.computed(()=>l.value.has(o.value)&&r.element.value===o.value),i=c.shallowRef((n==null?void 0:n.id)||c.useId()),f=c.computed(()=>!o.value||!l.value.has(o.value)?!1:t.value.has(o.value)),d=c.computed(()=>{if(!o.value||!s.value||!l.value.has(o.value))return!1;const p=e.value.get(o.value);return p!=null&&p.groups.length?!Array.from(t.value.entries()).some(([z,M])=>M.groups.length?!M.groups.some(_=>p.groups.includes(_)):!1):!0});return{elementRef:o,registerElement:()=>{if(!o.value)throw new Error("ElementRef is not set");e.value.set(o.value,{node:o.value,groups:(n==null?void 0:n.groups)??[],layer:(n==null?void 0:n.layer)??null,defaultLayer:(n==null?void 0:n.layer)??null,events:(n==null?void 0:n.events)??{},data:(n==null?void 0:n.data)??null,id:i.value}),v("add",o.value),o.value.addEventListener("dragstart",D),o.value.addEventListener("drag",D),o.value.setAttribute(Q,"true"),o.value.setAttribute("draggable","false")},unregisterElement:()=>{o.value&&(v("remove",o.value),e.value.delete(o.value),a.value.delete(o.value),o.value.removeEventListener("dragstart",D),o.value.removeEventListener("drag",D),o.value.removeAttribute(Q),o.value.removeAttribute("draggable"))},isDragging:f,isOvered:u,isAllowed:d,id:i}},C=(n,e)=>n?e.contains(n):!1,se=n=>{var i,f;const e=T(n.activeContainer.ref.value),t=B(e),r=((i=n.pointerPosition.current.value)==null?void 0:i.x)??0,a=((f=n.pointerPosition.current.value)==null?void 0:f.y)??0,l=!(e&&r>=e.x&&r<=e.x+e.width&&a>=e.y&&a<=e.y+e.height),v=Array.from(n.draggingElements.value.keys()),o=Array.from(n.visibleElements.value.entries()).filter(([d,g])=>{if(!d)return!1;const h=T(d);return h&&e&&G(h,e)}).map(([d,g])=>{const h=T(d),p=B(h),z=r>=h.x&&r<=h.x+h.width&&a>=h.y&&a<=h.y+h.height,M=J(h,e),_=j(t,p);let w=0;for(const[Z,Y]of n.visibleElements.value.entries())Z!==d&&Z&&d&&C(d,Z)&&w++;return{element:g,node:d,isPointerInElement:z,overlapPercent:M,depth:w,centerDistance:_}}).sort((d,g)=>{if(!l){if(d.isPointerInElement&&g.isPointerInElement)return g.depth-d.depth;if(d.isPointerInElement!==g.isPointerInElement)return d.isPointerInElement?-1:1}return Math.abs(d.overlapPercent-g.overlapPercent)<=1?d.centerDistance-g.centerDistance:g.overlapPercent-d.overlapPercent}),u=Array.from(n.visibleZones.value.entries()).filter(([d,g])=>{if(!d||v.some(p=>p&&C(d,p)))return!1;const h=T(d);return h&&e&&G(h,e)}).map(([d,g])=>{const h=T(d),p=B(h),z=r>=h.x&&r<=h.x+h.width&&a>=h.y&&a<=h.y+h.height,M=J(h,e),_=j(t,p);let w=0;for(const[Z,Y]of n.visibleZones.value.entries())Z!==d&&Z&&d&&C(d,Z)&&w++;return{zone:g,node:d,isPointerInElement:z,overlapPercent:M,depth:w,centerDistance:_}}).sort((d,g)=>{if(!l){if(d.isPointerInElement&&g.isPointerInElement)return g.depth-d.depth;if(d.isPointerInElement!==g.isPointerInElement)return d.isPointerInElement?-1:1}return Math.abs(d.overlapPercent-g.overlapPercent)<=1?d.centerDistance-g.centerDistance:g.overlapPercent-d.overlapPercent});return[...o.map(d=>d.node),...u.map(d=>d.node)]},ue=(n,e)=>{const{pointerPosition:t,keyboard:r}=A(),a=(e==null?void 0:e.moveStep)||10;return{onKeyboardStart:o=>{var d;D(o);const u=T(n.value);(d=n.value)==null||d.blur();const i=u.x+u.width/2,f=u.y+u.height/2;t.start.value={x:i,y:f},t.current.value={x:i,y:f},t.offset.pixel.value={x:u.width/2,y:u.height/2},t.offset.percent.value={x:50,y:50}},onKeyboardMove:()=>{if(!t.current.value)return;const o=t.current.value.x,u=t.current.value.y;let i=o,f=u;r.w.value&&(f-=a),r.s.value&&(f+=a),r.a.value&&(i-=a),r.d.value&&(i+=a),t.current.value={x:i,y:f}},onKeyboardEnd:()=>{t.current.value=null,t.start.value=null,t.offset.pixel.value=null,t.offset.percent.value=null}}},ie=n=>{const e=A();return{onPointerStart:s=>{e.pointerPosition.start.value={x:s.clientX,y:s.clientY},e.pointerPosition.current.value={x:s.clientX,y:s.clientY};const{pixel:l,percent:v}=le(n.value,{x:s.clientX,y:s.clientY});e.pointerPosition.offset.pixel.value=l,e.pointerPosition.offset.percent.value=v},onPointerMove:s=>{e.pointerPosition.current.value={x:s.clientX,y:s.clientY}},onPointerEnd:()=>{e.pointerPosition.current.value=null,e.pointerPosition.start.value=null,e.pointerPosition.offset.pixel.value=null,e.pointerPosition.offset.percent.value=null}}},ce=(n,e)=>{var Y,K;const t=A(),{onPointerStart:r,onPointerMove:a,onPointerEnd:s}=ie(n),{onKeyboardStart:l,onKeyboardMove:v,onKeyboardEnd:o}=ue(n,e==null?void 0:e.keyboard);let u=null;const i=m=>{var b,E;if(!m)return new Map;const L=t.selectedElementsMap.value.has(m);if(t.selectedElementsMap.value.size>0&&L){const x=new Map;return Array.from(t.selectedElementsMap.value.entries()).forEach(([k,R])=>{var U,O;x.set(k,{...R,initialHTML:((U=R.node)==null?void 0:U.outerHTML)??"",initialRect:(O=R.node)==null?void 0:O.getBoundingClientRect()})}),x}t.selectedElementsMap.value.clear();const S=t.elementsMap.value.get(m);if(!S)return new Map;const P=new Map;return P.set(m,{...S,initialHTML:((b=S.node)==null?void 0:b.outerHTML)??"",initialRect:(E=S.node)==null?void 0:E.getBoundingClientRect()}),P},f=m=>{if(!m)return{element:null,zone:null};const L=Array.isArray(m)?m:[m],S=Array.from(t.draggingElements.value.keys()),P=L.find(E=>{if(!t.visibleZones.value.has(E))return!1;const x=t.zonesMap.value.get(E);return!(!x||S.some(k=>k&&(k===x.node||C(x.node,k)))||x.groups.length&&!!Array.from(t.draggingElements.value.values()).some(R=>R.groups.length?!R.groups.some(U=>x.groups.includes(U)):!1))});return P?{element:L.find(E=>t.visibleElements.value.has(E)&&t.elementsMap.value.has(E)&&!S.some(x=>x&&(x===E||C(E,x)||C(x,E)))&&(E===P||C(E,P)))||null,zone:P}:{element:null,zone:null}},d=((Y=e==null?void 0:e.sensor)==null?void 0:Y.setup)||se,g=m=>{var P,b,E,x,k,R,U,O,q,N,V,F;const L=t.hovered.element.value,S=t.hovered.zone.value;t.hovered.element.value=m.element,t.hovered.zone.value=m.zone,L&&t.hovered.element.value!==L&&((E=(b=(P=t.elementsMap.value.get(L))==null?void 0:P.events)==null?void 0:b.onLeave)==null||E.call(b,t),t.hovered.element.value&&((R=(k=(x=t.elementsMap.value.get(t.hovered.element.value))==null?void 0:x.events)==null?void 0:k.onHover)==null||R.call(k,t))),S&&t.hovered.zone.value!==S&&((q=(O=(U=t.zonesMap.value.get(S))==null?void 0:U.events)==null?void 0:O.onLeave)==null||q.call(O,t),t.hovered.zone.value&&((F=(V=(N=t.zonesMap.value.get(t.hovered.zone.value))==null?void 0:N.events)==null?void 0:V.onHover)==null||F.call(V,t)))},h=H.useThrottleFn(()=>{const m=d(t),L=f(m);g(L)},((K=e==null?void 0:e.sensor)==null?void 0:K.throttle)??0),p=()=>{h(),u=requestAnimationFrame(p)},z=()=>p(),M=()=>{u!==null&&(cancelAnimationFrame(u),u=null)};return{activate:m=>{t.draggingElements.value=i(n.value),m instanceof PointerEvent?r(m):l(m),z()},track:m=>{m instanceof KeyboardEvent?v():a(m)},deactivate:(m=!0)=>{var L,S;if(s(),o(),m){if(t.hovered.zone.value){const P=t.zonesMap.value.get(t.hovered.zone.value);(S=P==null?void 0:(L=P.events).onDrop)==null||S.call(L,t)}else Array.from(t.draggingElements.value.values()).forEach(P=>{var b,E;return(E=(b=P.events).onEnd)==null?void 0:E.call(b,t)});t.selectedElementsMap.value.clear()}t.draggingElements.value.clear(),t.hovered.zone.value=null,t.hovered.element.value=null,M()}}},ve=H.createGlobalState(()=>{let n="",e="",t="",r=null,a=null,s=null,l=null,v=null;const{activeContainer:o}=A(),u=()=>{const g=document.body;n=g.style.userSelect,g.style.userSelect="none",window.addEventListener("contextmenu",D),window.addEventListener("selectstart",D),window.addEventListener("touchstart",D),window.addEventListener("touchmove",D)},i=()=>{const g=document.body;g.style.userSelect=n,g.style.touchAction=e,g.style.overscrollBehavior=t,window.removeEventListener("contextmenu",D),window.removeEventListener("selectstart",D),window.removeEventListener("touchstart",D),window.removeEventListener("touchmove",D)},f=()=>{r&&(document.removeEventListener("pointermove",r),r=null),a&&(document.removeEventListener("pointerup",a),a=null),s&&(s=null),l&&(document.removeEventListener("wheel",l),l=null),v&&(document.removeEventListener("keydown",v),document.removeEventListener("keypress",v),document.removeEventListener("keyup",v),v=null)};return{handleDragStart:(g,h,p)=>{f(),g.target.blur(),p!=null&&p.container&&(o.component.value=c.markRaw(p.container));const{activate:z,track:M,deactivate:_}=ce(h,p);a=()=>{o.component.value=null,i(),_(!0),f()},s=()=>{o.component.value=null,i(),_(!1),f()},r=w=>M(w),l=w=>M(w),v=w=>{w.type==="keyup"&&(w.code==="Escape"&&(s==null||s()),w.code==="Enter"&&(a==null||a())),M(w)},u(),z(g),document.addEventListener("pointermove",r),document.addEventListener("pointerup",a),document.addEventListener("wheel",l),document.addEventListener("keydown",v),document.addEventListener("keypress",v),document.addEventListener("keyup",v)}}}),de=n=>{const{id:e,elementRef:t,isDragging:r,isOvered:a,isAllowed:s,registerElement:l,unregisterElement:v}=oe(n),{pointerPosition:o}=A(),{handleDragStart:u}=ve(),i=f=>u(f,t,n);return c.onMounted(l),c.onBeforeUnmount(v),{pointerPosition:o,elementRef:t,isDragging:r,isOvered:a,isAllowed:s,handleDragStart:i,id:e}},fe=n=>{const{zonesMap:e,hovered:t,draggingElements:r,isDragging:a,handleDropZoneIntersection:s}=A(),l=c.ref(null),v=c.computed(()=>t.zone.value===l.value),o=c.computed(()=>{if(!l.value||!a.value)return!1;const f=e.value.get(l.value);return f!=null&&f.groups.length?!Array.from(r.value.values()).some(d=>d.groups.length?!d.groups.some(g=>f.groups.includes(g)):!1):!0});return{elementRef:l,registerZone:()=>{if(!l.value)throw new Error("elementRef is not set");s("add",l.value),e.value.set(l.value,{node:l.value,groups:(n==null?void 0:n.groups)??[],events:(n==null?void 0:n.events)??{},data:(n==null?void 0:n.data)??void 0}),l.value.setAttribute("data-dnd-droppable","true")},unregisterZone:()=>{l.value&&(s("remove",l.value),e.value.delete(l.value))},isOvered:v,isAllowed:o}},ge=n=>{const{elementRef:e,registerZone:t,unregisterZone:r,isOvered:a,isAllowed:s}=fe(n);return c.onMounted(t),c.onBeforeUnmount(r),{elementRef:e,isOvered:a,isAllowed:s}},me=n=>{const{selectedElementsMap:e,elementsMap:t}=A(),r=c.computed(()=>n.value?e.value.has(n.value):!1),a=c.computed(()=>{if(!n.value)return!1;for(const[u,i]of e.value.entries())if(u&&C(u,n.value))return!0;return!1}),s=c.computed(()=>{if(!n.value)return!1;for(const[u,i]of e.value.entries())if(u&&C(n.value,u))return!0;return!1}),l=()=>{n.value&&e.value.delete(n.value)},v=()=>{if(!n.value)return;const u=t.value.get(n.value);if(u){if(a.value)for(const[i,f]of[...e.value.entries()])i&&C(i,n.value)&&e.value.delete(i);if(s.value)for(const[i,f]of[...e.value.entries()])i&&C(n.value,i)&&e.value.delete(i);e.value.set(n.value,u)}};return{handleUnselect:l,handleSelect:v,handleToggleSelect:()=>{n.value&&(e.value.has(n.value)?l():v())},isSelected:r,isParentOfSelected:a}};exports.DnDOperations=X;exports.default=ae;exports.getBoundingBox=T;exports.useDnDStore=A;exports.useDraggable=de;exports.useDroppable=ge;exports.useSelection=me;
1
+ "use strict";var ee=Object.defineProperty;var te=(n,e,t)=>e in n?ee(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t;var C=(n,e,t)=>te(n,typeof e!="symbol"?e+"":e,t);Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const c=require("vue"),H=require("@vueuse/core"),y=class y{};C(y,"remove",(e,t)=>{if(!e||t===void 0)return;const[r]=e.splice(t,1);return r}),C(y,"insert",(e,t,r)=>{!e||t===void 0||e.splice(t,0,r)}),C(y,"move",(e,t,r,a)=>{if(!e||!r||t===void 0||a===void 0)return;const s=y.remove(e,t);y.insert(r,a,s)}),C(y,"swap",(e,t,r,a)=>{if(!e||!r||t===void 0||a===void 0)return;const s=e[t],l=r[a];e[t]=l,r[a]=s}),C(y,"copy",(e,t,r,a)=>{if(!e||t===void 0||!r||a===void 0)return;const s=e[t];y.insert(r,a,s)}),C(y,"applyTransfer",e=>{const t=e.hovered.element.value,r=e.hovered.zone.value;t?e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i;return y.move((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.elementsMap.value.get(t))==null?void 0:v.data)==null?void 0:o.source,(i=(u=e.elementsMap.value.get(t))==null?void 0:u.data)==null?void 0:i.index)}):r&&e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i,f;return y.move((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.zonesMap.value.get(r))==null?void 0:v.data)==null?void 0:o.source,(f=(i=(u=e.zonesMap.value.get(r))==null?void 0:u.data)==null?void 0:i.source)==null?void 0:f.length)})}),C(y,"applyCopy",e=>{const t=e.hovered.element.value,r=e.hovered.zone.value;t?e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i;return y.copy((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.elementsMap.value.get(t))==null?void 0:v.data)==null?void 0:o.source,(i=(u=e.elementsMap.value.get(t))==null?void 0:u.data)==null?void 0:i.index)}):r&&e.draggingElements.value.forEach(a=>{var s,l,v,o,u,i,f;return y.copy((s=a.data)==null?void 0:s.source,(l=a.data)==null?void 0:l.index,(o=(v=e.zonesMap.value.get(r))==null?void 0:v.data)==null?void 0:o.source,(f=(i=(u=e.zonesMap.value.get(r))==null?void 0:u.data)==null?void 0:i.source)==null?void 0:f.length)})}),C(y,"applySwap",e=>{var a,s,l,v,o,u;const t=e.hovered.element.value,r=e.hovered.zone.value;if(t&&e.draggingElements.value.size===1){const i=e.draggingElements.value.values().next().value;y.swap((a=i==null?void 0:i.data)==null?void 0:a.source,(s=i==null?void 0:i.data)==null?void 0:s.index,(v=(l=e.elementsMap.value.get(t))==null?void 0:l.data)==null?void 0:v.source,(u=(o=e.elementsMap.value.get(t))==null?void 0:o.data)==null?void 0:u.index)}else r&&e.draggingElements.value.forEach(i=>{var f,d,g,h,p,z,M;return y.move((f=i.data)==null?void 0:f.source,(d=i.data)==null?void 0:d.index,(h=(g=e.zonesMap.value.get(r))==null?void 0:g.data)==null?void 0:h.source,(M=(z=(p=e.zonesMap.value.get(r))==null?void 0:p.data)==null?void 0:z.source)==null?void 0:M.length)})}),C(y,"applyRemove",e=>{e.draggingElements.value.forEach(t=>{var r,a;(r=t.data)!=null&&r.source&&((a=t.data)==null?void 0:a.index)!==void 0&&y.remove(t.data.source,t.data.index)})}),C(y,"applyInsert",(e,t)=>{const r=e.hovered.element.value,a=e.hovered.zone.value;r&&t.length>0?t.forEach(s=>{var l,v,o,u;y.insert((v=(l=e.elementsMap.value.get(r))==null?void 0:l.data)==null?void 0:v.source,(u=(o=e.elementsMap.value.get(r))==null?void 0:o.data)==null?void 0:u.index,s)}):a&&t.forEach(s=>{var l,v,o,u,i;y.insert((v=(l=e.zonesMap.value.get(a))==null?void 0:l.data)==null?void 0:v.source,(i=(u=(o=e.zonesMap.value.get(a))==null?void 0:o.data)==null?void 0:u.source)==null?void 0:i.length,s)})});let X=y;const A=H.createGlobalState(()=>{const n=c.ref(new Map),e=c.computed(()=>n.value.size>0),t={component:c.ref(null),ref:c.shallowRef(null)},r=c.ref(new Map),a=c.ref(new Map),s=c.ref(new Map),l=c.ref(new Set),v=c.ref(new Set),o=new IntersectionObserver(K=>{K.forEach(m=>v.value[m.isIntersecting?"add":"delete"](m.target))}),u=new IntersectionObserver(K=>{K.forEach(m=>l.value[m.isIntersecting?"add":"delete"](m.target))}),i=(K,m)=>{K==="add"?o.observe(m):(o.unobserve(m),v.value.delete(m))},f=(K,m)=>{K==="add"?u.observe(m):(u.unobserve(m),l.value.delete(m))};c.onUnmounted(()=>{o.disconnect(),u.disconnect()});const d={start:c.shallowRef(null),current:c.shallowRef(null),offset:{percent:c.shallowRef(null),pixel:c.shallowRef(null)}},{w:g,s:h,a:p,d:z,ctrl:M,shift:_,alt:w,meta:Z}=H.useMagicKeys(),Y={zone:c.shallowRef(null),element:c.shallowRef(null)};return{draggingElements:n,isDragging:e,activeContainer:t,elementsMap:r,selectedElementsMap:a,zonesMap:s,visibleZones:l,visibleElements:v,pointerPosition:d,keyboard:{w:g,s:h,a:p,d:z,ctrl:M,shift:_,alt:w,meta:Z},hovered:Y,handleDragElementIntersection:i,handleDropZoneIntersection:f}}),W=()=>{const n=c.ref(null),{draggingElements:e,pointerPosition:t,isDragging:r,activeContainer:a}=A();return c.onMounted(()=>{a.ref=n}),c.onBeforeUnmount(()=>{a.ref.value=null}),{elementRef:n,draggingElements:e,pointerPosition:t,isDragging:r}},ne=["innerHTML"],re=c.defineComponent({__name:"DefaultOverlay",setup(n){const{elementRef:e,pointerPosition:t,isDragging:r,draggingElements:a}=W(),s=c.computed(()=>{var l,v,o,u;return{transform:`translate3d(${(((l=t.current.value)==null?void 0:l.x)??0)-(((v=t.offset.pixel.value)==null?void 0:v.x)??0)}px, ${(((o=t.current.value)==null?void 0:o.y)??0)-(((u=t.offset.pixel.value)==null?void 0:u.y)??0)}px, 0)`,zIndex:1e3,position:"fixed",top:0,left:0,transition:"0.3s cubic-bezier(0.165, 0.84, 0.44, 1)"}});return(l,v)=>c.unref(r)?(c.openBlock(),c.createElementBlock("div",{key:0,ref_key:"elementRef",ref:e,style:c.normalizeStyle(s.value)},[(c.openBlock(!0),c.createElementBlock(c.Fragment,null,c.renderList(c.unref(a),([o,u])=>{var i,f;return c.openBlock(),c.createElementBlock("div",{key:u.id,innerHTML:u.initialHTML,style:c.normalizeStyle({width:`${(i=u.initialRect)==null?void 0:i.width}px`,height:`${(f=u.initialRect)==null?void 0:f.height}px`})},null,12,ne)}),128))],4)):c.createCommentVNode("",!0)}}),$=c.defineComponent({__name:"DragOverlay",setup(n){const{activeContainer:e}=A(),t=c.computed(()=>e.component.value??re);return(r,a)=>(c.openBlock(),c.createBlock(c.resolveDynamicComponent(t.value)))}}),ae={install(n){n.component("DragOverlay",$);const e=n.mount;n.mount=function(r){const a=e.call(this,r),s=typeof r=="string"?document.querySelector(r):r;if(s&&s instanceof Element&&!s.querySelector("#vue-dnd-kit-overlay")){const l=document.createElement("div");l.id="vue-dnd-kit-overlay",l.style.pointerEvents="none",s.appendChild(l);const v=c.createVNode($);c.render(v,l),n.__VUE_DND_KIT_OVERLAY__={container:l,vnode:v}}return a};const t=n.unmount;n.unmount=function(){return n.__VUE_DND_KIT_OVERLAY__&&(c.render(null,n.__VUE_DND_KIT_OVERLAY__.container),delete n.__VUE_DND_KIT_OVERLAY__),t.call(this)}}},G=(n,e)=>n.x<e.x+e.width&&n.x+n.width>e.x&&n.y<e.y+e.height&&n.y+n.height>e.y,T=n=>{if(!n)return{x:0,y:0,width:0,height:0,bottom:0,left:0,right:0,top:0};const e=n.getBoundingClientRect();return{bottom:e.bottom,left:e.left,right:e.right,top:e.top,x:e.x,y:e.y,width:e.width,height:e.height}},B=n=>({x:n.x+n.width/2,y:n.y+n.height/2}),le=(n,e)=>{const t=T(n);return{pixel:{x:e.x-t.x,y:e.y-t.y},percent:{x:(e.x-t.x)/t.width*100,y:(e.y-t.y)/t.height*100}}},j=(n,e)=>{const t=e.x-n.x,r=e.y-n.y;return Math.sqrt(t*t+r*r)},J=(n,e)=>{const t=Math.max(0,Math.min(n.x+n.width,e.x+e.width)-Math.max(n.x,e.x)),r=Math.max(0,Math.min(n.y+n.height,e.y+e.height)-Math.max(n.y,e.y)),a=t*r,s=n.width*n.height,l=e.width*e.height;return(a/s*100+a/l*100)/2},Q="data-vue-dnd-kit-draggable",D=n=>{n.preventDefault()},oe=n=>{const{elementsMap:e,draggingElements:t,hovered:r,selectedElementsMap:a,isDragging:s,visibleElements:l,handleDragElementIntersection:v}=A(),o=c.ref(null),u=c.computed(()=>l.value.has(o.value)&&r.element.value===o.value),i=c.shallowRef((n==null?void 0:n.id)||c.useId()),f=c.computed(()=>!o.value||!l.value.has(o.value)?!1:t.value.has(o.value)),d=c.computed(()=>{if(!o.value||!s.value||!l.value.has(o.value))return!1;const p=e.value.get(o.value);return p!=null&&p.groups.length?!Array.from(t.value.entries()).some(([z,M])=>M.groups.length?!M.groups.some(_=>p.groups.includes(_)):!1):!0});return{elementRef:o,registerElement:()=>{if(!o.value)throw new Error("ElementRef is not set");e.value.set(o.value,{node:o.value,groups:(n==null?void 0:n.groups)??[],layer:(n==null?void 0:n.layer)??null,defaultLayer:(n==null?void 0:n.layer)??null,events:(n==null?void 0:n.events)??{},data:(n==null?void 0:n.data)??null,id:i.value}),v("add",o.value),o.value.addEventListener("dragstart",D),o.value.addEventListener("drag",D),o.value.setAttribute(Q,"true"),o.value.setAttribute("draggable","false")},unregisterElement:()=>{o.value&&(v("remove",o.value),e.value.delete(o.value),a.value.delete(o.value),o.value.removeEventListener("dragstart",D),o.value.removeEventListener("drag",D),o.value.removeAttribute(Q),o.value.removeAttribute("draggable"))},isDragging:f,isOvered:u,isAllowed:d,id:i}},I=(n,e)=>n?e.contains(n):!1,se=n=>{var i,f;const e=T(n.activeContainer.ref.value),t=B(e),r=((i=n.pointerPosition.current.value)==null?void 0:i.x)??0,a=((f=n.pointerPosition.current.value)==null?void 0:f.y)??0,l=!(e&&r>=e.x&&r<=e.x+e.width&&a>=e.y&&a<=e.y+e.height),v=Array.from(n.draggingElements.value.keys()),o=Array.from(n.visibleElements.value.entries()).filter(([d,g])=>{if(!d)return!1;const h=T(d);return h&&e&&G(h,e)}).map(([d,g])=>{const h=T(d),p=B(h),z=r>=h.x&&r<=h.x+h.width&&a>=h.y&&a<=h.y+h.height,M=J(h,e),_=j(t,p);let w=0;for(const[Z,Y]of n.visibleElements.value.entries())Z!==d&&Z&&d&&I(d,Z)&&w++;return{element:g,node:d,isPointerInElement:z,overlapPercent:M,depth:w,centerDistance:_}}).sort((d,g)=>{if(!l){if(d.isPointerInElement&&g.isPointerInElement)return g.depth-d.depth;if(d.isPointerInElement!==g.isPointerInElement)return d.isPointerInElement?-1:1}return Math.abs(d.overlapPercent-g.overlapPercent)<=1?d.centerDistance-g.centerDistance:g.overlapPercent-d.overlapPercent}),u=Array.from(n.visibleZones.value.entries()).filter(([d,g])=>{if(!d||v.some(p=>p&&I(d,p)))return!1;const h=T(d);return h&&e&&G(h,e)}).map(([d,g])=>{const h=T(d),p=B(h),z=r>=h.x&&r<=h.x+h.width&&a>=h.y&&a<=h.y+h.height,M=J(h,e),_=j(t,p);let w=0;for(const[Z,Y]of n.visibleZones.value.entries())Z!==d&&Z&&d&&I(d,Z)&&w++;return{zone:g,node:d,isPointerInElement:z,overlapPercent:M,depth:w,centerDistance:_}}).sort((d,g)=>{if(!l){if(d.isPointerInElement&&g.isPointerInElement)return g.depth-d.depth;if(d.isPointerInElement!==g.isPointerInElement)return d.isPointerInElement?-1:1}return Math.abs(d.overlapPercent-g.overlapPercent)<=1?d.centerDistance-g.centerDistance:g.overlapPercent-d.overlapPercent});return[...o.map(d=>d.node),...u.map(d=>d.node)]},ue=(n,e)=>{const{pointerPosition:t,keyboard:r}=A(),a=(e==null?void 0:e.moveStep)||10;return{onKeyboardStart:o=>{var d;D(o);const u=T(n.value);(d=n.value)==null||d.blur();const i=u.x+u.width/2,f=u.y+u.height/2;t.start.value={x:i,y:f},t.current.value={x:i,y:f},t.offset.pixel.value={x:u.width/2,y:u.height/2},t.offset.percent.value={x:50,y:50}},onKeyboardMove:()=>{if(!t.current.value)return;const o=t.current.value.x,u=t.current.value.y;let i=o,f=u;r.w.value&&(f-=a),r.s.value&&(f+=a),r.a.value&&(i-=a),r.d.value&&(i+=a),t.current.value={x:i,y:f}},onKeyboardEnd:()=>{t.current.value=null,t.start.value=null,t.offset.pixel.value=null,t.offset.percent.value=null}}},ie=n=>{const e=A();return{onPointerStart:s=>{e.pointerPosition.start.value={x:s.clientX,y:s.clientY},e.pointerPosition.current.value={x:s.clientX,y:s.clientY};const{pixel:l,percent:v}=le(n.value,{x:s.clientX,y:s.clientY});e.pointerPosition.offset.pixel.value=l,e.pointerPosition.offset.percent.value=v},onPointerMove:s=>{e.pointerPosition.current.value={x:s.clientX,y:s.clientY}},onPointerEnd:()=>{e.pointerPosition.current.value=null,e.pointerPosition.start.value=null,e.pointerPosition.offset.pixel.value=null,e.pointerPosition.offset.percent.value=null}}},ce=(n,e)=>{var Y,K;const t=A(),{onPointerStart:r,onPointerMove:a,onPointerEnd:s}=ie(n),{onKeyboardStart:l,onKeyboardMove:v,onKeyboardEnd:o}=ue(n,e==null?void 0:e.keyboard);let u=null;const i=m=>{var b,E;if(!m)return new Map;const L=t.selectedElementsMap.value.has(m);if(t.selectedElementsMap.value.size>0&&L){const x=new Map;return Array.from(t.selectedElementsMap.value.entries()).forEach(([k,R])=>{var U,O;x.set(k,{...R,initialHTML:((U=R.node)==null?void 0:U.outerHTML)??"",initialRect:(O=R.node)==null?void 0:O.getBoundingClientRect()})}),x}t.selectedElementsMap.value.clear();const S=t.elementsMap.value.get(m);if(!S)return new Map;const P=new Map;return P.set(m,{...S,initialHTML:((b=S.node)==null?void 0:b.outerHTML)??"",initialRect:(E=S.node)==null?void 0:E.getBoundingClientRect()}),P},f=m=>{if(!m)return{element:null,zone:null};const L=Array.isArray(m)?m:[m],S=Array.from(t.draggingElements.value.keys()),P=L.find(E=>{if(!t.visibleZones.value.has(E))return!1;const x=t.zonesMap.value.get(E);return!(!x||S.some(k=>k&&(k===x.node||I(x.node,k)))||x.groups.length&&!!Array.from(t.draggingElements.value.values()).some(R=>R.groups.length?!R.groups.some(U=>x.groups.includes(U)):!1))});return P?{element:L.find(E=>t.visibleElements.value.has(E)&&t.elementsMap.value.has(E)&&!S.some(x=>x&&(x===E||I(E,x)||I(x,E)))&&(E===P||I(E,P)))||null,zone:P}:{element:null,zone:null}},d=((Y=e==null?void 0:e.sensor)==null?void 0:Y.setup)||se,g=m=>{var P,b,E,x,k,R,U,O,q,N,V,F;const L=t.hovered.element.value,S=t.hovered.zone.value;t.hovered.element.value=m.element,t.hovered.zone.value=m.zone,L&&t.hovered.element.value!==L&&((E=(b=(P=t.elementsMap.value.get(L))==null?void 0:P.events)==null?void 0:b.onLeave)==null||E.call(b,t),t.hovered.element.value&&((R=(k=(x=t.elementsMap.value.get(t.hovered.element.value))==null?void 0:x.events)==null?void 0:k.onHover)==null||R.call(k,t))),S&&t.hovered.zone.value!==S&&((q=(O=(U=t.zonesMap.value.get(S))==null?void 0:U.events)==null?void 0:O.onLeave)==null||q.call(O,t),t.hovered.zone.value&&((F=(V=(N=t.zonesMap.value.get(t.hovered.zone.value))==null?void 0:N.events)==null?void 0:V.onHover)==null||F.call(V,t)))},h=H.useThrottleFn(()=>{const m=d(t),L=f(m);g(L)},((K=e==null?void 0:e.sensor)==null?void 0:K.throttle)??0),p=()=>{h(),u=requestAnimationFrame(p)},z=()=>p(),M=()=>{u!==null&&(cancelAnimationFrame(u),u=null)};return{activate:m=>{t.draggingElements.value=i(n.value),m instanceof PointerEvent?r(m):l(m),z()},track:m=>{m instanceof KeyboardEvent?v():a(m)},deactivate:(m=!0)=>{var L,S;if(s(),o(),m){if(t.hovered.zone.value){const P=t.zonesMap.value.get(t.hovered.zone.value);(S=P==null?void 0:(L=P.events).onDrop)==null||S.call(L,t)}else Array.from(t.draggingElements.value.values()).forEach(P=>{var b,E;return(E=(b=P.events).onEnd)==null?void 0:E.call(b,t)});t.selectedElementsMap.value.clear()}t.draggingElements.value.clear(),t.hovered.zone.value=null,t.hovered.element.value=null,M()}}},ve=H.createGlobalState(()=>{let n="",e="",t="",r=null,a=null,s=null,l=null,v=null;const{activeContainer:o}=A(),u=()=>{const g=document.body;n=g.style.userSelect,g.style.userSelect="none",window.addEventListener("contextmenu",D),window.addEventListener("selectstart",D),window.addEventListener("touchstart",D),window.addEventListener("touchmove",D)},i=()=>{const g=document.body;g.style.userSelect=n,g.style.touchAction=e,g.style.overscrollBehavior=t,window.removeEventListener("contextmenu",D),window.removeEventListener("selectstart",D),window.removeEventListener("touchstart",D),window.removeEventListener("touchmove",D)},f=()=>{r&&(document.removeEventListener("pointermove",r),r=null),a&&(document.removeEventListener("pointerup",a),a=null),s&&(s=null),l&&(document.removeEventListener("wheel",l),l=null),v&&(document.removeEventListener("keydown",v),document.removeEventListener("keypress",v),document.removeEventListener("keyup",v),v=null)};return{handleDragStart:(g,h,p)=>{f(),g.target.blur(),p!=null&&p.container&&(o.component.value=c.markRaw(p.container));const{activate:z,track:M,deactivate:_}=ce(h,p);a=()=>{o.component.value=null,i(),_(!0),f()},s=()=>{o.component.value=null,i(),_(!1),f()},r=w=>M(w),l=w=>M(w),v=w=>{w.type==="keyup"&&(w.code==="Escape"&&(s==null||s()),w.code==="Enter"&&(a==null||a())),M(w)},u(),z(g),document.addEventListener("pointermove",r),document.addEventListener("pointerup",a),document.addEventListener("wheel",l),document.addEventListener("keydown",v),document.addEventListener("keypress",v),document.addEventListener("keyup",v)}}}),de=n=>{const{id:e,elementRef:t,isDragging:r,isOvered:a,isAllowed:s,registerElement:l,unregisterElement:v}=oe(n),{pointerPosition:o}=A(),{handleDragStart:u}=ve(),i=f=>u(f,t,n);return c.onMounted(l),c.onBeforeUnmount(v),{pointerPosition:o,elementRef:t,isDragging:r,isOvered:a,isAllowed:s,handleDragStart:i,id:e}},fe=n=>{const{zonesMap:e,hovered:t,draggingElements:r,isDragging:a,handleDropZoneIntersection:s}=A(),l=c.ref(null),v=c.computed(()=>t.zone.value===l.value),o=c.computed(()=>{if(!l.value||!a.value)return!1;const f=e.value.get(l.value);return f!=null&&f.groups.length?!Array.from(r.value.values()).some(d=>d.groups.length?!d.groups.some(g=>f.groups.includes(g)):!1):!0});return{elementRef:l,registerZone:()=>{if(!l.value)throw new Error("elementRef is not set");s("add",l.value),e.value.set(l.value,{node:l.value,groups:(n==null?void 0:n.groups)??[],events:(n==null?void 0:n.events)??{},data:(n==null?void 0:n.data)??void 0}),l.value.setAttribute("data-dnd-droppable","true")},unregisterZone:()=>{l.value&&(s("remove",l.value),e.value.delete(l.value))},isOvered:v,isAllowed:o}},ge=n=>{const{elementRef:e,registerZone:t,unregisterZone:r,isOvered:a,isAllowed:s}=fe(n);return c.onMounted(t),c.onBeforeUnmount(r),{elementRef:e,isOvered:a,isAllowed:s}},me=n=>{const{selectedElementsMap:e,elementsMap:t}=A(),r=c.computed(()=>n.value?e.value.has(n.value):!1),a=c.computed(()=>{if(!n.value)return!1;for(const[u,i]of e.value.entries())if(u&&I(u,n.value))return!0;return!1}),s=c.computed(()=>{if(!n.value)return!1;for(const[u,i]of e.value.entries())if(u&&I(n.value,u))return!0;return!1}),l=()=>{n.value&&e.value.delete(n.value)},v=()=>{if(!n.value)return;const u=t.value.get(n.value);if(u){if(a.value)for(const[i,f]of[...e.value.entries()])i&&I(i,n.value)&&e.value.delete(i);if(s.value)for(const[i,f]of[...e.value.entries()])i&&I(n.value,i)&&e.value.delete(i);e.value.set(n.value,u)}};return{handleUnselect:l,handleSelect:v,handleToggleSelect:()=>{n.value&&(e.value.has(n.value)?l():v())},isSelected:r,isParentOfSelected:a}};exports.DnDOperations=X;exports.default=ae;exports.getBoundingBox=T;exports.useDnDStore=A;exports.useDragContainer=W;exports.useDraggable=de;exports.useDroppable=ge;exports.useSelection=me;
2
2
  //# sourceMappingURL=vue-dnd-kit-core.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"vue-dnd-kit-core.cjs.js","sources":["../src/utils/operations.ts","../src/composables/useDnDStore.ts","../src/composables/useDragContainer.ts","../src/components/DefaultOverlay.vue","../src/components/DragOverlay.vue","../src/plugin.ts","../src/utils/geometry.ts","../src/utils/namespaces.ts","../src/utils/events.ts","../src/managers/useElementManager.ts","../src/utils/dom.ts","../src/utils/sensor.ts","../src/composables/useKeyboard.ts","../src/composables/usePointer.ts","../src/composables/useSensor.ts","../src/managers/useEventManager.ts","../src/composables/useDraggable.ts","../src/managers/useZoneManager.ts","../src/composables/useDroppable.ts","../src/composables/useSelection.ts"],"sourcesContent":["import { IDnDStore } from '../types';\r\n\r\nexport class DnDOperations {\r\n static remove = (source?: any[], index?: number) => {\r\n if (!source || index === undefined) return;\r\n const [item] = source.splice(index, 1);\r\n return item;\r\n };\r\n static insert = (target?: any[], index?: number, item?: any) => {\r\n if (!target || index === undefined) return;\r\n target.splice(index, 0, item);\r\n };\r\n static move = (\r\n source?: any[],\r\n sourceIndex?: number,\r\n target?: any[],\r\n targetIndex?: number\r\n ) => {\r\n if (\r\n !source ||\r\n !target ||\r\n sourceIndex === undefined ||\r\n targetIndex === undefined\r\n )\r\n return;\r\n const item = DnDOperations.remove(source, sourceIndex);\r\n DnDOperations.insert(target, targetIndex, item);\r\n };\r\n static swap = (\r\n source?: any[],\r\n sourceIndex?: number,\r\n target?: any[],\r\n targetIndex?: number\r\n ) => {\r\n if (\r\n !source ||\r\n !target ||\r\n sourceIndex === undefined ||\r\n targetIndex === undefined\r\n )\r\n return;\r\n\r\n const sourceItem = source[sourceIndex];\r\n const targetItem = target[targetIndex];\r\n\r\n source[sourceIndex] = targetItem;\r\n target[targetIndex] = sourceItem;\r\n };\r\n static copy = (\r\n source?: any[],\r\n index?: number,\r\n target?: any[],\r\n targetIndex?: number\r\n ) => {\r\n if (!source || index === undefined || !target || targetIndex === undefined)\r\n return;\r\n const item = source[index];\r\n DnDOperations.insert(target, targetIndex, item);\r\n };\r\n static applyTransfer = (store: IDnDStore) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n\r\n if (hoveredElement) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.move(\r\n element.data?.source,\r\n element.data?.index,\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index\r\n )\r\n );\r\n } else if (hoveredZone) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.move(\r\n element.data?.source,\r\n element.data?.index,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length\r\n )\r\n );\r\n }\r\n };\r\n\r\n static applyCopy = (store: IDnDStore) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n\r\n if (hoveredElement) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.copy(\r\n element.data?.source,\r\n element.data?.index,\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index\r\n )\r\n );\r\n } else if (hoveredZone) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.copy(\r\n element.data?.source,\r\n element.data?.index,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length\r\n )\r\n );\r\n }\r\n };\r\n static applySwap = (store: IDnDStore) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n if (hoveredElement && store.draggingElements.value.size === 1) {\r\n const element = store.draggingElements.value.values().next().value;\r\n DnDOperations.swap(\r\n element?.data?.source,\r\n element?.data?.index,\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index\r\n );\r\n } else if (hoveredZone) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.move(\r\n element.data?.source,\r\n element.data?.index,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length\r\n )\r\n );\r\n }\r\n };\r\n static applyRemove = (store: IDnDStore) => {\r\n store.draggingElements.value.forEach((element) => {\r\n if (element.data?.source && element.data?.index !== undefined) {\r\n DnDOperations.remove(element.data.source, element.data.index);\r\n }\r\n });\r\n };\r\n static applyInsert = (store: IDnDStore, items: any[]) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n if (hoveredElement && items.length > 0) {\r\n items.forEach((item) => {\r\n DnDOperations.insert(\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index,\r\n item\r\n );\r\n });\r\n } else if (hoveredZone) {\r\n items.forEach((item) => {\r\n DnDOperations.insert(\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length,\r\n item\r\n );\r\n });\r\n }\r\n };\r\n}\r\n","import type {\r\n IDragElement,\r\n IDraggingElement,\r\n IDropZone,\r\n IPoint,\r\n} from '../types';\r\nimport { computed, ref, shallowRef, type Component, onUnmounted } from 'vue';\r\nimport { createGlobalState, useMagicKeys } from '@vueuse/core';\r\n\r\nexport const useDnDStore = createGlobalState(() => {\r\n const draggingElements = ref<Map<HTMLElement | Element, IDraggingElement>>(\r\n new Map()\r\n );\r\n const isDragging = computed<boolean>(() => draggingElements.value.size > 0);\r\n\r\n const activeContainer = {\r\n component: ref<Component | null>(null),\r\n ref: shallowRef<HTMLElement | null>(null),\r\n };\r\n\r\n const elementsMap = ref<Map<HTMLElement | Element, IDragElement>>(new Map());\r\n const selectedElementsMap = ref<Map<HTMLElement | Element, IDragElement>>(\r\n new Map()\r\n );\r\n const zonesMap = ref<Map<HTMLElement | Element, IDropZone>>(new Map());\r\n const visibleZones = ref<Set<HTMLElement | Element>>(new Set());\r\n const visibleElements = ref<Set<HTMLElement | Element>>(new Set());\r\n\r\n // Создаем IntersectionObserver для отслеживания видимости элементов\r\n const elementObserver = new IntersectionObserver((entries) => {\r\n entries.forEach((entry) =>\r\n visibleElements.value[entry.isIntersecting ? 'add' : 'delete'](\r\n entry.target\r\n )\r\n );\r\n });\r\n const zoneObserver = new IntersectionObserver((entries) => {\r\n entries.forEach((entry) =>\r\n visibleZones.value[entry.isIntersecting ? 'add' : 'delete'](entry.target)\r\n );\r\n });\r\n\r\n const handleDragElementIntersection = (\r\n action: 'add' | 'remove',\r\n element: HTMLElement | Element\r\n ) => {\r\n if (action === 'add') {\r\n elementObserver.observe(element);\r\n } else {\r\n elementObserver.unobserve(element);\r\n visibleElements.value.delete(element);\r\n }\r\n };\r\n\r\n const handleDropZoneIntersection = (\r\n action: 'add' | 'remove',\r\n element: HTMLElement | Element\r\n ) => {\r\n if (action === 'add') {\r\n zoneObserver.observe(element);\r\n } else {\r\n zoneObserver.unobserve(element);\r\n visibleZones.value.delete(element);\r\n }\r\n };\r\n\r\n onUnmounted(() => {\r\n elementObserver.disconnect();\r\n zoneObserver.disconnect();\r\n });\r\n\r\n const pointerPosition = {\r\n start: shallowRef<IPoint | null>(null),\r\n current: shallowRef<IPoint | null>(null),\r\n offset: {\r\n percent: shallowRef<IPoint | null>(null),\r\n pixel: shallowRef<IPoint | null>(null),\r\n },\r\n };\r\n\r\n const { w, s, a, d, ctrl, shift, alt, meta } = useMagicKeys();\r\n\r\n const hovered = {\r\n zone: shallowRef<HTMLElement | Element | null>(null),\r\n element: shallowRef<HTMLElement | Element | null>(null),\r\n };\r\n\r\n return {\r\n draggingElements,\r\n isDragging,\r\n activeContainer,\r\n elementsMap,\r\n selectedElementsMap,\r\n zonesMap,\r\n visibleZones,\r\n visibleElements,\r\n pointerPosition,\r\n keyboard: {\r\n w,\r\n s,\r\n a,\r\n d,\r\n ctrl,\r\n shift,\r\n alt,\r\n meta,\r\n },\r\n hovered,\r\n handleDragElementIntersection,\r\n handleDropZoneIntersection,\r\n };\r\n});\r\n","import { onBeforeUnmount, onMounted, ref } from 'vue';\r\n\r\nimport { useDnDStore } from './useDnDStore';\r\n\r\n/**\r\n * Hook for creating custom drag container with overlay management.\r\n * Provides functionality for controlling drag visualization and element positioning.\r\n *\r\n * This hook is typically used to create custom drag overlays, layers,\r\n * and control how dragged elements are displayed during drag operations.\r\n *\r\n * @example\r\n * ```vue\r\n * <script setup lang=\"ts\">\r\n * import { computed } from 'vue';\r\n * import { useDragContainer } from '../composables/useDragContainer';\r\n *\r\n * const { elementRef, pointerPosition, isDragging, draggingElements } =\r\n * useDragContainer();\r\n *\r\n * const computedStyle = computed(() => ({\r\n * transform: `translate3d(${\r\n * (pointerPosition.current.value?.x ?? 0) -\r\n * (pointerPosition.offset.pixel.value?.x ?? 0)\r\n * }px, ${\r\n * (pointerPosition.current.value?.y ?? 0) -\r\n * (pointerPosition.offset.pixel.value?.y ?? 0)\r\n * }px, 0)`,\r\n * }));\r\n *</script>\r\n *\r\n *<template>\r\n * <Teleport to=\"body\">\r\n * <div\r\n * v-if=\"isDragging\"\r\n * ref=\"elementRef\"\r\n * :style=\"computedStyle\"\r\n * class=\"default-drag-overlay\"\r\n * >\r\n * <div\r\n * v-for=\"(element, index) in draggingElements\"\r\n * :key=\"index\"\r\n * v-html=\"element.initialHTML\"\r\n * :style=\"{\r\n * width: `${element.initialRect?.width}px`,\r\n * height: `${element.initialRect?.height}px`,\r\n * }\"\r\n * />\r\n * </div>\r\n * </Teleport>\r\n *</template>\r\n *\r\n *<style scoped>\r\n * .default-drag-overlay {\r\n * position: fixed;\r\n * top: 0;\r\n * left: 0;\r\n * background-color: rgba(0, 0, 0, 0.5);\r\n * transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);\r\n * z-index: 1000;\r\n * }\r\n *</style>\r\n *\r\n * ```\r\n *\r\n * @returns {Object} Container controls and state\r\n * @property {Ref<HTMLElement | null>} elementRef - Reference to be bound to container element\r\n * @property {Ref<IDragElement[]>} draggingElements - Currently dragged elements\r\n * @property {IPointerPosition} pointerPosition - Current pointer coordinates and offsets\r\n * @property {Ref<boolean>} isDragging - Whether drag operation is in progress\r\n */\r\nexport const useDragContainer = () => {\r\n const elementRef = ref<HTMLElement | null>(null);\r\n\r\n const { draggingElements, pointerPosition, isDragging, activeContainer } =\r\n useDnDStore();\r\n\r\n onMounted(() => {\r\n activeContainer.ref = elementRef;\r\n });\r\n\r\n onBeforeUnmount(() => {\r\n activeContainer.ref.value = null;\r\n });\r\n\r\n return {\r\n elementRef,\r\n draggingElements,\r\n pointerPosition,\r\n isDragging,\r\n };\r\n};\r\n","<script setup lang=\"ts\">\r\n import { computed, CSSProperties } from 'vue';\r\n import { useDragContainer } from '../composables/useDragContainer';\r\n\r\n const { elementRef, pointerPosition, isDragging, draggingElements } =\r\n useDragContainer();\r\n\r\n const computedStyle = computed<CSSProperties>(() => ({\r\n transform: `translate3d(${\r\n (pointerPosition.current.value?.x ?? 0) -\r\n (pointerPosition.offset.pixel.value?.x ?? 0)\r\n }px, ${\r\n (pointerPosition.current.value?.y ?? 0) -\r\n (pointerPosition.offset.pixel.value?.y ?? 0)\r\n }px, 0)`,\r\n zIndex: 1000,\r\n position: 'fixed',\r\n top: 0,\r\n left: 0,\r\n transition: '0.3s cubic-bezier(0.165, 0.84, 0.44, 1)',\r\n }));\r\n</script>\r\n\r\n<template>\r\n <div\r\n v-if=\"isDragging\"\r\n ref=\"elementRef\"\r\n :style=\"computedStyle\"\r\n >\r\n <div\r\n v-for=\"[_, element] in draggingElements\"\r\n :key=\"element.id\"\r\n v-html=\"element.initialHTML\"\r\n :style=\"{\r\n width: `${element.initialRect?.width}px`,\r\n height: `${element.initialRect?.height}px`,\r\n }\"\r\n />\r\n </div>\r\n</template>\r\n","<script setup lang=\"ts\">\r\n import { computed } from 'vue';\r\n import { useDnDStore } from '../composables/useDnDStore';\r\n import DefaultOverlay from './DefaultOverlay.vue';\r\n\r\n const { activeContainer } = useDnDStore();\r\n\r\n const overlay = computed(\r\n () => activeContainer.component.value ?? DefaultOverlay\r\n );\r\n</script>\r\n\r\n<template>\r\n <component :is=\"overlay\" />\r\n</template>\r\n","import { createVNode, render } from 'vue';\r\n\r\nimport type { App } from 'vue';\r\nimport DragOverlay from './components/DragOverlay.vue';\r\n\r\nexport const VueDndKitPlugin = {\r\n install(app: App) {\r\n app.component('DragOverlay', DragOverlay);\r\n const originalMount = app.mount;\r\n app.mount = function (rootContainer) {\r\n const instance = originalMount.call(this, rootContainer);\r\n\r\n const rootEl =\r\n typeof rootContainer === 'string'\r\n ? document.querySelector(rootContainer)\r\n : rootContainer;\r\n\r\n if (rootEl && rootEl instanceof Element) {\r\n if (!rootEl.querySelector('#vue-dnd-kit-overlay')) {\r\n const overlayContainer = document.createElement('div');\r\n\r\n overlayContainer.id = 'vue-dnd-kit-overlay';\r\n overlayContainer.style.pointerEvents = 'none';\r\n\r\n rootEl.appendChild(overlayContainer);\r\n const vnode = createVNode(DragOverlay);\r\n render(vnode, overlayContainer);\r\n app.__VUE_DND_KIT_OVERLAY__ = {\r\n container: overlayContainer,\r\n vnode,\r\n };\r\n }\r\n }\r\n\r\n return instance;\r\n };\r\n\r\n // Модифицируем метод unmount для очистки\r\n const originalUnmount = app.unmount;\r\n app.unmount = function () {\r\n if (app.__VUE_DND_KIT_OVERLAY__) {\r\n render(null, app.__VUE_DND_KIT_OVERLAY__.container);\r\n delete app.__VUE_DND_KIT_OVERLAY__;\r\n }\r\n return originalUnmount.call(this);\r\n };\r\n },\r\n};\r\n\r\ndeclare module '@vue/runtime-core' {\r\n export interface App {\r\n __VUE_DND_KIT_OVERLAY__?: {\r\n container: HTMLElement;\r\n vnode: any;\r\n };\r\n }\r\n}\r\n","import type { IBoundingBox, IPoint } from '../types';\r\n\r\nexport const checkCollision = (\r\n boxA: IBoundingBox,\r\n boxB: IBoundingBox\r\n): boolean => {\r\n return (\r\n boxA.x < boxB.x + boxB.width &&\r\n boxA.x + boxA.width > boxB.x &&\r\n boxA.y < boxB.y + boxB.height &&\r\n boxA.y + boxA.height > boxB.y\r\n );\r\n};\r\n\r\nexport const getBoundingBox = (element: HTMLElement | null): IBoundingBox => {\r\n if (!element)\r\n return {\r\n x: 0,\r\n y: 0,\r\n width: 0,\r\n height: 0,\r\n bottom: 0,\r\n left: 0,\r\n right: 0,\r\n top: 0,\r\n };\r\n\r\n const rect = element.getBoundingClientRect();\r\n\r\n return {\r\n bottom: rect.bottom,\r\n left: rect.left,\r\n right: rect.right,\r\n top: rect.top,\r\n x: rect.x,\r\n y: rect.y,\r\n width: rect.width,\r\n height: rect.height,\r\n };\r\n};\r\n\r\nexport const getCenter = (box: IBoundingBox): IPoint => ({\r\n x: box.x + box.width / 2,\r\n y: box.y + box.height / 2,\r\n});\r\n\r\nexport const getOffset = (element: HTMLElement | null, pointer: IPoint) => {\r\n const rect = getBoundingBox(element);\r\n return {\r\n pixel: {\r\n x: pointer.x - rect.x,\r\n y: pointer.y - rect.y,\r\n },\r\n percent: {\r\n x: ((pointer.x - rect.x) / rect.width) * 100,\r\n y: ((pointer.y - rect.y) / rect.height) * 100,\r\n },\r\n };\r\n};\r\n\r\nexport const getDistance = (pointA: IPoint, pointB: IPoint): number => {\r\n const dx = pointB.x - pointA.x;\r\n const dy = pointB.y - pointA.y;\r\n return Math.sqrt(dx * dx + dy * dy);\r\n};\r\n\r\nexport const getOverlapPercent = (\r\n boxA: IBoundingBox,\r\n boxB: IBoundingBox\r\n): number => {\r\n const xOverlap = Math.max(\r\n 0,\r\n Math.min(boxA.x + boxA.width, boxB.x + boxB.width) -\r\n Math.max(boxA.x, boxB.x)\r\n );\r\n const yOverlap = Math.max(\r\n 0,\r\n Math.min(boxA.y + boxA.height, boxB.y + boxB.height) -\r\n Math.max(boxA.y, boxB.y)\r\n );\r\n\r\n const overlapArea = xOverlap * yOverlap;\r\n\r\n const boxAArea = boxA.width * boxA.height;\r\n const boxBArea = boxB.width * boxB.height;\r\n\r\n // Возвращаем среднее значение процентов перекрытия относительно обоих элементов\r\n return ((overlapArea / boxAArea) * 100 + (overlapArea / boxBArea) * 100) / 2;\r\n};\r\n","export const draggableDataName = 'data-vue-dnd-kit-draggable';\r\nexport const droppableDataName = 'data-vue-dnd-kit-droppable';\r\n","export const preventEvent = (event: Event) => {\r\n event.preventDefault();\r\n \r\n};\r\n\r\n","import { computed, ref, shallowRef, useId } from 'vue';\r\n\r\nimport type { IUseDragOptions } from '../types';\r\nimport { draggableDataName } from '../utils/namespaces';\r\nimport { preventEvent } from '../utils/events';\r\nimport { useDnDStore } from '../composables/useDnDStore';\r\n\r\nexport const useElementManager = (options?: IUseDragOptions) => {\r\n const {\r\n elementsMap,\r\n draggingElements,\r\n hovered,\r\n selectedElementsMap,\r\n isDragging: isDragStarted,\r\n visibleElements,\r\n handleDragElementIntersection,\r\n } = useDnDStore();\r\n\r\n const elementRef = ref<HTMLElement | null>(null);\r\n const isOvered = computed<boolean>(\r\n () =>\r\n visibleElements.value.has(elementRef.value as HTMLElement) &&\r\n hovered.element.value === elementRef.value\r\n );\r\n\r\n const id = shallowRef(options?.id || useId());\r\n\r\n const isDragging = computed<boolean>(() => {\r\n if (!elementRef.value) return false;\r\n if (!visibleElements.value.has(elementRef.value)) return false;\r\n return draggingElements.value.has(elementRef.value);\r\n });\r\n\r\n const isAllowed = computed<boolean>(() => {\r\n if (!elementRef.value) return false;\r\n if (!isDragStarted.value) return false;\r\n if (!visibleElements.value.has(elementRef.value)) return false;\r\n\r\n const currentElement = elementsMap.value.get(elementRef.value);\r\n if (!currentElement?.groups.length) return true;\r\n\r\n return !Array.from(draggingElements.value.entries()).some(\r\n ([_, draggingElement]) => {\r\n if (!draggingElement.groups.length) return false;\r\n return !draggingElement.groups.some((group) =>\r\n currentElement.groups.includes(group)\r\n );\r\n }\r\n );\r\n });\r\n\r\n const registerElement = () => {\r\n if (!elementRef.value) throw new Error('ElementRef is not set');\r\n\r\n elementsMap.value.set(elementRef.value, {\r\n node: elementRef.value,\r\n groups: options?.groups ?? [],\r\n layer: options?.layer ?? null,\r\n defaultLayer: options?.layer ?? null,\r\n events: options?.events ?? {},\r\n data: options?.data ?? null,\r\n id: id.value,\r\n });\r\n\r\n handleDragElementIntersection('add', elementRef.value);\r\n\r\n elementRef.value.addEventListener('dragstart', preventEvent);\r\n elementRef.value.addEventListener('drag', preventEvent);\r\n elementRef.value.setAttribute(draggableDataName, 'true');\r\n elementRef.value.setAttribute('draggable', 'false');\r\n };\r\n\r\n const unregisterElement = () => {\r\n if (!elementRef.value) return;\r\n\r\n handleDragElementIntersection('remove', elementRef.value);\r\n\r\n elementsMap.value.delete(elementRef.value);\r\n selectedElementsMap.value.delete(elementRef.value);\r\n\r\n elementRef.value.removeEventListener('dragstart', preventEvent);\r\n elementRef.value.removeEventListener('drag', preventEvent);\r\n elementRef.value.removeAttribute(draggableDataName);\r\n elementRef.value.removeAttribute('draggable');\r\n };\r\n\r\n return {\r\n elementRef,\r\n registerElement,\r\n unregisterElement,\r\n isDragging,\r\n isOvered,\r\n isAllowed,\r\n id,\r\n };\r\n};\r\n","export const isDescendant = (\r\n element: HTMLElement | Element | null,\r\n container: HTMLElement | Element\r\n): boolean => {\r\n if (!element) return false;\r\n return container.contains(element);\r\n};\r\n","import {\r\n checkCollision,\r\n getBoundingBox,\r\n getCenter,\r\n getDistance,\r\n getOverlapPercent,\r\n} from './geometry';\r\n\r\nimport { IDnDStore } from '../types';\r\nimport { isDescendant } from './dom';\r\n\r\nexport const defaultCollisionDetection = (store: IDnDStore) => {\r\n const containerRect = getBoundingBox(store.activeContainer.ref.value);\r\n const containerCenter = getCenter(containerRect);\r\n const pointerX = store.pointerPosition.current.value?.x ?? 0;\r\n const pointerY = store.pointerPosition.current.value?.y ?? 0;\r\n\r\n const isPointerInActiveContainer =\r\n containerRect &&\r\n pointerX >= containerRect.x &&\r\n pointerX <= containerRect.x + containerRect.width &&\r\n pointerY >= containerRect.y &&\r\n pointerY <= containerRect.y + containerRect.height;\r\n\r\n const shouldUseNormalPriority = !isPointerInActiveContainer;\r\n\r\n const activeDragNodes = Array.from(store.draggingElements.value.keys());\r\n\r\n const allCollidingElements = Array.from(store.visibleElements.value.entries())\r\n .filter(([node, _]) => {\r\n if (!node) return false;\r\n\r\n const rect = getBoundingBox(node as HTMLElement);\r\n return rect && containerRect && checkCollision(rect, containerRect);\r\n })\r\n .map(([node, element]) => {\r\n const rect = getBoundingBox(node as HTMLElement);\r\n const elementCenter = getCenter(rect);\r\n\r\n const isPointerInElement =\r\n pointerX >= rect.x &&\r\n pointerX <= rect.x + rect.width &&\r\n pointerY >= rect.y &&\r\n pointerY <= rect.y + rect.height;\r\n\r\n const overlapPercent = getOverlapPercent(rect, containerRect);\r\n const centerDistance = getDistance(containerCenter, elementCenter);\r\n\r\n // Вычисляем глубину вложенности\r\n let depth = 0;\r\n for (const [parentNode, _] of store.visibleElements.value.entries()) {\r\n if (\r\n parentNode !== node &&\r\n parentNode &&\r\n node &&\r\n isDescendant(node as HTMLElement, parentNode as HTMLElement)\r\n ) {\r\n depth++;\r\n }\r\n }\r\n\r\n return {\r\n element,\r\n node: node as HTMLElement,\r\n isPointerInElement,\r\n overlapPercent,\r\n depth,\r\n centerDistance,\r\n };\r\n })\r\n .sort((a, b) => {\r\n if (!shouldUseNormalPriority) {\r\n if (a.isPointerInElement && b.isPointerInElement)\r\n return b.depth - a.depth;\r\n if (a.isPointerInElement !== b.isPointerInElement)\r\n return a.isPointerInElement ? -1 : 1;\r\n }\r\n if (Math.abs(a.overlapPercent - b.overlapPercent) <= 1)\r\n return a.centerDistance - b.centerDistance;\r\n return b.overlapPercent - a.overlapPercent;\r\n });\r\n\r\n const allCollidingZones = Array.from(store.visibleZones.value.entries())\r\n .filter(([node, _]) => {\r\n if (\r\n !node ||\r\n activeDragNodes.some(\r\n (dragNode) =>\r\n dragNode &&\r\n isDescendant(node as HTMLElement, dragNode as HTMLElement)\r\n )\r\n )\r\n return false;\r\n\r\n const rect = getBoundingBox(node as HTMLElement);\r\n return rect && containerRect && checkCollision(rect, containerRect);\r\n })\r\n .map(([node, zone]) => {\r\n const rect = getBoundingBox(node as HTMLElement);\r\n const zoneCenter = getCenter(rect);\r\n\r\n const isPointerInElement =\r\n pointerX >= rect.x &&\r\n pointerX <= rect.x + rect.width &&\r\n pointerY >= rect.y &&\r\n pointerY <= rect.y + rect.height;\r\n\r\n const overlapPercent = getOverlapPercent(rect, containerRect);\r\n const centerDistance = getDistance(containerCenter, zoneCenter);\r\n\r\n // Вычисляем глубину вложенности\r\n let depth = 0;\r\n for (const [parentNode, _] of store.visibleZones.value.entries()) {\r\n if (\r\n parentNode !== node &&\r\n parentNode &&\r\n node &&\r\n isDescendant(node as HTMLElement, parentNode as HTMLElement)\r\n ) {\r\n depth++;\r\n }\r\n }\r\n\r\n return {\r\n zone,\r\n node: node as HTMLElement,\r\n isPointerInElement,\r\n overlapPercent,\r\n depth,\r\n centerDistance,\r\n };\r\n })\r\n .sort((a, b) => {\r\n if (!shouldUseNormalPriority) {\r\n if (a.isPointerInElement && b.isPointerInElement)\r\n return b.depth - a.depth;\r\n if (a.isPointerInElement !== b.isPointerInElement)\r\n return a.isPointerInElement ? -1 : 1;\r\n }\r\n if (Math.abs(a.overlapPercent - b.overlapPercent) <= 1)\r\n return a.centerDistance - b.centerDistance;\r\n return b.overlapPercent - a.overlapPercent;\r\n });\r\n\r\n return [\r\n ...allCollidingElements.map((item) => item.node),\r\n ...allCollidingZones.map((item) => item.node),\r\n ];\r\n};\r\n","import type { Ref } from 'vue';\r\nimport { getBoundingBox } from '../utils/geometry';\r\nimport { preventEvent } from '../utils/events';\r\nimport { useDnDStore } from './useDnDStore';\r\n\r\nexport interface IKeyboardOptions {\r\n moveStep?: number;\r\n}\r\n\r\nexport const useKeyboard = (\r\n elementRef: Ref<HTMLElement | null>,\r\n options?: IKeyboardOptions\r\n) => {\r\n const { pointerPosition, keyboard } = useDnDStore();\r\n const moveStep = options?.moveStep || 10;\r\n\r\n const onKeyboardStart = (event: KeyboardEvent) => {\r\n preventEvent(event);\r\n\r\n const rect = getBoundingBox(elementRef.value);\r\n\r\n elementRef.value?.blur();\r\n\r\n const centerX = rect.x + rect.width / 2;\r\n const centerY = rect.y + rect.height / 2;\r\n\r\n pointerPosition.start.value = {\r\n x: centerX,\r\n y: centerY,\r\n };\r\n\r\n pointerPosition.current.value = {\r\n x: centerX,\r\n y: centerY,\r\n };\r\n\r\n pointerPosition.offset.pixel.value = {\r\n x: rect.width / 2,\r\n y: rect.height / 2,\r\n };\r\n\r\n pointerPosition.offset.percent.value = {\r\n x: 50,\r\n y: 50,\r\n };\r\n };\r\n\r\n const onKeyboardMove = () => {\r\n if (!pointerPosition.current.value) return;\r\n\r\n const currentX = pointerPosition.current.value.x;\r\n const currentY = pointerPosition.current.value.y;\r\n\r\n let newX = currentX;\r\n let newY = currentY;\r\n\r\n if (keyboard.w.value) newY -= moveStep;\r\n if (keyboard.s.value) newY += moveStep;\r\n if (keyboard.a.value) newX -= moveStep;\r\n if (keyboard.d.value) newX += moveStep;\r\n\r\n pointerPosition.current.value = {\r\n x: newX,\r\n y: newY,\r\n };\r\n };\r\n\r\n const onKeyboardEnd = () => {\r\n pointerPosition.current.value = null;\r\n pointerPosition.start.value = null;\r\n pointerPosition.offset.pixel.value = null;\r\n pointerPosition.offset.percent.value = null;\r\n };\r\n\r\n return {\r\n onKeyboardStart,\r\n onKeyboardMove,\r\n onKeyboardEnd,\r\n };\r\n};\r\n","import type { Ref } from 'vue';\r\nimport { getOffset } from '../utils/geometry';\r\nimport { useDnDStore } from './useDnDStore';\r\n\r\nexport const usePointer = (elementRef: Ref<HTMLElement | null>) => {\r\n const store = useDnDStore();\r\n\r\n const onPointerStart = (event: PointerEvent) => {\r\n store.pointerPosition.start.value = { x: event.clientX, y: event.clientY };\r\n store.pointerPosition.current.value = {\r\n x: event.clientX,\r\n y: event.clientY,\r\n };\r\n\r\n const { pixel, percent } = getOffset(elementRef.value, {\r\n x: event.clientX,\r\n y: event.clientY,\r\n });\r\n\r\n store.pointerPosition.offset.pixel.value = pixel;\r\n store.pointerPosition.offset.percent.value = percent;\r\n };\r\n\r\n const onPointerMove = (event: PointerEvent | WheelEvent) => {\r\n store.pointerPosition.current.value = {\r\n x: event.clientX,\r\n y: event.clientY,\r\n };\r\n };\r\n\r\n const onPointerEnd = () => {\r\n store.pointerPosition.current.value = null;\r\n store.pointerPosition.start.value = null;\r\n store.pointerPosition.offset.pixel.value = null;\r\n store.pointerPosition.offset.percent.value = null;\r\n };\r\n\r\n return {\r\n onPointerStart,\r\n onPointerMove,\r\n onPointerEnd,\r\n };\r\n};\r\n","import type {\r\n ICollisionDetectionResult,\r\n IDraggingElement,\r\n IUseDragOptions,\r\n} from '../types';\r\n\r\nimport type { Ref } from 'vue';\r\nimport { defaultCollisionDetection } from '../utils/sensor';\r\nimport { isDescendant } from '../utils/dom';\r\nimport { useDnDStore } from './useDnDStore';\r\nimport { useKeyboard } from './useKeyboard';\r\nimport { usePointer } from './usePointer';\r\nimport { useThrottleFn } from '@vueuse/core';\r\n\r\nexport const useSensor = (\r\n elementRef: Ref<HTMLElement | null>,\r\n options?: IUseDragOptions\r\n) => {\r\n const store = useDnDStore();\r\n\r\n const { onPointerStart, onPointerMove, onPointerEnd } =\r\n usePointer(elementRef);\r\n\r\n const { onKeyboardStart, onKeyboardMove, onKeyboardEnd } = useKeyboard(\r\n elementRef,\r\n options?.keyboard\r\n );\r\n\r\n let animationFrameId: number | null = null;\r\n\r\n const getDraggingElements = (\r\n draggableElement: HTMLElement | null\r\n ): Map<HTMLElement | Element, IDraggingElement> => {\r\n if (!draggableElement) return new Map();\r\n\r\n const isDraggableInSelection =\r\n store.selectedElementsMap.value.has(draggableElement);\r\n\r\n if (store.selectedElementsMap.value.size > 0 && isDraggableInSelection) {\r\n const result = new Map<HTMLElement | Element, IDraggingElement>();\r\n\r\n Array.from(store.selectedElementsMap.value.entries()).forEach(\r\n ([node, element]) => {\r\n result.set(node, {\r\n ...element,\r\n initialHTML: element.node?.outerHTML ?? '',\r\n initialRect: element.node?.getBoundingClientRect(),\r\n });\r\n }\r\n );\r\n\r\n return result;\r\n }\r\n\r\n store.selectedElementsMap.value.clear();\r\n\r\n const element = store.elementsMap.value.get(draggableElement);\r\n if (!element) return new Map();\r\n\r\n const result = new Map<HTMLElement | Element, IDraggingElement>();\r\n result.set(draggableElement, {\r\n ...element,\r\n initialHTML: element.node?.outerHTML ?? '',\r\n initialRect: element.node?.getBoundingClientRect(),\r\n });\r\n\r\n return result;\r\n };\r\n\r\n const processUserCollisionResults = (\r\n htmlElements: HTMLElement | HTMLElement[] | Element | Element[] | null\r\n ) => {\r\n if (!htmlElements) {\r\n return { element: null, zone: null };\r\n }\r\n\r\n const elements = Array.isArray(htmlElements)\r\n ? htmlElements\r\n : [htmlElements];\r\n\r\n const activeDragNodes = Array.from(store.draggingElements.value.keys());\r\n\r\n const filteredZoneElement = elements.find((htmlElement) => {\r\n if (!store.visibleZones.value.has(htmlElement)) return false;\r\n\r\n const zone = store.zonesMap.value.get(htmlElement);\r\n if (!zone) return false;\r\n\r\n if (\r\n activeDragNodes.some(\r\n (dragNode) =>\r\n dragNode &&\r\n (dragNode === zone.node ||\r\n isDescendant(zone.node as HTMLElement, dragNode as HTMLElement))\r\n )\r\n )\r\n return false;\r\n\r\n if (zone.groups.length) {\r\n const isCompatible = !Array.from(\r\n store.draggingElements.value.values()\r\n ).some((element) => {\r\n if (!element.groups.length) return false;\r\n return !element.groups.some((group) => zone.groups.includes(group));\r\n });\r\n if (!isCompatible) return false;\r\n }\r\n\r\n return true;\r\n });\r\n\r\n if (!filteredZoneElement) {\r\n return { element: null, zone: null };\r\n }\r\n\r\n const possibleElement = elements.find(\r\n (htmlElement) =>\r\n store.visibleElements.value.has(htmlElement) &&\r\n store.elementsMap.value.has(htmlElement) &&\r\n !activeDragNodes.some(\r\n (dragNode) =>\r\n dragNode &&\r\n (dragNode === htmlElement ||\r\n isDescendant(\r\n htmlElement as HTMLElement,\r\n dragNode as HTMLElement\r\n ) ||\r\n isDescendant(dragNode as HTMLElement, htmlElement as HTMLElement))\r\n ) &&\r\n (htmlElement === filteredZoneElement ||\r\n isDescendant(\r\n htmlElement as HTMLElement,\r\n filteredZoneElement as HTMLElement\r\n ))\r\n );\r\n\r\n return {\r\n element: possibleElement || null,\r\n zone: filteredZoneElement,\r\n };\r\n };\r\n\r\n const detectCollisions = options?.sensor?.setup || defaultCollisionDetection;\r\n\r\n const processCollisionResults = (results: ICollisionDetectionResult) => {\r\n const previousElement = store.hovered.element.value;\r\n const previousZone = store.hovered.zone.value;\r\n\r\n store.hovered.element.value = results.element;\r\n store.hovered.zone.value = results.zone;\r\n\r\n if (previousElement) {\r\n if (store.hovered.element.value !== previousElement) {\r\n store.elementsMap.value.get(previousElement)?.events?.onLeave?.(store);\r\n\r\n if (store.hovered.element.value)\r\n store.elementsMap.value\r\n .get(store.hovered.element.value)\r\n ?.events?.onHover?.(store);\r\n }\r\n }\r\n\r\n if (previousZone) {\r\n if (store.hovered.zone.value !== previousZone) {\r\n store.zonesMap.value.get(previousZone)?.events?.onLeave?.(store);\r\n\r\n if (store.hovered.zone.value)\r\n store.zonesMap.value\r\n .get(store.hovered.zone.value)\r\n ?.events?.onHover?.(store);\r\n }\r\n }\r\n };\r\n\r\n const throttledDetectAndProcess = useThrottleFn(() => {\r\n const htmlElements = detectCollisions(store);\r\n const processedResults = processUserCollisionResults(htmlElements);\r\n processCollisionResults(processedResults);\r\n }, options?.sensor?.throttle ?? 0);\r\n\r\n const animationLoop = () => {\r\n throttledDetectAndProcess();\r\n\r\n animationFrameId = requestAnimationFrame(animationLoop);\r\n };\r\n\r\n const startDetection = () => animationLoop();\r\n\r\n const stopDetection = () => {\r\n if (animationFrameId !== null) {\r\n cancelAnimationFrame(animationFrameId);\r\n animationFrameId = null;\r\n }\r\n };\r\n\r\n const activate = (event: PointerEvent | KeyboardEvent) => {\r\n store.draggingElements.value = getDraggingElements(elementRef.value);\r\n\r\n if (event instanceof PointerEvent) {\r\n onPointerStart(event);\r\n } else {\r\n onKeyboardStart(event);\r\n }\r\n\r\n startDetection();\r\n };\r\n\r\n const track = (event: PointerEvent | WheelEvent | KeyboardEvent) => {\r\n if (event instanceof KeyboardEvent) {\r\n onKeyboardMove();\r\n } else {\r\n onPointerMove(event);\r\n }\r\n };\r\n\r\n const deactivate = (triggerEvents = true) => {\r\n onPointerEnd();\r\n onKeyboardEnd();\r\n\r\n if (triggerEvents) {\r\n if (store.hovered.zone.value) {\r\n const zone = store.zonesMap.value.get(store.hovered.zone.value);\r\n zone?.events.onDrop?.(store);\r\n } else {\r\n Array.from(store.draggingElements.value.values()).forEach((element) =>\r\n element.events.onEnd?.(store)\r\n );\r\n }\r\n\r\n store.selectedElementsMap.value.clear();\r\n }\r\n store.draggingElements.value.clear();\r\n\r\n store.hovered.zone.value = null;\r\n store.hovered.element.value = null;\r\n\r\n stopDetection();\r\n };\r\n\r\n return {\r\n activate,\r\n track,\r\n deactivate,\r\n };\r\n};\r\n","import { Ref, markRaw } from 'vue';\r\n\r\nimport type { IUseDragOptions } from '../types';\r\nimport { createGlobalState } from '@vueuse/core';\r\nimport { preventEvent } from '../utils/events';\r\nimport { useDnDStore } from '../composables/useDnDStore';\r\nimport { useSensor } from '../composables/useSensor';\r\n\r\nenum EKeyboardKey {\r\n ESCAPE = 'Escape',\r\n SPACE = 'Space',\r\n ENTER = 'Enter',\r\n W = 'KeyW',\r\n A = 'KeyA',\r\n S = 'KeyS',\r\n D = 'KeyD',\r\n CONTROL = 'ControlLeft',\r\n ALT = 'AltLeft',\r\n SHIFT = 'ShiftLeft',\r\n META = 'MetaLeft',\r\n}\r\n\r\nexport const useEventManager = createGlobalState(() => {\r\n let originalUserSelect = '';\r\n let originalTouchAction = '';\r\n let originalOverscrollBehavior = '';\r\n\r\n let currentMoveHandler: ((event: any) => void) | null = null;\r\n let currentEndHandler: (() => void) | null = null;\r\n let currentCancelHandler: (() => void) | null = null;\r\n let currentScrollHandler: ((event: WheelEvent) => void) | null = null;\r\n let currentKeyHandler: ((event: KeyboardEvent) => void) | null = null;\r\n\r\n const { activeContainer } = useDnDStore();\r\n\r\n const disableInteractions = () => {\r\n const body = document.body;\r\n\r\n originalUserSelect = body.style.userSelect;\r\n\r\n body.style.userSelect = 'none';\r\n\r\n window.addEventListener('contextmenu', preventEvent);\r\n window.addEventListener('selectstart', preventEvent);\r\n window.addEventListener('touchstart', preventEvent);\r\n window.addEventListener('touchmove', preventEvent);\r\n };\r\n\r\n const enableInteractions = () => {\r\n const body = document.body;\r\n\r\n body.style.userSelect = originalUserSelect;\r\n body.style.touchAction = originalTouchAction;\r\n body.style.overscrollBehavior = originalOverscrollBehavior;\r\n\r\n window.removeEventListener('contextmenu', preventEvent);\r\n window.removeEventListener('selectstart', preventEvent);\r\n window.removeEventListener('touchstart', preventEvent);\r\n window.removeEventListener('touchmove', preventEvent);\r\n };\r\n\r\n const clearAllListeners = () => {\r\n if (currentMoveHandler) {\r\n document.removeEventListener('pointermove', currentMoveHandler);\r\n currentMoveHandler = null;\r\n }\r\n\r\n if (currentEndHandler) {\r\n document.removeEventListener('pointerup', currentEndHandler);\r\n currentEndHandler = null;\r\n }\r\n\r\n if (currentCancelHandler) {\r\n currentCancelHandler = null;\r\n }\r\n\r\n if (currentScrollHandler) {\r\n document.removeEventListener('wheel', currentScrollHandler);\r\n currentScrollHandler = null;\r\n }\r\n\r\n if (currentKeyHandler) {\r\n document.removeEventListener('keydown', currentKeyHandler);\r\n document.removeEventListener('keypress', currentKeyHandler);\r\n document.removeEventListener('keyup', currentKeyHandler);\r\n currentKeyHandler = null;\r\n }\r\n };\r\n\r\n const handleDragStart = (\r\n event: PointerEvent | KeyboardEvent,\r\n elementRef: Ref<HTMLElement | null>,\r\n options?: IUseDragOptions\r\n ) => {\r\n clearAllListeners();\r\n\r\n (event.target as HTMLElement).blur();\r\n\r\n if (options?.container)\r\n activeContainer.component.value = markRaw(options.container);\r\n\r\n const { activate, track, deactivate } = useSensor(elementRef, options);\r\n\r\n currentEndHandler = () => {\r\n activeContainer.component.value = null;\r\n enableInteractions();\r\n deactivate(true);\r\n clearAllListeners();\r\n };\r\n\r\n currentCancelHandler = () => {\r\n activeContainer.component.value = null;\r\n enableInteractions();\r\n deactivate(false);\r\n clearAllListeners();\r\n };\r\n\r\n currentMoveHandler = (event: PointerEvent | KeyboardEvent) => track(event);\r\n currentScrollHandler = (event: WheelEvent) => track(event);\r\n currentKeyHandler = (event: KeyboardEvent) => {\r\n if (event.type === 'keyup') {\r\n if (event.code === EKeyboardKey.ESCAPE) currentCancelHandler?.();\r\n if (event.code === EKeyboardKey.ENTER) currentEndHandler?.();\r\n }\r\n\r\n track(event);\r\n };\r\n\r\n disableInteractions();\r\n activate(event);\r\n\r\n document.addEventListener('pointermove', currentMoveHandler);\r\n document.addEventListener('pointerup', currentEndHandler);\r\n document.addEventListener('wheel', currentScrollHandler);\r\n document.addEventListener('keydown', currentKeyHandler);\r\n document.addEventListener('keypress', currentKeyHandler);\r\n document.addEventListener('keyup', currentKeyHandler);\r\n };\r\n\r\n return {\r\n handleDragStart,\r\n };\r\n});\r\n","import { onBeforeUnmount, onMounted } from 'vue';\r\n\r\nimport type { IUseDragOptions } from '../types';\r\nimport { useDnDStore } from './useDnDStore';\r\nimport { useElementManager } from '../managers/useElementManager';\r\nimport { useEventManager } from '../managers/useEventManager';\r\n\r\nexport const useDraggable = (options?: IUseDragOptions) => {\r\n const {\r\n id,\r\n elementRef,\r\n isDragging,\r\n isOvered,\r\n isAllowed,\r\n registerElement,\r\n unregisterElement,\r\n } = useElementManager(options);\r\n\r\n const { pointerPosition } = useDnDStore();\r\n const { handleDragStart: start } = useEventManager();\r\n\r\n const handleDragStart = (event: PointerEvent | KeyboardEvent) =>\r\n start(event, elementRef, options);\r\n\r\n onMounted(registerElement);\r\n onBeforeUnmount(unregisterElement);\r\n\r\n return {\r\n pointerPosition,\r\n elementRef,\r\n isDragging,\r\n isOvered,\r\n isAllowed,\r\n handleDragStart,\r\n id,\r\n };\r\n};\r\n","import { computed, ref } from 'vue';\r\n\r\nimport type { IUseDropOptions } from '../types';\r\nimport { useDnDStore } from '../composables/useDnDStore';\r\n\r\nexport const useZoneManager = (options?: IUseDropOptions) => {\r\n const {\r\n zonesMap,\r\n hovered,\r\n draggingElements,\r\n isDragging,\r\n handleDropZoneIntersection,\r\n } = useDnDStore();\r\n\r\n const elementRef = ref<HTMLElement | null>(null);\r\n\r\n const isOvered = computed<boolean>(() => {\r\n return hovered.zone.value === elementRef.value;\r\n });\r\n\r\n const isAllowed = computed<boolean>(() => {\r\n if (!elementRef.value || !isDragging.value) return false;\r\n\r\n const currentZone = zonesMap.value.get(elementRef.value);\r\n if (!currentZone?.groups.length) return true;\r\n\r\n return !Array.from(draggingElements.value.values()).some((element) => {\r\n if (!element.groups.length) return false;\r\n return !element.groups.some((group) =>\r\n currentZone.groups.includes(group)\r\n );\r\n });\r\n });\r\n\r\n const registerZone = () => {\r\n if (!elementRef.value) throw new Error('elementRef is not set');\r\n\r\n handleDropZoneIntersection('add', elementRef.value);\r\n\r\n zonesMap.value.set(elementRef.value, {\r\n node: elementRef.value,\r\n groups: options?.groups ?? [],\r\n events: options?.events ?? {},\r\n data: options?.data ?? undefined,\r\n });\r\n\r\n elementRef.value.setAttribute('data-dnd-droppable', 'true');\r\n };\r\n\r\n const unregisterZone = () => {\r\n if (!elementRef.value) return;\r\n\r\n handleDropZoneIntersection('remove', elementRef.value);\r\n\r\n zonesMap.value.delete(elementRef.value);\r\n };\r\n\r\n return { elementRef, registerZone, unregisterZone, isOvered, isAllowed };\r\n};\r\n","import { onBeforeUnmount, onMounted } from 'vue';\r\n\r\nimport type { IUseDropOptions } from '../types';\r\nimport { useZoneManager } from '../managers/useZoneManager';\r\n\r\n/**\r\n * Hook for creating drop zones that can accept dragged elements.\r\n * Manages drop zone registration and interaction states.\r\n *\r\n * @param options - Configuration options for drop zone\r\n * @param options.groups - Groups that this zone accepts. Elements can only be\r\n * dropped if they share at least one group with the zone\r\n * @param options.events - Event handlers for drop zone lifecycle\r\n * @param options.events.onDrop - Called when compatible element is dropped\r\n * @param options.events.onHover - Called when compatible element hovers\r\n * @param options.events.onLeave - Called when element leaves zone\r\n * @param options.data - Custom data accessible in event handlers\r\n *\r\n * @returns Object containing:\r\n * - elementRef: Reference to be bound to drop zone element\r\n * - isOvered: Whether zone is currently being hovered by dragged element\r\n * - isAllowed: Whether currently dragged element can be dropped (groups match)\r\n *\r\n * @example\r\n * ```vue\r\n * <template>\r\n * <div\r\n * ref=\"elementRef\"\r\n * :class=\"{\r\n * 'drop-zone': true,\r\n * 'zone-hovered': isOvered,\r\n * 'drop-allowed': isAllowed && isOvered,\r\n * 'drop-forbidden': !isAllowed && isOvered\r\n * }\"\r\n * >\r\n * <slot />\r\n * </div>\r\n * </template>\r\n *\r\n * <script setup lang=\"ts\">\r\n * const { elementRef, isOvered, isAllowed } = useDrop({\r\n * // Зона принимает только элементы из группы 'items'\r\n * groups: ['items'],\r\n * events: {\r\n * onDrop: (store) => {\r\n * const droppedElements = store.draggingElements.value;\r\n * console.log('Elements dropped!', droppedElements);\r\n * },\r\n * onHover: (store) => {\r\n * // Подсветка зоны при наведении совместимого элемента\r\n * if (isAllowed.value) {\r\n * console.log('Compatible element hovering!');\r\n * }\r\n * },\r\n * onLeave: () => {\r\n * console.log('Element left drop zone');\r\n * }\r\n * },\r\n * // Пользовательские данные доступны в обработчиках\r\n * data: {\r\n * zoneId: 'main-drop-zone',\r\n * acceptLimit: 5\r\n * }\r\n * });\r\n * </script>\r\n *\r\n * <style scoped>\r\n * .drop-zone {\r\n * border: 2px dashed #ccc;\r\n * padding: 20px;\r\n * transition: all 0.3s;\r\n * }\r\n *\r\n * .zone-hovered {\r\n * background: #f0f0f0;\r\n * }\r\n *\r\n * .drop-allowed {\r\n * border-color: #4CAF50;\r\n * background: #E8F5E9;\r\n * }\r\n *\r\n * .drop-forbidden {\r\n * border-color: #F44336;\r\n * background: #FFEBEE;\r\n * }\r\n * </style>\r\n * ```\r\n */\r\nexport const useDroppable = (options?: IUseDropOptions) => {\r\n const { elementRef, registerZone, unregisterZone, isOvered, isAllowed } =\r\n useZoneManager(options);\r\n\r\n // Register/unregister drop zone with store\r\n onMounted(registerZone);\r\n onBeforeUnmount(unregisterZone);\r\n\r\n return { elementRef, isOvered, isAllowed };\r\n};\r\n","import { computed, type Ref } from 'vue';\r\nimport { useDnDStore } from './useDnDStore';\r\nimport { isDescendant } from '../utils/dom';\r\n\r\nexport const useSelection = (elementRef: Ref<HTMLElement | null>) => {\r\n const { selectedElementsMap, elementsMap } = useDnDStore();\r\n\r\n const isSelected = computed<boolean>(() =>\r\n elementRef.value ? selectedElementsMap.value.has(elementRef.value) : false\r\n );\r\n\r\n const isParentOfSelected = computed(() => {\r\n if (!elementRef.value) return false;\r\n\r\n for (const [node, _] of selectedElementsMap.value.entries()) {\r\n if (\r\n node &&\r\n isDescendant(node as HTMLElement, elementRef.value as HTMLElement)\r\n ) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n });\r\n\r\n const hasSelectedParent = computed(() => {\r\n if (!elementRef.value) return false;\r\n\r\n for (const [node, _] of selectedElementsMap.value.entries()) {\r\n if (\r\n node &&\r\n isDescendant(elementRef.value as HTMLElement, node as HTMLElement)\r\n ) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n });\r\n\r\n const handleUnselect = () => {\r\n if (!elementRef.value) return;\r\n selectedElementsMap.value.delete(elementRef.value);\r\n };\r\n\r\n const handleSelect = () => {\r\n if (!elementRef.value) return;\r\n const element = elementsMap.value.get(elementRef.value);\r\n if (!element) return;\r\n\r\n if (isParentOfSelected.value) {\r\n // Удаляем все дочерние выбранные элементы\r\n for (const [node, _] of [...selectedElementsMap.value.entries()]) {\r\n if (\r\n node &&\r\n isDescendant(node as HTMLElement, elementRef.value as HTMLElement)\r\n ) {\r\n selectedElementsMap.value.delete(node);\r\n }\r\n }\r\n }\r\n\r\n if (hasSelectedParent.value) {\r\n // Удаляем все родительские выбранные элементы\r\n for (const [node, _] of [...selectedElementsMap.value.entries()]) {\r\n if (\r\n node &&\r\n isDescendant(elementRef.value as HTMLElement, node as HTMLElement)\r\n ) {\r\n selectedElementsMap.value.delete(node);\r\n }\r\n }\r\n }\r\n\r\n selectedElementsMap.value.set(elementRef.value, element);\r\n };\r\n\r\n const handleToggleSelect = () => {\r\n if (!elementRef.value) return;\r\n\r\n selectedElementsMap.value.has(elementRef.value)\r\n ? handleUnselect()\r\n : handleSelect();\r\n };\r\n\r\n return {\r\n handleUnselect,\r\n handleSelect,\r\n handleToggleSelect,\r\n isSelected,\r\n isParentOfSelected,\r\n };\r\n};\r\n"],"names":["_DnDOperations","__publicField","source","index","item","target","sourceIndex","targetIndex","sourceItem","targetItem","store","hoveredElement","hoveredZone","element","_a","_b","_d","_c","_f","_e","_g","items","DnDOperations","useDnDStore","createGlobalState","draggingElements","ref","isDragging","computed","activeContainer","shallowRef","elementsMap","selectedElementsMap","zonesMap","visibleZones","visibleElements","elementObserver","entries","entry","zoneObserver","handleDragElementIntersection","action","handleDropZoneIntersection","onUnmounted","pointerPosition","w","s","a","d","ctrl","shift","alt","meta","useMagicKeys","hovered","useDragContainer","elementRef","onMounted","onBeforeUnmount","computedStyle","overlay","DefaultOverlay","VueDndKitPlugin","app","DragOverlay","originalMount","rootContainer","instance","rootEl","overlayContainer","vnode","createVNode","render","originalUnmount","checkCollision","boxA","boxB","getBoundingBox","rect","getCenter","box","getOffset","pointer","getDistance","pointA","pointB","dx","dy","getOverlapPercent","xOverlap","yOverlap","overlapArea","boxAArea","boxBArea","draggableDataName","preventEvent","event","useElementManager","options","isDragStarted","isOvered","id","useId","isAllowed","currentElement","_","draggingElement","group","isDescendant","container","defaultCollisionDetection","containerRect","containerCenter","pointerX","pointerY","shouldUseNormalPriority","activeDragNodes","allCollidingElements","node","elementCenter","isPointerInElement","overlapPercent","centerDistance","depth","parentNode","b","allCollidingZones","dragNode","zone","zoneCenter","useKeyboard","keyboard","moveStep","centerX","centerY","currentX","currentY","newX","newY","usePointer","pixel","percent","useSensor","onPointerStart","onPointerMove","onPointerEnd","onKeyboardStart","onKeyboardMove","onKeyboardEnd","animationFrameId","getDraggingElements","draggableElement","isDraggableInSelection","result","processUserCollisionResults","htmlElements","elements","filteredZoneElement","htmlElement","detectCollisions","processCollisionResults","results","previousElement","previousZone","_i","_h","_l","_k","_j","throttledDetectAndProcess","useThrottleFn","processedResults","animationLoop","startDetection","stopDetection","triggerEvents","useEventManager","originalUserSelect","originalTouchAction","originalOverscrollBehavior","currentMoveHandler","currentEndHandler","currentCancelHandler","currentScrollHandler","currentKeyHandler","disableInteractions","body","enableInteractions","clearAllListeners","markRaw","activate","track","deactivate","useDraggable","registerElement","unregisterElement","start","handleDragStart","useZoneManager","currentZone","useDroppable","registerZone","unregisterZone","useSelection","isSelected","isParentOfSelected","hasSelectedParent","handleUnselect","handleSelect"],"mappings":"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"}
1
+ {"version":3,"file":"vue-dnd-kit-core.cjs.js","sources":["../src/utils/operations.ts","../src/composables/useDnDStore.ts","../src/composables/useDragContainer.ts","../src/components/DefaultOverlay.vue","../src/components/DragOverlay.vue","../src/plugin.ts","../src/utils/geometry.ts","../src/utils/namespaces.ts","../src/utils/events.ts","../src/managers/useElementManager.ts","../src/utils/dom.ts","../src/utils/sensor.ts","../src/composables/useKeyboard.ts","../src/composables/usePointer.ts","../src/composables/useSensor.ts","../src/managers/useEventManager.ts","../src/composables/useDraggable.ts","../src/managers/useZoneManager.ts","../src/composables/useDroppable.ts","../src/composables/useSelection.ts"],"sourcesContent":["import { IDnDStore } from '../types';\r\n\r\nexport class DnDOperations {\r\n static remove = (source?: any[], index?: number) => {\r\n if (!source || index === undefined) return;\r\n const [item] = source.splice(index, 1);\r\n return item;\r\n };\r\n static insert = (target?: any[], index?: number, item?: any) => {\r\n if (!target || index === undefined) return;\r\n target.splice(index, 0, item);\r\n };\r\n static move = (\r\n source?: any[],\r\n sourceIndex?: number,\r\n target?: any[],\r\n targetIndex?: number\r\n ) => {\r\n if (\r\n !source ||\r\n !target ||\r\n sourceIndex === undefined ||\r\n targetIndex === undefined\r\n )\r\n return;\r\n const item = DnDOperations.remove(source, sourceIndex);\r\n DnDOperations.insert(target, targetIndex, item);\r\n };\r\n static swap = (\r\n source?: any[],\r\n sourceIndex?: number,\r\n target?: any[],\r\n targetIndex?: number\r\n ) => {\r\n if (\r\n !source ||\r\n !target ||\r\n sourceIndex === undefined ||\r\n targetIndex === undefined\r\n )\r\n return;\r\n\r\n const sourceItem = source[sourceIndex];\r\n const targetItem = target[targetIndex];\r\n\r\n source[sourceIndex] = targetItem;\r\n target[targetIndex] = sourceItem;\r\n };\r\n static copy = (\r\n source?: any[],\r\n index?: number,\r\n target?: any[],\r\n targetIndex?: number\r\n ) => {\r\n if (!source || index === undefined || !target || targetIndex === undefined)\r\n return;\r\n const item = source[index];\r\n DnDOperations.insert(target, targetIndex, item);\r\n };\r\n static applyTransfer = (store: IDnDStore) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n\r\n if (hoveredElement) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.move(\r\n element.data?.source,\r\n element.data?.index,\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index\r\n )\r\n );\r\n } else if (hoveredZone) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.move(\r\n element.data?.source,\r\n element.data?.index,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length\r\n )\r\n );\r\n }\r\n };\r\n\r\n static applyCopy = (store: IDnDStore) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n\r\n if (hoveredElement) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.copy(\r\n element.data?.source,\r\n element.data?.index,\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index\r\n )\r\n );\r\n } else if (hoveredZone) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.copy(\r\n element.data?.source,\r\n element.data?.index,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length\r\n )\r\n );\r\n }\r\n };\r\n static applySwap = (store: IDnDStore) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n if (hoveredElement && store.draggingElements.value.size === 1) {\r\n const element = store.draggingElements.value.values().next().value;\r\n DnDOperations.swap(\r\n element?.data?.source,\r\n element?.data?.index,\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index\r\n );\r\n } else if (hoveredZone) {\r\n store.draggingElements.value.forEach((element) =>\r\n DnDOperations.move(\r\n element.data?.source,\r\n element.data?.index,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length\r\n )\r\n );\r\n }\r\n };\r\n static applyRemove = (store: IDnDStore) => {\r\n store.draggingElements.value.forEach((element) => {\r\n if (element.data?.source && element.data?.index !== undefined) {\r\n DnDOperations.remove(element.data.source, element.data.index);\r\n }\r\n });\r\n };\r\n static applyInsert = (store: IDnDStore, items: any[]) => {\r\n const hoveredElement = store.hovered.element.value;\r\n const hoveredZone = store.hovered.zone.value;\r\n if (hoveredElement && items.length > 0) {\r\n items.forEach((item) => {\r\n DnDOperations.insert(\r\n store.elementsMap.value.get(hoveredElement)?.data?.source,\r\n store.elementsMap.value.get(hoveredElement)?.data?.index,\r\n item\r\n );\r\n });\r\n } else if (hoveredZone) {\r\n items.forEach((item) => {\r\n DnDOperations.insert(\r\n store.zonesMap.value.get(hoveredZone)?.data?.source,\r\n store.zonesMap.value.get(hoveredZone)?.data?.source?.length,\r\n item\r\n );\r\n });\r\n }\r\n };\r\n}\r\n","import type {\r\n IDragElement,\r\n IDraggingElement,\r\n IDropZone,\r\n IPoint,\r\n} from '../types';\r\nimport { computed, ref, shallowRef, type Component, onUnmounted } from 'vue';\r\nimport { createGlobalState, useMagicKeys } from '@vueuse/core';\r\n\r\nexport const useDnDStore = createGlobalState(() => {\r\n const draggingElements = ref<Map<HTMLElement | Element, IDraggingElement>>(\r\n new Map()\r\n );\r\n const isDragging = computed<boolean>(() => draggingElements.value.size > 0);\r\n\r\n const activeContainer = {\r\n component: ref<Component | null>(null),\r\n ref: shallowRef<HTMLElement | null>(null),\r\n };\r\n\r\n const elementsMap = ref<Map<HTMLElement | Element, IDragElement>>(new Map());\r\n const selectedElementsMap = ref<Map<HTMLElement | Element, IDragElement>>(\r\n new Map()\r\n );\r\n const zonesMap = ref<Map<HTMLElement | Element, IDropZone>>(new Map());\r\n const visibleZones = ref<Set<HTMLElement | Element>>(new Set());\r\n const visibleElements = ref<Set<HTMLElement | Element>>(new Set());\r\n\r\n // Создаем IntersectionObserver для отслеживания видимости элементов\r\n const elementObserver = new IntersectionObserver((entries) => {\r\n entries.forEach((entry) =>\r\n visibleElements.value[entry.isIntersecting ? 'add' : 'delete'](\r\n entry.target\r\n )\r\n );\r\n });\r\n const zoneObserver = new IntersectionObserver((entries) => {\r\n entries.forEach((entry) =>\r\n visibleZones.value[entry.isIntersecting ? 'add' : 'delete'](entry.target)\r\n );\r\n });\r\n\r\n const handleDragElementIntersection = (\r\n action: 'add' | 'remove',\r\n element: HTMLElement | Element\r\n ) => {\r\n if (action === 'add') {\r\n elementObserver.observe(element);\r\n } else {\r\n elementObserver.unobserve(element);\r\n visibleElements.value.delete(element);\r\n }\r\n };\r\n\r\n const handleDropZoneIntersection = (\r\n action: 'add' | 'remove',\r\n element: HTMLElement | Element\r\n ) => {\r\n if (action === 'add') {\r\n zoneObserver.observe(element);\r\n } else {\r\n zoneObserver.unobserve(element);\r\n visibleZones.value.delete(element);\r\n }\r\n };\r\n\r\n onUnmounted(() => {\r\n elementObserver.disconnect();\r\n zoneObserver.disconnect();\r\n });\r\n\r\n const pointerPosition = {\r\n start: shallowRef<IPoint | null>(null),\r\n current: shallowRef<IPoint | null>(null),\r\n offset: {\r\n percent: shallowRef<IPoint | null>(null),\r\n pixel: shallowRef<IPoint | null>(null),\r\n },\r\n };\r\n\r\n const { w, s, a, d, ctrl, shift, alt, meta } = useMagicKeys();\r\n\r\n const hovered = {\r\n zone: shallowRef<HTMLElement | Element | null>(null),\r\n element: shallowRef<HTMLElement | Element | null>(null),\r\n };\r\n\r\n return {\r\n draggingElements,\r\n isDragging,\r\n activeContainer,\r\n elementsMap,\r\n selectedElementsMap,\r\n zonesMap,\r\n visibleZones,\r\n visibleElements,\r\n pointerPosition,\r\n keyboard: {\r\n w,\r\n s,\r\n a,\r\n d,\r\n ctrl,\r\n shift,\r\n alt,\r\n meta,\r\n },\r\n hovered,\r\n handleDragElementIntersection,\r\n handleDropZoneIntersection,\r\n };\r\n});\r\n","import { onBeforeUnmount, onMounted, ref } from 'vue';\r\n\r\nimport { useDnDStore } from './useDnDStore';\r\n\r\n/**\r\n * Hook for creating custom drag container with overlay management.\r\n * Provides functionality for controlling drag visualization and element positioning.\r\n *\r\n * This hook is typically used to create custom drag overlays, layers,\r\n * and control how dragged elements are displayed during drag operations.\r\n *\r\n * @example\r\n * ```vue\r\n * <script setup lang=\"ts\">\r\n * import { computed } from 'vue';\r\n * import { useDragContainer } from '../composables/useDragContainer';\r\n *\r\n * const { elementRef, pointerPosition, isDragging, draggingElements } =\r\n * useDragContainer();\r\n *\r\n * const computedStyle = computed(() => ({\r\n * transform: `translate3d(${\r\n * (pointerPosition.current.value?.x ?? 0) -\r\n * (pointerPosition.offset.pixel.value?.x ?? 0)\r\n * }px, ${\r\n * (pointerPosition.current.value?.y ?? 0) -\r\n * (pointerPosition.offset.pixel.value?.y ?? 0)\r\n * }px, 0)`,\r\n * }));\r\n *</script>\r\n *\r\n *<template>\r\n * <Teleport to=\"body\">\r\n * <div\r\n * v-if=\"isDragging\"\r\n * ref=\"elementRef\"\r\n * :style=\"computedStyle\"\r\n * class=\"default-drag-overlay\"\r\n * >\r\n * <div\r\n * v-for=\"(element, index) in draggingElements\"\r\n * :key=\"index\"\r\n * v-html=\"element.initialHTML\"\r\n * :style=\"{\r\n * width: `${element.initialRect?.width}px`,\r\n * height: `${element.initialRect?.height}px`,\r\n * }\"\r\n * />\r\n * </div>\r\n * </Teleport>\r\n *</template>\r\n *\r\n *<style scoped>\r\n * .default-drag-overlay {\r\n * position: fixed;\r\n * top: 0;\r\n * left: 0;\r\n * background-color: rgba(0, 0, 0, 0.5);\r\n * transition: 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);\r\n * z-index: 1000;\r\n * }\r\n *</style>\r\n *\r\n * ```\r\n *\r\n * @returns {Object} Container controls and state\r\n * @property {Ref<HTMLElement | null>} elementRef - Reference to be bound to container element\r\n * @property {Ref<IDragElement[]>} draggingElements - Currently dragged elements\r\n * @property {IPointerPosition} pointerPosition - Current pointer coordinates and offsets\r\n * @property {Ref<boolean>} isDragging - Whether drag operation is in progress\r\n */\r\nexport const useDragContainer = () => {\r\n const elementRef = ref<HTMLElement | null>(null);\r\n\r\n const { draggingElements, pointerPosition, isDragging, activeContainer } =\r\n useDnDStore();\r\n\r\n onMounted(() => {\r\n activeContainer.ref = elementRef;\r\n });\r\n\r\n onBeforeUnmount(() => {\r\n activeContainer.ref.value = null;\r\n });\r\n\r\n return {\r\n elementRef,\r\n draggingElements,\r\n pointerPosition,\r\n isDragging,\r\n };\r\n};\r\n","<script setup lang=\"ts\">\r\n import { computed, CSSProperties } from 'vue';\r\n import { useDragContainer } from '../composables/useDragContainer';\r\n\r\n const { elementRef, pointerPosition, isDragging, draggingElements } =\r\n useDragContainer();\r\n\r\n const computedStyle = computed<CSSProperties>(() => ({\r\n transform: `translate3d(${\r\n (pointerPosition.current.value?.x ?? 0) -\r\n (pointerPosition.offset.pixel.value?.x ?? 0)\r\n }px, ${\r\n (pointerPosition.current.value?.y ?? 0) -\r\n (pointerPosition.offset.pixel.value?.y ?? 0)\r\n }px, 0)`,\r\n zIndex: 1000,\r\n position: 'fixed',\r\n top: 0,\r\n left: 0,\r\n transition: '0.3s cubic-bezier(0.165, 0.84, 0.44, 1)',\r\n }));\r\n</script>\r\n\r\n<template>\r\n <div\r\n v-if=\"isDragging\"\r\n ref=\"elementRef\"\r\n :style=\"computedStyle\"\r\n >\r\n <div\r\n v-for=\"[_, element] in draggingElements\"\r\n :key=\"element.id\"\r\n v-html=\"element.initialHTML\"\r\n :style=\"{\r\n width: `${element.initialRect?.width}px`,\r\n height: `${element.initialRect?.height}px`,\r\n }\"\r\n />\r\n </div>\r\n</template>\r\n","<script setup lang=\"ts\">\r\n import { computed } from 'vue';\r\n import { useDnDStore } from '../composables/useDnDStore';\r\n import DefaultOverlay from './DefaultOverlay.vue';\r\n\r\n const { activeContainer } = useDnDStore();\r\n\r\n const overlay = computed(\r\n () => activeContainer.component.value ?? DefaultOverlay\r\n );\r\n</script>\r\n\r\n<template>\r\n <component :is=\"overlay\" />\r\n</template>\r\n","import { createVNode, render } from 'vue';\r\n\r\nimport type { App } from 'vue';\r\nimport DragOverlay from './components/DragOverlay.vue';\r\n\r\nexport const VueDndKitPlugin = {\r\n install(app: App) {\r\n app.component('DragOverlay', DragOverlay);\r\n const originalMount = app.mount;\r\n app.mount = function (rootContainer) {\r\n const instance = originalMount.call(this, rootContainer);\r\n\r\n const rootEl =\r\n typeof rootContainer === 'string'\r\n ? document.querySelector(rootContainer)\r\n : rootContainer;\r\n\r\n if (rootEl && rootEl instanceof Element) {\r\n if (!rootEl.querySelector('#vue-dnd-kit-overlay')) {\r\n const overlayContainer = document.createElement('div');\r\n\r\n overlayContainer.id = 'vue-dnd-kit-overlay';\r\n overlayContainer.style.pointerEvents = 'none';\r\n\r\n rootEl.appendChild(overlayContainer);\r\n const vnode = createVNode(DragOverlay);\r\n render(vnode, overlayContainer);\r\n app.__VUE_DND_KIT_OVERLAY__ = {\r\n container: overlayContainer,\r\n vnode,\r\n };\r\n }\r\n }\r\n\r\n return instance;\r\n };\r\n\r\n // Модифицируем метод unmount для очистки\r\n const originalUnmount = app.unmount;\r\n app.unmount = function () {\r\n if (app.__VUE_DND_KIT_OVERLAY__) {\r\n render(null, app.__VUE_DND_KIT_OVERLAY__.container);\r\n delete app.__VUE_DND_KIT_OVERLAY__;\r\n }\r\n return originalUnmount.call(this);\r\n };\r\n },\r\n};\r\n\r\ndeclare module '@vue/runtime-core' {\r\n export interface App {\r\n __VUE_DND_KIT_OVERLAY__?: {\r\n container: HTMLElement;\r\n vnode: any;\r\n };\r\n }\r\n}\r\n","import type { IBoundingBox, IPoint } from '../types';\r\n\r\nexport const checkCollision = (\r\n boxA: IBoundingBox,\r\n boxB: IBoundingBox\r\n): boolean => {\r\n return (\r\n boxA.x < boxB.x + boxB.width &&\r\n boxA.x + boxA.width > boxB.x &&\r\n boxA.y < boxB.y + boxB.height &&\r\n boxA.y + boxA.height > boxB.y\r\n );\r\n};\r\n\r\nexport const getBoundingBox = (element: HTMLElement | null): IBoundingBox => {\r\n if (!element)\r\n return {\r\n x: 0,\r\n y: 0,\r\n width: 0,\r\n height: 0,\r\n bottom: 0,\r\n left: 0,\r\n right: 0,\r\n top: 0,\r\n };\r\n\r\n const rect = element.getBoundingClientRect();\r\n\r\n return {\r\n bottom: rect.bottom,\r\n left: rect.left,\r\n right: rect.right,\r\n top: rect.top,\r\n x: rect.x,\r\n y: rect.y,\r\n width: rect.width,\r\n height: rect.height,\r\n };\r\n};\r\n\r\nexport const getCenter = (box: IBoundingBox): IPoint => ({\r\n x: box.x + box.width / 2,\r\n y: box.y + box.height / 2,\r\n});\r\n\r\nexport const getOffset = (element: HTMLElement | null, pointer: IPoint) => {\r\n const rect = getBoundingBox(element);\r\n return {\r\n pixel: {\r\n x: pointer.x - rect.x,\r\n y: pointer.y - rect.y,\r\n },\r\n percent: {\r\n x: ((pointer.x - rect.x) / rect.width) * 100,\r\n y: ((pointer.y - rect.y) / rect.height) * 100,\r\n },\r\n };\r\n};\r\n\r\nexport const getDistance = (pointA: IPoint, pointB: IPoint): number => {\r\n const dx = pointB.x - pointA.x;\r\n const dy = pointB.y - pointA.y;\r\n return Math.sqrt(dx * dx + dy * dy);\r\n};\r\n\r\nexport const getOverlapPercent = (\r\n boxA: IBoundingBox,\r\n boxB: IBoundingBox\r\n): number => {\r\n const xOverlap = Math.max(\r\n 0,\r\n Math.min(boxA.x + boxA.width, boxB.x + boxB.width) -\r\n Math.max(boxA.x, boxB.x)\r\n );\r\n const yOverlap = Math.max(\r\n 0,\r\n Math.min(boxA.y + boxA.height, boxB.y + boxB.height) -\r\n Math.max(boxA.y, boxB.y)\r\n );\r\n\r\n const overlapArea = xOverlap * yOverlap;\r\n\r\n const boxAArea = boxA.width * boxA.height;\r\n const boxBArea = boxB.width * boxB.height;\r\n\r\n // Возвращаем среднее значение процентов перекрытия относительно обоих элементов\r\n return ((overlapArea / boxAArea) * 100 + (overlapArea / boxBArea) * 100) / 2;\r\n};\r\n","export const draggableDataName = 'data-vue-dnd-kit-draggable';\r\nexport const droppableDataName = 'data-vue-dnd-kit-droppable';\r\n","export const preventEvent = (event: Event) => {\r\n event.preventDefault();\r\n \r\n};\r\n\r\n","import { computed, ref, shallowRef, useId } from 'vue';\r\n\r\nimport type { IUseDragOptions } from '../types';\r\nimport { draggableDataName } from '../utils/namespaces';\r\nimport { preventEvent } from '../utils/events';\r\nimport { useDnDStore } from '../composables/useDnDStore';\r\n\r\nexport const useElementManager = (options?: IUseDragOptions) => {\r\n const {\r\n elementsMap,\r\n draggingElements,\r\n hovered,\r\n selectedElementsMap,\r\n isDragging: isDragStarted,\r\n visibleElements,\r\n handleDragElementIntersection,\r\n } = useDnDStore();\r\n\r\n const elementRef = ref<HTMLElement | null>(null);\r\n const isOvered = computed<boolean>(\r\n () =>\r\n visibleElements.value.has(elementRef.value as HTMLElement) &&\r\n hovered.element.value === elementRef.value\r\n );\r\n\r\n const id = shallowRef(options?.id || useId());\r\n\r\n const isDragging = computed<boolean>(() => {\r\n if (!elementRef.value) return false;\r\n if (!visibleElements.value.has(elementRef.value)) return false;\r\n return draggingElements.value.has(elementRef.value);\r\n });\r\n\r\n const isAllowed = computed<boolean>(() => {\r\n if (!elementRef.value) return false;\r\n if (!isDragStarted.value) return false;\r\n if (!visibleElements.value.has(elementRef.value)) return false;\r\n\r\n const currentElement = elementsMap.value.get(elementRef.value);\r\n if (!currentElement?.groups.length) return true;\r\n\r\n return !Array.from(draggingElements.value.entries()).some(\r\n ([_, draggingElement]) => {\r\n if (!draggingElement.groups.length) return false;\r\n return !draggingElement.groups.some((group) =>\r\n currentElement.groups.includes(group)\r\n );\r\n }\r\n );\r\n });\r\n\r\n const registerElement = () => {\r\n if (!elementRef.value) throw new Error('ElementRef is not set');\r\n\r\n elementsMap.value.set(elementRef.value, {\r\n node: elementRef.value,\r\n groups: options?.groups ?? [],\r\n layer: options?.layer ?? null,\r\n defaultLayer: options?.layer ?? null,\r\n events: options?.events ?? {},\r\n data: options?.data ?? null,\r\n id: id.value,\r\n });\r\n\r\n handleDragElementIntersection('add', elementRef.value);\r\n\r\n elementRef.value.addEventListener('dragstart', preventEvent);\r\n elementRef.value.addEventListener('drag', preventEvent);\r\n elementRef.value.setAttribute(draggableDataName, 'true');\r\n elementRef.value.setAttribute('draggable', 'false');\r\n };\r\n\r\n const unregisterElement = () => {\r\n if (!elementRef.value) return;\r\n\r\n handleDragElementIntersection('remove', elementRef.value);\r\n\r\n elementsMap.value.delete(elementRef.value);\r\n selectedElementsMap.value.delete(elementRef.value);\r\n\r\n elementRef.value.removeEventListener('dragstart', preventEvent);\r\n elementRef.value.removeEventListener('drag', preventEvent);\r\n elementRef.value.removeAttribute(draggableDataName);\r\n elementRef.value.removeAttribute('draggable');\r\n };\r\n\r\n return {\r\n elementRef,\r\n registerElement,\r\n unregisterElement,\r\n isDragging,\r\n isOvered,\r\n isAllowed,\r\n id,\r\n };\r\n};\r\n","export const isDescendant = (\r\n element: HTMLElement | Element | null,\r\n container: HTMLElement | Element\r\n): boolean => {\r\n if (!element) return false;\r\n return container.contains(element);\r\n};\r\n","import {\r\n checkCollision,\r\n getBoundingBox,\r\n getCenter,\r\n getDistance,\r\n getOverlapPercent,\r\n} from './geometry';\r\n\r\nimport { IDnDStore } from '../types';\r\nimport { isDescendant } from './dom';\r\n\r\nexport const defaultCollisionDetection = (store: IDnDStore) => {\r\n const containerRect = getBoundingBox(store.activeContainer.ref.value);\r\n const containerCenter = getCenter(containerRect);\r\n const pointerX = store.pointerPosition.current.value?.x ?? 0;\r\n const pointerY = store.pointerPosition.current.value?.y ?? 0;\r\n\r\n const isPointerInActiveContainer =\r\n containerRect &&\r\n pointerX >= containerRect.x &&\r\n pointerX <= containerRect.x + containerRect.width &&\r\n pointerY >= containerRect.y &&\r\n pointerY <= containerRect.y + containerRect.height;\r\n\r\n const shouldUseNormalPriority = !isPointerInActiveContainer;\r\n\r\n const activeDragNodes = Array.from(store.draggingElements.value.keys());\r\n\r\n const allCollidingElements = Array.from(store.visibleElements.value.entries())\r\n .filter(([node, _]) => {\r\n if (!node) return false;\r\n\r\n const rect = getBoundingBox(node as HTMLElement);\r\n return rect && containerRect && checkCollision(rect, containerRect);\r\n })\r\n .map(([node, element]) => {\r\n const rect = getBoundingBox(node as HTMLElement);\r\n const elementCenter = getCenter(rect);\r\n\r\n const isPointerInElement =\r\n pointerX >= rect.x &&\r\n pointerX <= rect.x + rect.width &&\r\n pointerY >= rect.y &&\r\n pointerY <= rect.y + rect.height;\r\n\r\n const overlapPercent = getOverlapPercent(rect, containerRect);\r\n const centerDistance = getDistance(containerCenter, elementCenter);\r\n\r\n // Вычисляем глубину вложенности\r\n let depth = 0;\r\n for (const [parentNode, _] of store.visibleElements.value.entries()) {\r\n if (\r\n parentNode !== node &&\r\n parentNode &&\r\n node &&\r\n isDescendant(node as HTMLElement, parentNode as HTMLElement)\r\n ) {\r\n depth++;\r\n }\r\n }\r\n\r\n return {\r\n element,\r\n node: node as HTMLElement,\r\n isPointerInElement,\r\n overlapPercent,\r\n depth,\r\n centerDistance,\r\n };\r\n })\r\n .sort((a, b) => {\r\n if (!shouldUseNormalPriority) {\r\n if (a.isPointerInElement && b.isPointerInElement)\r\n return b.depth - a.depth;\r\n if (a.isPointerInElement !== b.isPointerInElement)\r\n return a.isPointerInElement ? -1 : 1;\r\n }\r\n if (Math.abs(a.overlapPercent - b.overlapPercent) <= 1)\r\n return a.centerDistance - b.centerDistance;\r\n return b.overlapPercent - a.overlapPercent;\r\n });\r\n\r\n const allCollidingZones = Array.from(store.visibleZones.value.entries())\r\n .filter(([node, _]) => {\r\n if (\r\n !node ||\r\n activeDragNodes.some(\r\n (dragNode) =>\r\n dragNode &&\r\n isDescendant(node as HTMLElement, dragNode as HTMLElement)\r\n )\r\n )\r\n return false;\r\n\r\n const rect = getBoundingBox(node as HTMLElement);\r\n return rect && containerRect && checkCollision(rect, containerRect);\r\n })\r\n .map(([node, zone]) => {\r\n const rect = getBoundingBox(node as HTMLElement);\r\n const zoneCenter = getCenter(rect);\r\n\r\n const isPointerInElement =\r\n pointerX >= rect.x &&\r\n pointerX <= rect.x + rect.width &&\r\n pointerY >= rect.y &&\r\n pointerY <= rect.y + rect.height;\r\n\r\n const overlapPercent = getOverlapPercent(rect, containerRect);\r\n const centerDistance = getDistance(containerCenter, zoneCenter);\r\n\r\n // Вычисляем глубину вложенности\r\n let depth = 0;\r\n for (const [parentNode, _] of store.visibleZones.value.entries()) {\r\n if (\r\n parentNode !== node &&\r\n parentNode &&\r\n node &&\r\n isDescendant(node as HTMLElement, parentNode as HTMLElement)\r\n ) {\r\n depth++;\r\n }\r\n }\r\n\r\n return {\r\n zone,\r\n node: node as HTMLElement,\r\n isPointerInElement,\r\n overlapPercent,\r\n depth,\r\n centerDistance,\r\n };\r\n })\r\n .sort((a, b) => {\r\n if (!shouldUseNormalPriority) {\r\n if (a.isPointerInElement && b.isPointerInElement)\r\n return b.depth - a.depth;\r\n if (a.isPointerInElement !== b.isPointerInElement)\r\n return a.isPointerInElement ? -1 : 1;\r\n }\r\n if (Math.abs(a.overlapPercent - b.overlapPercent) <= 1)\r\n return a.centerDistance - b.centerDistance;\r\n return b.overlapPercent - a.overlapPercent;\r\n });\r\n\r\n return [\r\n ...allCollidingElements.map((item) => item.node),\r\n ...allCollidingZones.map((item) => item.node),\r\n ];\r\n};\r\n","import type { Ref } from 'vue';\r\nimport { getBoundingBox } from '../utils/geometry';\r\nimport { preventEvent } from '../utils/events';\r\nimport { useDnDStore } from './useDnDStore';\r\n\r\nexport interface IKeyboardOptions {\r\n moveStep?: number;\r\n}\r\n\r\nexport const useKeyboard = (\r\n elementRef: Ref<HTMLElement | null>,\r\n options?: IKeyboardOptions\r\n) => {\r\n const { pointerPosition, keyboard } = useDnDStore();\r\n const moveStep = options?.moveStep || 10;\r\n\r\n const onKeyboardStart = (event: KeyboardEvent) => {\r\n preventEvent(event);\r\n\r\n const rect = getBoundingBox(elementRef.value);\r\n\r\n elementRef.value?.blur();\r\n\r\n const centerX = rect.x + rect.width / 2;\r\n const centerY = rect.y + rect.height / 2;\r\n\r\n pointerPosition.start.value = {\r\n x: centerX,\r\n y: centerY,\r\n };\r\n\r\n pointerPosition.current.value = {\r\n x: centerX,\r\n y: centerY,\r\n };\r\n\r\n pointerPosition.offset.pixel.value = {\r\n x: rect.width / 2,\r\n y: rect.height / 2,\r\n };\r\n\r\n pointerPosition.offset.percent.value = {\r\n x: 50,\r\n y: 50,\r\n };\r\n };\r\n\r\n const onKeyboardMove = () => {\r\n if (!pointerPosition.current.value) return;\r\n\r\n const currentX = pointerPosition.current.value.x;\r\n const currentY = pointerPosition.current.value.y;\r\n\r\n let newX = currentX;\r\n let newY = currentY;\r\n\r\n if (keyboard.w.value) newY -= moveStep;\r\n if (keyboard.s.value) newY += moveStep;\r\n if (keyboard.a.value) newX -= moveStep;\r\n if (keyboard.d.value) newX += moveStep;\r\n\r\n pointerPosition.current.value = {\r\n x: newX,\r\n y: newY,\r\n };\r\n };\r\n\r\n const onKeyboardEnd = () => {\r\n pointerPosition.current.value = null;\r\n pointerPosition.start.value = null;\r\n pointerPosition.offset.pixel.value = null;\r\n pointerPosition.offset.percent.value = null;\r\n };\r\n\r\n return {\r\n onKeyboardStart,\r\n onKeyboardMove,\r\n onKeyboardEnd,\r\n };\r\n};\r\n","import type { Ref } from 'vue';\r\nimport { getOffset } from '../utils/geometry';\r\nimport { useDnDStore } from './useDnDStore';\r\n\r\nexport const usePointer = (elementRef: Ref<HTMLElement | null>) => {\r\n const store = useDnDStore();\r\n\r\n const onPointerStart = (event: PointerEvent) => {\r\n store.pointerPosition.start.value = { x: event.clientX, y: event.clientY };\r\n store.pointerPosition.current.value = {\r\n x: event.clientX,\r\n y: event.clientY,\r\n };\r\n\r\n const { pixel, percent } = getOffset(elementRef.value, {\r\n x: event.clientX,\r\n y: event.clientY,\r\n });\r\n\r\n store.pointerPosition.offset.pixel.value = pixel;\r\n store.pointerPosition.offset.percent.value = percent;\r\n };\r\n\r\n const onPointerMove = (event: PointerEvent | WheelEvent) => {\r\n store.pointerPosition.current.value = {\r\n x: event.clientX,\r\n y: event.clientY,\r\n };\r\n };\r\n\r\n const onPointerEnd = () => {\r\n store.pointerPosition.current.value = null;\r\n store.pointerPosition.start.value = null;\r\n store.pointerPosition.offset.pixel.value = null;\r\n store.pointerPosition.offset.percent.value = null;\r\n };\r\n\r\n return {\r\n onPointerStart,\r\n onPointerMove,\r\n onPointerEnd,\r\n };\r\n};\r\n","import type {\r\n ICollisionDetectionResult,\r\n IDraggingElement,\r\n IUseDragOptions,\r\n} from '../types';\r\n\r\nimport type { Ref } from 'vue';\r\nimport { defaultCollisionDetection } from '../utils/sensor';\r\nimport { isDescendant } from '../utils/dom';\r\nimport { useDnDStore } from './useDnDStore';\r\nimport { useKeyboard } from './useKeyboard';\r\nimport { usePointer } from './usePointer';\r\nimport { useThrottleFn } from '@vueuse/core';\r\n\r\nexport const useSensor = (\r\n elementRef: Ref<HTMLElement | null>,\r\n options?: IUseDragOptions\r\n) => {\r\n const store = useDnDStore();\r\n\r\n const { onPointerStart, onPointerMove, onPointerEnd } =\r\n usePointer(elementRef);\r\n\r\n const { onKeyboardStart, onKeyboardMove, onKeyboardEnd } = useKeyboard(\r\n elementRef,\r\n options?.keyboard\r\n );\r\n\r\n let animationFrameId: number | null = null;\r\n\r\n const getDraggingElements = (\r\n draggableElement: HTMLElement | null\r\n ): Map<HTMLElement | Element, IDraggingElement> => {\r\n if (!draggableElement) return new Map();\r\n\r\n const isDraggableInSelection =\r\n store.selectedElementsMap.value.has(draggableElement);\r\n\r\n if (store.selectedElementsMap.value.size > 0 && isDraggableInSelection) {\r\n const result = new Map<HTMLElement | Element, IDraggingElement>();\r\n\r\n Array.from(store.selectedElementsMap.value.entries()).forEach(\r\n ([node, element]) => {\r\n result.set(node, {\r\n ...element,\r\n initialHTML: element.node?.outerHTML ?? '',\r\n initialRect: element.node?.getBoundingClientRect(),\r\n });\r\n }\r\n );\r\n\r\n return result;\r\n }\r\n\r\n store.selectedElementsMap.value.clear();\r\n\r\n const element = store.elementsMap.value.get(draggableElement);\r\n if (!element) return new Map();\r\n\r\n const result = new Map<HTMLElement | Element, IDraggingElement>();\r\n result.set(draggableElement, {\r\n ...element,\r\n initialHTML: element.node?.outerHTML ?? '',\r\n initialRect: element.node?.getBoundingClientRect(),\r\n });\r\n\r\n return result;\r\n };\r\n\r\n const processUserCollisionResults = (\r\n htmlElements: HTMLElement | HTMLElement[] | Element | Element[] | null\r\n ) => {\r\n if (!htmlElements) {\r\n return { element: null, zone: null };\r\n }\r\n\r\n const elements = Array.isArray(htmlElements)\r\n ? htmlElements\r\n : [htmlElements];\r\n\r\n const activeDragNodes = Array.from(store.draggingElements.value.keys());\r\n\r\n const filteredZoneElement = elements.find((htmlElement) => {\r\n if (!store.visibleZones.value.has(htmlElement)) return false;\r\n\r\n const zone = store.zonesMap.value.get(htmlElement);\r\n if (!zone) return false;\r\n\r\n if (\r\n activeDragNodes.some(\r\n (dragNode) =>\r\n dragNode &&\r\n (dragNode === zone.node ||\r\n isDescendant(zone.node as HTMLElement, dragNode as HTMLElement))\r\n )\r\n )\r\n return false;\r\n\r\n if (zone.groups.length) {\r\n const isCompatible = !Array.from(\r\n store.draggingElements.value.values()\r\n ).some((element) => {\r\n if (!element.groups.length) return false;\r\n return !element.groups.some((group) => zone.groups.includes(group));\r\n });\r\n if (!isCompatible) return false;\r\n }\r\n\r\n return true;\r\n });\r\n\r\n if (!filteredZoneElement) {\r\n return { element: null, zone: null };\r\n }\r\n\r\n const possibleElement = elements.find(\r\n (htmlElement) =>\r\n store.visibleElements.value.has(htmlElement) &&\r\n store.elementsMap.value.has(htmlElement) &&\r\n !activeDragNodes.some(\r\n (dragNode) =>\r\n dragNode &&\r\n (dragNode === htmlElement ||\r\n isDescendant(\r\n htmlElement as HTMLElement,\r\n dragNode as HTMLElement\r\n ) ||\r\n isDescendant(dragNode as HTMLElement, htmlElement as HTMLElement))\r\n ) &&\r\n (htmlElement === filteredZoneElement ||\r\n isDescendant(\r\n htmlElement as HTMLElement,\r\n filteredZoneElement as HTMLElement\r\n ))\r\n );\r\n\r\n return {\r\n element: possibleElement || null,\r\n zone: filteredZoneElement,\r\n };\r\n };\r\n\r\n const detectCollisions = options?.sensor?.setup || defaultCollisionDetection;\r\n\r\n const processCollisionResults = (results: ICollisionDetectionResult) => {\r\n const previousElement = store.hovered.element.value;\r\n const previousZone = store.hovered.zone.value;\r\n\r\n store.hovered.element.value = results.element;\r\n store.hovered.zone.value = results.zone;\r\n\r\n if (previousElement) {\r\n if (store.hovered.element.value !== previousElement) {\r\n store.elementsMap.value.get(previousElement)?.events?.onLeave?.(store);\r\n\r\n if (store.hovered.element.value)\r\n store.elementsMap.value\r\n .get(store.hovered.element.value)\r\n ?.events?.onHover?.(store);\r\n }\r\n }\r\n\r\n if (previousZone) {\r\n if (store.hovered.zone.value !== previousZone) {\r\n store.zonesMap.value.get(previousZone)?.events?.onLeave?.(store);\r\n\r\n if (store.hovered.zone.value)\r\n store.zonesMap.value\r\n .get(store.hovered.zone.value)\r\n ?.events?.onHover?.(store);\r\n }\r\n }\r\n };\r\n\r\n const throttledDetectAndProcess = useThrottleFn(() => {\r\n const htmlElements = detectCollisions(store);\r\n const processedResults = processUserCollisionResults(htmlElements);\r\n processCollisionResults(processedResults);\r\n }, options?.sensor?.throttle ?? 0);\r\n\r\n const animationLoop = () => {\r\n throttledDetectAndProcess();\r\n\r\n animationFrameId = requestAnimationFrame(animationLoop);\r\n };\r\n\r\n const startDetection = () => animationLoop();\r\n\r\n const stopDetection = () => {\r\n if (animationFrameId !== null) {\r\n cancelAnimationFrame(animationFrameId);\r\n animationFrameId = null;\r\n }\r\n };\r\n\r\n const activate = (event: PointerEvent | KeyboardEvent) => {\r\n store.draggingElements.value = getDraggingElements(elementRef.value);\r\n\r\n if (event instanceof PointerEvent) {\r\n onPointerStart(event);\r\n } else {\r\n onKeyboardStart(event);\r\n }\r\n\r\n startDetection();\r\n };\r\n\r\n const track = (event: PointerEvent | WheelEvent | KeyboardEvent) => {\r\n if (event instanceof KeyboardEvent) {\r\n onKeyboardMove();\r\n } else {\r\n onPointerMove(event);\r\n }\r\n };\r\n\r\n const deactivate = (triggerEvents = true) => {\r\n onPointerEnd();\r\n onKeyboardEnd();\r\n\r\n if (triggerEvents) {\r\n if (store.hovered.zone.value) {\r\n const zone = store.zonesMap.value.get(store.hovered.zone.value);\r\n zone?.events.onDrop?.(store);\r\n } else {\r\n Array.from(store.draggingElements.value.values()).forEach((element) =>\r\n element.events.onEnd?.(store)\r\n );\r\n }\r\n\r\n store.selectedElementsMap.value.clear();\r\n }\r\n store.draggingElements.value.clear();\r\n\r\n store.hovered.zone.value = null;\r\n store.hovered.element.value = null;\r\n\r\n stopDetection();\r\n };\r\n\r\n return {\r\n activate,\r\n track,\r\n deactivate,\r\n };\r\n};\r\n","import { Ref, markRaw } from 'vue';\r\n\r\nimport type { IUseDragOptions } from '../types';\r\nimport { createGlobalState } from '@vueuse/core';\r\nimport { preventEvent } from '../utils/events';\r\nimport { useDnDStore } from '../composables/useDnDStore';\r\nimport { useSensor } from '../composables/useSensor';\r\n\r\nenum EKeyboardKey {\r\n ESCAPE = 'Escape',\r\n SPACE = 'Space',\r\n ENTER = 'Enter',\r\n W = 'KeyW',\r\n A = 'KeyA',\r\n S = 'KeyS',\r\n D = 'KeyD',\r\n CONTROL = 'ControlLeft',\r\n ALT = 'AltLeft',\r\n SHIFT = 'ShiftLeft',\r\n META = 'MetaLeft',\r\n}\r\n\r\nexport const useEventManager = createGlobalState(() => {\r\n let originalUserSelect = '';\r\n let originalTouchAction = '';\r\n let originalOverscrollBehavior = '';\r\n\r\n let currentMoveHandler: ((event: any) => void) | null = null;\r\n let currentEndHandler: (() => void) | null = null;\r\n let currentCancelHandler: (() => void) | null = null;\r\n let currentScrollHandler: ((event: WheelEvent) => void) | null = null;\r\n let currentKeyHandler: ((event: KeyboardEvent) => void) | null = null;\r\n\r\n const { activeContainer } = useDnDStore();\r\n\r\n const disableInteractions = () => {\r\n const body = document.body;\r\n\r\n originalUserSelect = body.style.userSelect;\r\n\r\n body.style.userSelect = 'none';\r\n\r\n window.addEventListener('contextmenu', preventEvent);\r\n window.addEventListener('selectstart', preventEvent);\r\n window.addEventListener('touchstart', preventEvent);\r\n window.addEventListener('touchmove', preventEvent);\r\n };\r\n\r\n const enableInteractions = () => {\r\n const body = document.body;\r\n\r\n body.style.userSelect = originalUserSelect;\r\n body.style.touchAction = originalTouchAction;\r\n body.style.overscrollBehavior = originalOverscrollBehavior;\r\n\r\n window.removeEventListener('contextmenu', preventEvent);\r\n window.removeEventListener('selectstart', preventEvent);\r\n window.removeEventListener('touchstart', preventEvent);\r\n window.removeEventListener('touchmove', preventEvent);\r\n };\r\n\r\n const clearAllListeners = () => {\r\n if (currentMoveHandler) {\r\n document.removeEventListener('pointermove', currentMoveHandler);\r\n currentMoveHandler = null;\r\n }\r\n\r\n if (currentEndHandler) {\r\n document.removeEventListener('pointerup', currentEndHandler);\r\n currentEndHandler = null;\r\n }\r\n\r\n if (currentCancelHandler) {\r\n currentCancelHandler = null;\r\n }\r\n\r\n if (currentScrollHandler) {\r\n document.removeEventListener('wheel', currentScrollHandler);\r\n currentScrollHandler = null;\r\n }\r\n\r\n if (currentKeyHandler) {\r\n document.removeEventListener('keydown', currentKeyHandler);\r\n document.removeEventListener('keypress', currentKeyHandler);\r\n document.removeEventListener('keyup', currentKeyHandler);\r\n currentKeyHandler = null;\r\n }\r\n };\r\n\r\n const handleDragStart = (\r\n event: PointerEvent | KeyboardEvent,\r\n elementRef: Ref<HTMLElement | null>,\r\n options?: IUseDragOptions\r\n ) => {\r\n clearAllListeners();\r\n\r\n (event.target as HTMLElement).blur();\r\n\r\n if (options?.container)\r\n activeContainer.component.value = markRaw(options.container);\r\n\r\n const { activate, track, deactivate } = useSensor(elementRef, options);\r\n\r\n currentEndHandler = () => {\r\n activeContainer.component.value = null;\r\n enableInteractions();\r\n deactivate(true);\r\n clearAllListeners();\r\n };\r\n\r\n currentCancelHandler = () => {\r\n activeContainer.component.value = null;\r\n enableInteractions();\r\n deactivate(false);\r\n clearAllListeners();\r\n };\r\n\r\n currentMoveHandler = (event: PointerEvent | KeyboardEvent) => track(event);\r\n currentScrollHandler = (event: WheelEvent) => track(event);\r\n currentKeyHandler = (event: KeyboardEvent) => {\r\n if (event.type === 'keyup') {\r\n if (event.code === EKeyboardKey.ESCAPE) currentCancelHandler?.();\r\n if (event.code === EKeyboardKey.ENTER) currentEndHandler?.();\r\n }\r\n\r\n track(event);\r\n };\r\n\r\n disableInteractions();\r\n activate(event);\r\n\r\n document.addEventListener('pointermove', currentMoveHandler);\r\n document.addEventListener('pointerup', currentEndHandler);\r\n document.addEventListener('wheel', currentScrollHandler);\r\n document.addEventListener('keydown', currentKeyHandler);\r\n document.addEventListener('keypress', currentKeyHandler);\r\n document.addEventListener('keyup', currentKeyHandler);\r\n };\r\n\r\n return {\r\n handleDragStart,\r\n };\r\n});\r\n","import { onBeforeUnmount, onMounted } from 'vue';\r\n\r\nimport type { IUseDragOptions } from '../types';\r\nimport { useDnDStore } from './useDnDStore';\r\nimport { useElementManager } from '../managers/useElementManager';\r\nimport { useEventManager } from '../managers/useEventManager';\r\n\r\nexport const useDraggable = (options?: IUseDragOptions) => {\r\n const {\r\n id,\r\n elementRef,\r\n isDragging,\r\n isOvered,\r\n isAllowed,\r\n registerElement,\r\n unregisterElement,\r\n } = useElementManager(options);\r\n\r\n const { pointerPosition } = useDnDStore();\r\n const { handleDragStart: start } = useEventManager();\r\n\r\n const handleDragStart = (event: PointerEvent | KeyboardEvent) =>\r\n start(event, elementRef, options);\r\n\r\n onMounted(registerElement);\r\n onBeforeUnmount(unregisterElement);\r\n\r\n return {\r\n pointerPosition,\r\n elementRef,\r\n isDragging,\r\n isOvered,\r\n isAllowed,\r\n handleDragStart,\r\n id,\r\n };\r\n};\r\n","import { computed, ref } from 'vue';\r\n\r\nimport type { IUseDropOptions } from '../types';\r\nimport { useDnDStore } from '../composables/useDnDStore';\r\n\r\nexport const useZoneManager = (options?: IUseDropOptions) => {\r\n const {\r\n zonesMap,\r\n hovered,\r\n draggingElements,\r\n isDragging,\r\n handleDropZoneIntersection,\r\n } = useDnDStore();\r\n\r\n const elementRef = ref<HTMLElement | null>(null);\r\n\r\n const isOvered = computed<boolean>(() => {\r\n return hovered.zone.value === elementRef.value;\r\n });\r\n\r\n const isAllowed = computed<boolean>(() => {\r\n if (!elementRef.value || !isDragging.value) return false;\r\n\r\n const currentZone = zonesMap.value.get(elementRef.value);\r\n if (!currentZone?.groups.length) return true;\r\n\r\n return !Array.from(draggingElements.value.values()).some((element) => {\r\n if (!element.groups.length) return false;\r\n return !element.groups.some((group) =>\r\n currentZone.groups.includes(group)\r\n );\r\n });\r\n });\r\n\r\n const registerZone = () => {\r\n if (!elementRef.value) throw new Error('elementRef is not set');\r\n\r\n handleDropZoneIntersection('add', elementRef.value);\r\n\r\n zonesMap.value.set(elementRef.value, {\r\n node: elementRef.value,\r\n groups: options?.groups ?? [],\r\n events: options?.events ?? {},\r\n data: options?.data ?? undefined,\r\n });\r\n\r\n elementRef.value.setAttribute('data-dnd-droppable', 'true');\r\n };\r\n\r\n const unregisterZone = () => {\r\n if (!elementRef.value) return;\r\n\r\n handleDropZoneIntersection('remove', elementRef.value);\r\n\r\n zonesMap.value.delete(elementRef.value);\r\n };\r\n\r\n return { elementRef, registerZone, unregisterZone, isOvered, isAllowed };\r\n};\r\n","import { onBeforeUnmount, onMounted } from 'vue';\r\n\r\nimport type { IUseDropOptions } from '../types';\r\nimport { useZoneManager } from '../managers/useZoneManager';\r\n\r\n/**\r\n * Hook for creating drop zones that can accept dragged elements.\r\n * Manages drop zone registration and interaction states.\r\n *\r\n * @param options - Configuration options for drop zone\r\n * @param options.groups - Groups that this zone accepts. Elements can only be\r\n * dropped if they share at least one group with the zone\r\n * @param options.events - Event handlers for drop zone lifecycle\r\n * @param options.events.onDrop - Called when compatible element is dropped\r\n * @param options.events.onHover - Called when compatible element hovers\r\n * @param options.events.onLeave - Called when element leaves zone\r\n * @param options.data - Custom data accessible in event handlers\r\n *\r\n * @returns Object containing:\r\n * - elementRef: Reference to be bound to drop zone element\r\n * - isOvered: Whether zone is currently being hovered by dragged element\r\n * - isAllowed: Whether currently dragged element can be dropped (groups match)\r\n *\r\n * @example\r\n * ```vue\r\n * <template>\r\n * <div\r\n * ref=\"elementRef\"\r\n * :class=\"{\r\n * 'drop-zone': true,\r\n * 'zone-hovered': isOvered,\r\n * 'drop-allowed': isAllowed && isOvered,\r\n * 'drop-forbidden': !isAllowed && isOvered\r\n * }\"\r\n * >\r\n * <slot />\r\n * </div>\r\n * </template>\r\n *\r\n * <script setup lang=\"ts\">\r\n * const { elementRef, isOvered, isAllowed } = useDrop({\r\n * // Зона принимает только элементы из группы 'items'\r\n * groups: ['items'],\r\n * events: {\r\n * onDrop: (store) => {\r\n * const droppedElements = store.draggingElements.value;\r\n * console.log('Elements dropped!', droppedElements);\r\n * },\r\n * onHover: (store) => {\r\n * // Подсветка зоны при наведении совместимого элемента\r\n * if (isAllowed.value) {\r\n * console.log('Compatible element hovering!');\r\n * }\r\n * },\r\n * onLeave: () => {\r\n * console.log('Element left drop zone');\r\n * }\r\n * },\r\n * // Пользовательские данные доступны в обработчиках\r\n * data: {\r\n * zoneId: 'main-drop-zone',\r\n * acceptLimit: 5\r\n * }\r\n * });\r\n * </script>\r\n *\r\n * <style scoped>\r\n * .drop-zone {\r\n * border: 2px dashed #ccc;\r\n * padding: 20px;\r\n * transition: all 0.3s;\r\n * }\r\n *\r\n * .zone-hovered {\r\n * background: #f0f0f0;\r\n * }\r\n *\r\n * .drop-allowed {\r\n * border-color: #4CAF50;\r\n * background: #E8F5E9;\r\n * }\r\n *\r\n * .drop-forbidden {\r\n * border-color: #F44336;\r\n * background: #FFEBEE;\r\n * }\r\n * </style>\r\n * ```\r\n */\r\nexport const useDroppable = (options?: IUseDropOptions) => {\r\n const { elementRef, registerZone, unregisterZone, isOvered, isAllowed } =\r\n useZoneManager(options);\r\n\r\n // Register/unregister drop zone with store\r\n onMounted(registerZone);\r\n onBeforeUnmount(unregisterZone);\r\n\r\n return { elementRef, isOvered, isAllowed };\r\n};\r\n","import { computed, type Ref } from 'vue';\r\nimport { useDnDStore } from './useDnDStore';\r\nimport { isDescendant } from '../utils/dom';\r\n\r\nexport const useSelection = (elementRef: Ref<HTMLElement | null>) => {\r\n const { selectedElementsMap, elementsMap } = useDnDStore();\r\n\r\n const isSelected = computed<boolean>(() =>\r\n elementRef.value ? selectedElementsMap.value.has(elementRef.value) : false\r\n );\r\n\r\n const isParentOfSelected = computed(() => {\r\n if (!elementRef.value) return false;\r\n\r\n for (const [node, _] of selectedElementsMap.value.entries()) {\r\n if (\r\n node &&\r\n isDescendant(node as HTMLElement, elementRef.value as HTMLElement)\r\n ) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n });\r\n\r\n const hasSelectedParent = computed(() => {\r\n if (!elementRef.value) return false;\r\n\r\n for (const [node, _] of selectedElementsMap.value.entries()) {\r\n if (\r\n node &&\r\n isDescendant(elementRef.value as HTMLElement, node as HTMLElement)\r\n ) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n });\r\n\r\n const handleUnselect = () => {\r\n if (!elementRef.value) return;\r\n selectedElementsMap.value.delete(elementRef.value);\r\n };\r\n\r\n const handleSelect = () => {\r\n if (!elementRef.value) return;\r\n const element = elementsMap.value.get(elementRef.value);\r\n if (!element) return;\r\n\r\n if (isParentOfSelected.value) {\r\n // Удаляем все дочерние выбранные элементы\r\n for (const [node, _] of [...selectedElementsMap.value.entries()]) {\r\n if (\r\n node &&\r\n isDescendant(node as HTMLElement, elementRef.value as HTMLElement)\r\n ) {\r\n selectedElementsMap.value.delete(node);\r\n }\r\n }\r\n }\r\n\r\n if (hasSelectedParent.value) {\r\n // Удаляем все родительские выбранные элементы\r\n for (const [node, _] of [...selectedElementsMap.value.entries()]) {\r\n if (\r\n node &&\r\n isDescendant(elementRef.value as HTMLElement, node as HTMLElement)\r\n ) {\r\n selectedElementsMap.value.delete(node);\r\n }\r\n }\r\n }\r\n\r\n selectedElementsMap.value.set(elementRef.value, element);\r\n };\r\n\r\n const handleToggleSelect = () => {\r\n if (!elementRef.value) return;\r\n\r\n selectedElementsMap.value.has(elementRef.value)\r\n ? handleUnselect()\r\n : handleSelect();\r\n };\r\n\r\n return {\r\n handleUnselect,\r\n handleSelect,\r\n handleToggleSelect,\r\n isSelected,\r\n isParentOfSelected,\r\n };\r\n};\r\n"],"names":["_DnDOperations","__publicField","source","index","item","target","sourceIndex","targetIndex","sourceItem","targetItem","store","hoveredElement","hoveredZone","element","_a","_b","_d","_c","_f","_e","_g","items","DnDOperations","useDnDStore","createGlobalState","draggingElements","ref","isDragging","computed","activeContainer","shallowRef","elementsMap","selectedElementsMap","zonesMap","visibleZones","visibleElements","elementObserver","entries","entry","zoneObserver","handleDragElementIntersection","action","handleDropZoneIntersection","onUnmounted","pointerPosition","w","s","a","d","ctrl","shift","alt","meta","useMagicKeys","hovered","useDragContainer","elementRef","onMounted","onBeforeUnmount","computedStyle","overlay","DefaultOverlay","VueDndKitPlugin","app","DragOverlay","originalMount","rootContainer","instance","rootEl","overlayContainer","vnode","createVNode","render","originalUnmount","checkCollision","boxA","boxB","getBoundingBox","rect","getCenter","box","getOffset","pointer","getDistance","pointA","pointB","dx","dy","getOverlapPercent","xOverlap","yOverlap","overlapArea","boxAArea","boxBArea","draggableDataName","preventEvent","event","useElementManager","options","isDragStarted","isOvered","id","useId","isAllowed","currentElement","_","draggingElement","group","isDescendant","container","defaultCollisionDetection","containerRect","containerCenter","pointerX","pointerY","shouldUseNormalPriority","activeDragNodes","allCollidingElements","node","elementCenter","isPointerInElement","overlapPercent","centerDistance","depth","parentNode","b","allCollidingZones","dragNode","zone","zoneCenter","useKeyboard","keyboard","moveStep","centerX","centerY","currentX","currentY","newX","newY","usePointer","pixel","percent","useSensor","onPointerStart","onPointerMove","onPointerEnd","onKeyboardStart","onKeyboardMove","onKeyboardEnd","animationFrameId","getDraggingElements","draggableElement","isDraggableInSelection","result","processUserCollisionResults","htmlElements","elements","filteredZoneElement","htmlElement","detectCollisions","processCollisionResults","results","previousElement","previousZone","_i","_h","_l","_k","_j","throttledDetectAndProcess","useThrottleFn","processedResults","animationLoop","startDetection","stopDetection","triggerEvents","useEventManager","originalUserSelect","originalTouchAction","originalOverscrollBehavior","currentMoveHandler","currentEndHandler","currentCancelHandler","currentScrollHandler","currentKeyHandler","disableInteractions","body","enableInteractions","clearAllListeners","markRaw","activate","track","deactivate","useDraggable","registerElement","unregisterElement","start","handleDragStart","useZoneManager","currentZone","useDroppable","registerZone","unregisterZone","useSelection","isSelected","isParentOfSelected","hasSelectedParent","handleUnselect","handleSelect"],"mappings":"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"}
@@ -680,6 +680,7 @@ export {
680
680
  Te as default,
681
681
  O as getBoundingBox,
682
682
  T as useDnDStore,
683
+ Pe as useDragContainer,
683
684
  Ye as useDraggable,
684
685
  Ue as useDroppable,
685
686
  Ve as useSelection
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vue-dnd-kit/core",
3
- "version": "1.0.0",
3
+ "version": "1.1.0",
4
4
  "description": "Core functionality for Vue DnD Kit - a lightweight Vue 3 library for building performant and accessible drag and drop interfaces",
5
5
  "author": "ZiZIGY",
6
6
  "license": "MIT",