zcw-shared 1.16.2 → 1.19.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 +22 -1
- package/dist/hooks/useDraggable.d.ts +34 -0
- package/dist/hooks/useDraggable.js +183 -0
- package/dist/hooks/useDraggable.js.map +1 -0
- package/dist/hooks/useResizable.d.ts +48 -0
- package/dist/hooks/useResizable.js +169 -0
- package/dist/hooks/useResizable.js.map +1 -0
- package/package.json +3 -1
- package/references/blob.d.ts +16 -2
- package/references/browser.d.ts +4 -0
- package/references/dom.d.ts +23 -0
package/README.md
CHANGED
|
@@ -330,6 +330,12 @@ npx tsx tests/*.test.ts
|
|
|
330
330
|
|
|
331
331
|
2. **编译依赖**:改动了函数以后,因为playground中引用的是编译后的shared包,所以需要先编译shared包(`npm run build`),test中才能用到最新的代码。
|
|
332
332
|
|
|
333
|
+
3. **文档同步更新**:每次新增新功能或修改现有功能后,**必须**同步更新VitePress文档:
|
|
334
|
+
- 在 `docs/api/` 目录下更新或创建对应的API文档
|
|
335
|
+
- 在 `docs/examples/` 目录下添加使用示例
|
|
336
|
+
- 确保文档中的TypeScript泛型语法使用反引号包裹(如 `Promise<\`File\`>`)以避免Vue编译错误
|
|
337
|
+
- 运行 `npm run docs:dev` 验证文档编译无误
|
|
338
|
+
|
|
333
339
|
### 1. 添加新函数
|
|
334
340
|
|
|
335
341
|
```bash
|
|
@@ -342,7 +348,14 @@ types/category.d.ts
|
|
|
342
348
|
# 3. 创建测试
|
|
343
349
|
playground/tests/newFunction.test.ts
|
|
344
350
|
|
|
345
|
-
# 4.
|
|
351
|
+
# 4. 更新VitePress文档
|
|
352
|
+
docs/api/category.md # API文档
|
|
353
|
+
docs/examples/category.md # 使用示例
|
|
354
|
+
|
|
355
|
+
# 5. 验证文档编译
|
|
356
|
+
npm run docs:dev
|
|
357
|
+
|
|
358
|
+
# 6. 构建和导出
|
|
346
359
|
npm run build
|
|
347
360
|
```
|
|
348
361
|
|
|
@@ -374,6 +387,9 @@ export function newFunction(
|
|
|
374
387
|
# 类型检查
|
|
375
388
|
npx tsc --noEmit
|
|
376
389
|
|
|
390
|
+
# 验证文档编译
|
|
391
|
+
npm run docs:build
|
|
392
|
+
|
|
377
393
|
# 构建项目
|
|
378
394
|
npm run build
|
|
379
395
|
|
|
@@ -409,6 +425,11 @@ npm run publish:major # 主要版本
|
|
|
409
425
|
1. **JSDoc注释**:详细的函数说明和参数描述
|
|
410
426
|
2. **使用示例**:在测试文件中提供实际使用案例
|
|
411
427
|
3. **类型导出**:确保所有相关类型都可以导入
|
|
428
|
+
4. **VitePress文档**:
|
|
429
|
+
- **API文档**:在 `docs/api/` 目录下为每个模块创建详细的API文档
|
|
430
|
+
- **示例文档**:在 `docs/examples/` 目录下提供实际使用示例
|
|
431
|
+
- **语法规范**:TypeScript泛型语法必须用反引号包裹(如 `Promise<\`File\`>`)
|
|
432
|
+
- **编译验证**:确保文档能够正常编译,无Vue语法错误
|
|
412
433
|
|
|
413
434
|
---
|
|
414
435
|
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { Ref } from 'vue';
|
|
2
|
+
import type { HTMLElement, Document, MouseEvent, TouchEvent } from '../../references/dom.d';
|
|
3
|
+
import type { Window } from '../../references/browser.d';
|
|
4
|
+
export interface Position {
|
|
5
|
+
x: number;
|
|
6
|
+
y: number;
|
|
7
|
+
}
|
|
8
|
+
export interface DraggableEnvironment {
|
|
9
|
+
document: Document;
|
|
10
|
+
window: Window;
|
|
11
|
+
}
|
|
12
|
+
export interface UseDraggableOptions {
|
|
13
|
+
initialPosition?: Position;
|
|
14
|
+
enabled?: boolean;
|
|
15
|
+
onDragStart?: (position: Position, event: MouseEvent | TouchEvent) => void;
|
|
16
|
+
onDrag?: (position: Position, event: MouseEvent | TouchEvent) => void;
|
|
17
|
+
onDragEnd?: (position: Position, event: MouseEvent | TouchEvent) => void;
|
|
18
|
+
boundary?: {
|
|
19
|
+
minX?: number;
|
|
20
|
+
maxX?: number;
|
|
21
|
+
minY?: number;
|
|
22
|
+
maxY?: number;
|
|
23
|
+
};
|
|
24
|
+
useAbsolutePosition?: boolean;
|
|
25
|
+
useTransform?: boolean;
|
|
26
|
+
}
|
|
27
|
+
export declare function useDraggable(targetRef: Ref<HTMLElement | null>, options: UseDraggableOptions | undefined, env: DraggableEnvironment): {
|
|
28
|
+
position: Ref<Position, Position>;
|
|
29
|
+
isDragging: Ref<boolean, boolean>;
|
|
30
|
+
style: Ref<Record<string, string>, Record<string, string>>;
|
|
31
|
+
reset: () => void;
|
|
32
|
+
cleanup: () => void;
|
|
33
|
+
};
|
|
34
|
+
export default useDraggable;
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { ref, onMounted, onUnmounted } from 'vue';
|
|
2
|
+
export function useDraggable(targetRef, options = {}, env) {
|
|
3
|
+
const { initialPosition = { x: 0, y: 0 }, enabled = true, onDragStart, onDrag, onDragEnd, boundary, useAbsolutePosition = true, useTransform = false } = options;
|
|
4
|
+
const position = ref({ ...initialPosition });
|
|
5
|
+
const isDragging = ref(false);
|
|
6
|
+
let startX = 0;
|
|
7
|
+
let startY = 0;
|
|
8
|
+
let initialX = initialPosition.x;
|
|
9
|
+
let initialY = initialPosition.y;
|
|
10
|
+
let positionInitialized = false;
|
|
11
|
+
const applyBoundary = (pos) => {
|
|
12
|
+
if (!boundary)
|
|
13
|
+
return pos;
|
|
14
|
+
const { minX, maxX, minY, maxY } = boundary;
|
|
15
|
+
let { x, y } = pos;
|
|
16
|
+
if (minX !== undefined)
|
|
17
|
+
x = Math.max(minX, x);
|
|
18
|
+
if (maxX !== undefined)
|
|
19
|
+
x = Math.min(maxX, x);
|
|
20
|
+
if (minY !== undefined)
|
|
21
|
+
y = Math.max(minY, y);
|
|
22
|
+
if (maxY !== undefined)
|
|
23
|
+
y = Math.min(maxY, y);
|
|
24
|
+
return { x, y };
|
|
25
|
+
};
|
|
26
|
+
const style = ref({});
|
|
27
|
+
const updateStyle = () => {
|
|
28
|
+
if (!useAbsolutePosition && !useTransform)
|
|
29
|
+
return;
|
|
30
|
+
if (useAbsolutePosition) {
|
|
31
|
+
style.value = {
|
|
32
|
+
position: 'absolute',
|
|
33
|
+
top: `${position.value.y}px`,
|
|
34
|
+
left: `${position.value.x}px`,
|
|
35
|
+
...(useTransform ? {} : { transform: 'none' })
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
else if (useTransform) {
|
|
39
|
+
style.value = {
|
|
40
|
+
transform: `translate(${position.value.x}px, ${position.value.y}px)`
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
const updatePosition = (newPosition) => {
|
|
45
|
+
position.value = applyBoundary(newPosition);
|
|
46
|
+
updateStyle();
|
|
47
|
+
};
|
|
48
|
+
const onMouseDown = (e) => {
|
|
49
|
+
if (!enabled || !targetRef.value)
|
|
50
|
+
return;
|
|
51
|
+
e.stopPropagation();
|
|
52
|
+
e.preventDefault();
|
|
53
|
+
if (!positionInitialized && targetRef.value) {
|
|
54
|
+
const rect = targetRef.value.getBoundingClientRect();
|
|
55
|
+
if (!initialPosition.x && !initialPosition.y) {
|
|
56
|
+
initialX = rect.left;
|
|
57
|
+
initialY = rect.top;
|
|
58
|
+
position.value = { x: initialX, y: initialY };
|
|
59
|
+
}
|
|
60
|
+
positionInitialized = true;
|
|
61
|
+
}
|
|
62
|
+
isDragging.value = true;
|
|
63
|
+
startX = e.clientX - position.value.x;
|
|
64
|
+
startY = e.clientY - position.value.y;
|
|
65
|
+
if (onDragStart) {
|
|
66
|
+
onDragStart({ ...position.value }, e);
|
|
67
|
+
}
|
|
68
|
+
env.document.addEventListener('mousemove', onMouseMove, { passive: false });
|
|
69
|
+
env.document.addEventListener('mouseup', onMouseUp);
|
|
70
|
+
};
|
|
71
|
+
const onMouseMove = (e) => {
|
|
72
|
+
if (!isDragging.value)
|
|
73
|
+
return;
|
|
74
|
+
e.preventDefault();
|
|
75
|
+
env.window.requestAnimationFrame(() => {
|
|
76
|
+
const newPosition = {
|
|
77
|
+
x: e.clientX - startX,
|
|
78
|
+
y: e.clientY - startY
|
|
79
|
+
};
|
|
80
|
+
updatePosition(newPosition);
|
|
81
|
+
if (onDrag) {
|
|
82
|
+
onDrag({ ...position.value }, e);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
const onMouseUp = (e) => {
|
|
87
|
+
if (!isDragging.value)
|
|
88
|
+
return;
|
|
89
|
+
isDragging.value = false;
|
|
90
|
+
if (onDragEnd) {
|
|
91
|
+
onDragEnd({ ...position.value }, e);
|
|
92
|
+
}
|
|
93
|
+
env.document.removeEventListener('mousemove', onMouseMove);
|
|
94
|
+
env.document.removeEventListener('mouseup', onMouseUp);
|
|
95
|
+
};
|
|
96
|
+
const onTouchStart = (e) => {
|
|
97
|
+
if (!enabled || !targetRef.value || e.touches.length !== 1)
|
|
98
|
+
return;
|
|
99
|
+
e.stopPropagation();
|
|
100
|
+
if (!positionInitialized && targetRef.value) {
|
|
101
|
+
const rect = targetRef.value.getBoundingClientRect();
|
|
102
|
+
if (!initialPosition.x && !initialPosition.y) {
|
|
103
|
+
initialX = rect.left;
|
|
104
|
+
initialY = rect.top;
|
|
105
|
+
position.value = { x: initialX, y: initialY };
|
|
106
|
+
}
|
|
107
|
+
positionInitialized = true;
|
|
108
|
+
}
|
|
109
|
+
isDragging.value = true;
|
|
110
|
+
const touch = e.touches[0];
|
|
111
|
+
startX = touch.clientX - position.value.x;
|
|
112
|
+
startY = touch.clientY - position.value.y;
|
|
113
|
+
if (onDragStart) {
|
|
114
|
+
onDragStart({ ...position.value }, e);
|
|
115
|
+
}
|
|
116
|
+
env.document.addEventListener('touchmove', onTouchMove, { passive: false });
|
|
117
|
+
env.document.addEventListener('touchend', onTouchEnd);
|
|
118
|
+
env.document.addEventListener('touchcancel', onTouchEnd);
|
|
119
|
+
};
|
|
120
|
+
const onTouchMove = (e) => {
|
|
121
|
+
if (!isDragging.value || e.touches.length !== 1)
|
|
122
|
+
return;
|
|
123
|
+
e.preventDefault();
|
|
124
|
+
env.window.requestAnimationFrame(() => {
|
|
125
|
+
const touch = e.touches[0];
|
|
126
|
+
const newPosition = {
|
|
127
|
+
x: touch.clientX - startX,
|
|
128
|
+
y: touch.clientY - startY
|
|
129
|
+
};
|
|
130
|
+
updatePosition(newPosition);
|
|
131
|
+
if (onDrag) {
|
|
132
|
+
onDrag({ ...position.value }, e);
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
};
|
|
136
|
+
const onTouchEnd = (e) => {
|
|
137
|
+
if (!isDragging.value)
|
|
138
|
+
return;
|
|
139
|
+
isDragging.value = false;
|
|
140
|
+
if (onDragEnd) {
|
|
141
|
+
onDragEnd({ ...position.value }, e);
|
|
142
|
+
}
|
|
143
|
+
env.document.removeEventListener('touchmove', onTouchMove);
|
|
144
|
+
env.document.removeEventListener('touchend', onTouchEnd);
|
|
145
|
+
env.document.removeEventListener('touchcancel', onTouchEnd);
|
|
146
|
+
};
|
|
147
|
+
const reset = () => {
|
|
148
|
+
updatePosition({ ...initialPosition });
|
|
149
|
+
positionInitialized = false;
|
|
150
|
+
};
|
|
151
|
+
const cleanup = () => {
|
|
152
|
+
env.document.removeEventListener('mousemove', onMouseMove);
|
|
153
|
+
env.document.removeEventListener('mouseup', onMouseUp);
|
|
154
|
+
env.document.removeEventListener('touchmove', onTouchMove);
|
|
155
|
+
env.document.removeEventListener('touchend', onTouchEnd);
|
|
156
|
+
env.document.removeEventListener('touchcancel', onTouchEnd);
|
|
157
|
+
};
|
|
158
|
+
onMounted(() => {
|
|
159
|
+
const element = targetRef.value;
|
|
160
|
+
if (!element)
|
|
161
|
+
return;
|
|
162
|
+
updateStyle();
|
|
163
|
+
element.addEventListener('mousedown', onMouseDown);
|
|
164
|
+
element.addEventListener('touchstart', onTouchStart);
|
|
165
|
+
});
|
|
166
|
+
onUnmounted(() => {
|
|
167
|
+
const element = targetRef.value;
|
|
168
|
+
if (!element)
|
|
169
|
+
return;
|
|
170
|
+
element.removeEventListener('mousedown', onMouseDown);
|
|
171
|
+
element.removeEventListener('touchstart', onTouchStart);
|
|
172
|
+
cleanup();
|
|
173
|
+
});
|
|
174
|
+
return {
|
|
175
|
+
position,
|
|
176
|
+
isDragging,
|
|
177
|
+
style,
|
|
178
|
+
reset,
|
|
179
|
+
cleanup
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
export default useDraggable;
|
|
183
|
+
//# sourceMappingURL=useDraggable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDraggable.js","sourceRoot":"","sources":["../../src/hooks/useDraggable.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { Ref } from 'vue';
|
|
2
|
+
import type { HTMLElement, Document, MouseEvent, TouchEvent } from '../../references/dom.d';
|
|
3
|
+
import type { Window } from '../../references/browser.d';
|
|
4
|
+
export interface Size {
|
|
5
|
+
width: number;
|
|
6
|
+
height: number;
|
|
7
|
+
}
|
|
8
|
+
export interface ResizableEnvironment {
|
|
9
|
+
document: Document;
|
|
10
|
+
window: Window;
|
|
11
|
+
}
|
|
12
|
+
export interface UseResizableOptions {
|
|
13
|
+
initialSize?: Size;
|
|
14
|
+
enabled?: boolean;
|
|
15
|
+
onResizeStart?: (size: Size, event: MouseEvent | TouchEvent) => void;
|
|
16
|
+
onResize?: (size: Size, event: MouseEvent | TouchEvent) => void;
|
|
17
|
+
onResizeEnd?: (size: Size, event: MouseEvent | TouchEvent) => void;
|
|
18
|
+
constraints?: {
|
|
19
|
+
minWidth?: number;
|
|
20
|
+
maxWidth?: number;
|
|
21
|
+
minHeight?: number;
|
|
22
|
+
maxHeight?: number;
|
|
23
|
+
};
|
|
24
|
+
directions?: {
|
|
25
|
+
top?: boolean;
|
|
26
|
+
right?: boolean;
|
|
27
|
+
bottom?: boolean;
|
|
28
|
+
left?: boolean;
|
|
29
|
+
topLeft?: boolean;
|
|
30
|
+
topRight?: boolean;
|
|
31
|
+
bottomLeft?: boolean;
|
|
32
|
+
bottomRight?: boolean;
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
export declare function useResizable(targetRef: Ref<HTMLElement | null>, options: UseResizableOptions | undefined, env: ResizableEnvironment): {
|
|
36
|
+
size: Ref<Size, Size>;
|
|
37
|
+
style: Ref<{
|
|
38
|
+
width: string;
|
|
39
|
+
height: string;
|
|
40
|
+
}, {
|
|
41
|
+
width: string;
|
|
42
|
+
height: string;
|
|
43
|
+
}>;
|
|
44
|
+
isResizing: Ref<boolean, boolean>;
|
|
45
|
+
onResizeHandleMouseDown: (e: MouseEvent | TouchEvent, direction?: string) => void;
|
|
46
|
+
reset: () => void;
|
|
47
|
+
cleanupEventListeners: () => void;
|
|
48
|
+
};
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { ref, onMounted, onUnmounted } from 'vue';
|
|
2
|
+
export function useResizable(targetRef, options = {}, env) {
|
|
3
|
+
const { initialSize = { width: 0, height: 0 }, enabled = true, onResizeStart, onResize, onResizeEnd, constraints = {}, directions = { bottomRight: true } } = options;
|
|
4
|
+
const size = ref({ ...initialSize });
|
|
5
|
+
const isResizing = ref(false);
|
|
6
|
+
let startX = 0;
|
|
7
|
+
let startY = 0;
|
|
8
|
+
let startWidth = 0;
|
|
9
|
+
let startHeight = 0;
|
|
10
|
+
let currentDirection = '';
|
|
11
|
+
let sizeInitialized = false;
|
|
12
|
+
const style = ref({
|
|
13
|
+
width: `${initialSize.width}px`,
|
|
14
|
+
height: `${initialSize.height}px`
|
|
15
|
+
});
|
|
16
|
+
const initializeSize = () => {
|
|
17
|
+
if (!targetRef.value || sizeInitialized)
|
|
18
|
+
return;
|
|
19
|
+
const { width, height } = targetRef.value.getBoundingClientRect();
|
|
20
|
+
if (initialSize.width === 0 && initialSize.height === 0) {
|
|
21
|
+
size.value = { width, height };
|
|
22
|
+
style.value = {
|
|
23
|
+
width: `${width}px`,
|
|
24
|
+
height: `${height}px`
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
size.value = { ...initialSize };
|
|
29
|
+
style.value = {
|
|
30
|
+
width: `${initialSize.width}px`,
|
|
31
|
+
height: `${initialSize.height}px`
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
sizeInitialized = true;
|
|
35
|
+
};
|
|
36
|
+
const onResizeHandleMouseDown = (e, direction = 'bottomRight') => {
|
|
37
|
+
if (!enabled || !targetRef.value)
|
|
38
|
+
return;
|
|
39
|
+
e.stopPropagation();
|
|
40
|
+
e.preventDefault();
|
|
41
|
+
isResizing.value = true;
|
|
42
|
+
currentDirection = direction;
|
|
43
|
+
if ('clientX' in e) {
|
|
44
|
+
startX = e.clientX;
|
|
45
|
+
startY = e.clientY;
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
startX = e.touches[0].clientX;
|
|
49
|
+
startY = e.touches[0].clientY;
|
|
50
|
+
}
|
|
51
|
+
startWidth = targetRef.value.clientWidth;
|
|
52
|
+
startHeight = targetRef.value.clientHeight;
|
|
53
|
+
onResizeStart?.({ width: startWidth, height: startHeight }, e);
|
|
54
|
+
if ('clientX' in e) {
|
|
55
|
+
env.document.addEventListener('mousemove', onResizeMouseMove, { passive: true });
|
|
56
|
+
env.document.addEventListener('mouseup', onResizeMouseUp);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
env.document.addEventListener('touchmove', onResizeTouchMove, { passive: true });
|
|
60
|
+
env.document.addEventListener('touchend', onResizeTouchEnd);
|
|
61
|
+
env.document.addEventListener('touchcancel', onResizeTouchEnd);
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
const onResizeMouseMove = (e) => {
|
|
65
|
+
if (!isResizing.value || !targetRef.value)
|
|
66
|
+
return;
|
|
67
|
+
env.window.requestAnimationFrame(() => {
|
|
68
|
+
if (!targetRef.value)
|
|
69
|
+
return;
|
|
70
|
+
const deltaX = e.clientX - startX;
|
|
71
|
+
const deltaY = e.clientY - startY;
|
|
72
|
+
updateSize(deltaX, deltaY, e);
|
|
73
|
+
});
|
|
74
|
+
};
|
|
75
|
+
const onResizeTouchMove = (e) => {
|
|
76
|
+
if (!isResizing.value || !targetRef.value)
|
|
77
|
+
return;
|
|
78
|
+
env.window.requestAnimationFrame(() => {
|
|
79
|
+
if (!targetRef.value)
|
|
80
|
+
return;
|
|
81
|
+
const deltaX = e.touches[0].clientX - startX;
|
|
82
|
+
const deltaY = e.touches[0].clientY - startY;
|
|
83
|
+
updateSize(deltaX, deltaY, e);
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
const updateSize = (deltaX, deltaY, e) => {
|
|
87
|
+
let newWidth = startWidth;
|
|
88
|
+
let newHeight = startHeight;
|
|
89
|
+
if (currentDirection.includes('right')) {
|
|
90
|
+
newWidth = startWidth + deltaX;
|
|
91
|
+
}
|
|
92
|
+
else if (currentDirection.includes('left')) {
|
|
93
|
+
newWidth = startWidth - deltaX;
|
|
94
|
+
}
|
|
95
|
+
if (currentDirection.includes('bottom')) {
|
|
96
|
+
newHeight = startHeight + deltaY;
|
|
97
|
+
}
|
|
98
|
+
else if (currentDirection.includes('top')) {
|
|
99
|
+
newHeight = startHeight - deltaY;
|
|
100
|
+
}
|
|
101
|
+
if (constraints.minWidth !== undefined) {
|
|
102
|
+
newWidth = Math.max(constraints.minWidth, newWidth);
|
|
103
|
+
}
|
|
104
|
+
if (constraints.maxWidth !== undefined) {
|
|
105
|
+
newWidth = Math.min(constraints.maxWidth, newWidth);
|
|
106
|
+
}
|
|
107
|
+
if (constraints.minHeight !== undefined) {
|
|
108
|
+
newHeight = Math.max(constraints.minHeight, newHeight);
|
|
109
|
+
}
|
|
110
|
+
if (constraints.maxHeight !== undefined) {
|
|
111
|
+
newHeight = Math.min(constraints.maxHeight, newHeight);
|
|
112
|
+
}
|
|
113
|
+
size.value = { width: newWidth, height: newHeight };
|
|
114
|
+
style.value = {
|
|
115
|
+
width: `${newWidth}px`,
|
|
116
|
+
height: `${newHeight}px`
|
|
117
|
+
};
|
|
118
|
+
onResize?.(size.value, e);
|
|
119
|
+
};
|
|
120
|
+
const onResizeMouseUp = (e) => {
|
|
121
|
+
if (!isResizing.value)
|
|
122
|
+
return;
|
|
123
|
+
isResizing.value = false;
|
|
124
|
+
onResizeEnd?.(size.value, e);
|
|
125
|
+
env.document.removeEventListener('mousemove', onResizeMouseMove);
|
|
126
|
+
env.document.removeEventListener('mouseup', onResizeMouseUp);
|
|
127
|
+
};
|
|
128
|
+
const onResizeTouchEnd = (e) => {
|
|
129
|
+
if (!isResizing.value)
|
|
130
|
+
return;
|
|
131
|
+
isResizing.value = false;
|
|
132
|
+
onResizeEnd?.(size.value, e);
|
|
133
|
+
env.document.removeEventListener('touchmove', onResizeTouchMove);
|
|
134
|
+
env.document.removeEventListener('touchend', onResizeTouchEnd);
|
|
135
|
+
env.document.removeEventListener('touchcancel', onResizeTouchEnd);
|
|
136
|
+
};
|
|
137
|
+
const reset = () => {
|
|
138
|
+
size.value = { ...initialSize };
|
|
139
|
+
style.value = {
|
|
140
|
+
width: `${initialSize.width}px`,
|
|
141
|
+
height: `${initialSize.height}px`
|
|
142
|
+
};
|
|
143
|
+
};
|
|
144
|
+
const cleanupEventListeners = () => {
|
|
145
|
+
env.document.removeEventListener('mousemove', onResizeMouseMove);
|
|
146
|
+
env.document.removeEventListener('mouseup', onResizeMouseUp);
|
|
147
|
+
env.document.removeEventListener('touchmove', onResizeTouchMove);
|
|
148
|
+
env.document.removeEventListener('touchend', onResizeTouchEnd);
|
|
149
|
+
env.document.removeEventListener('touchcancel', onResizeTouchEnd);
|
|
150
|
+
};
|
|
151
|
+
onMounted(() => {
|
|
152
|
+
initializeSize();
|
|
153
|
+
});
|
|
154
|
+
onUnmounted(() => {
|
|
155
|
+
cleanupEventListeners();
|
|
156
|
+
});
|
|
157
|
+
onUnmounted(() => {
|
|
158
|
+
cleanupEventListeners();
|
|
159
|
+
});
|
|
160
|
+
return {
|
|
161
|
+
size,
|
|
162
|
+
style,
|
|
163
|
+
isResizing,
|
|
164
|
+
onResizeHandleMouseDown,
|
|
165
|
+
reset,
|
|
166
|
+
cleanupEventListeners
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
//# sourceMappingURL=useResizable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useResizable.js","sourceRoot":"","sources":["../../src/hooks/useResizable.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "zcw-shared",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.19.0",
|
|
4
4
|
"files": [
|
|
5
5
|
"references",
|
|
6
6
|
"dist",
|
|
@@ -111,8 +111,10 @@
|
|
|
111
111
|
"./functions/xml/modifyXml": "./dist/functions/xml/modifyXml.js",
|
|
112
112
|
"./hooks/useAltool": "./dist/hooks/useAltool.js",
|
|
113
113
|
"./hooks/useCache": "./dist/hooks/useCache.js",
|
|
114
|
+
"./hooks/useDraggable": "./dist/hooks/useDraggable.js",
|
|
114
115
|
"./hooks/useLocalStorage": "./dist/hooks/useLocalStorage.js",
|
|
115
116
|
"./hooks/usePluginSystem": "./dist/hooks/usePluginSystem.js",
|
|
117
|
+
"./hooks/useResizable": "./dist/hooks/useResizable.js",
|
|
116
118
|
"./hooks/useSessionStorage": "./dist/hooks/useSessionStorage.js",
|
|
117
119
|
"./hooks/useStorage": "./dist/hooks/useStorage.js",
|
|
118
120
|
"./hooks/useStorageWithIndexedDB": "./dist/hooks/useStorageWithIndexedDB.js",
|
package/references/blob.d.ts
CHANGED
|
@@ -2,14 +2,28 @@
|
|
|
2
2
|
import type { BufferSource } from './arraybuffer.d'
|
|
3
3
|
|
|
4
4
|
// Stream 相关类型(基础依赖)
|
|
5
|
-
export interface
|
|
5
|
+
export interface ReadableStreamBYOBReader {
|
|
6
|
+
read<T extends ArrayBufferView>(view: T): Promise<{ done: boolean; value: T }>
|
|
7
|
+
releaseLock(): void
|
|
8
|
+
cancel(reason?: any): Promise<void>
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export interface ReadableStreamDefaultReader<T> {
|
|
6
12
|
read(): Promise<{ done: boolean; value: T }>
|
|
7
13
|
releaseLock(): void
|
|
8
14
|
cancel(reason?: any): Promise<void>
|
|
9
15
|
}
|
|
10
16
|
|
|
17
|
+
export type ReadableStreamReader<T> = ReadableStreamDefaultReader<T> | ReadableStreamBYOBReader
|
|
18
|
+
|
|
19
|
+
export interface ReadableStreamGetReaderOptions {
|
|
20
|
+
mode?: 'byob'
|
|
21
|
+
}
|
|
22
|
+
|
|
11
23
|
export interface ReadableStream<T> {
|
|
12
|
-
getReader():
|
|
24
|
+
getReader(): ReadableStreamDefaultReader<Uint8Array>
|
|
25
|
+
getReader(options: { mode: 'byob' }): ReadableStreamBYOBReader
|
|
26
|
+
getReader(options?: ReadableStreamGetReaderOptions): ReadableStreamReader<T>
|
|
13
27
|
cancel(reason?: any): Promise<void>
|
|
14
28
|
locked: boolean
|
|
15
29
|
}
|
package/references/browser.d.ts
CHANGED
|
@@ -85,6 +85,10 @@ export interface Window {
|
|
|
85
85
|
Uint8Array: Uint8ArrayConstructor
|
|
86
86
|
DataView: DataViewConstructor
|
|
87
87
|
|
|
88
|
+
// 动画API
|
|
89
|
+
requestAnimationFrame: (callback: (time: number) => void) => number
|
|
90
|
+
cancelAnimationFrame: (id: number) => void
|
|
91
|
+
|
|
88
92
|
// 开发环境标识
|
|
89
93
|
__DEV__?: boolean
|
|
90
94
|
|
package/references/dom.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
// DOM 相关类型声明
|
|
2
|
+
import type { Blob } from './blob.d'
|
|
2
3
|
|
|
3
4
|
// DOM 元素接口 - 按继承关系组织
|
|
4
5
|
export interface Element {
|
|
@@ -16,6 +17,10 @@ export interface HTMLElement extends Element {
|
|
|
16
17
|
right: number
|
|
17
18
|
bottom: number
|
|
18
19
|
}
|
|
20
|
+
addEventListener(event: string, handler: (e: any) => void, options?: any): void
|
|
21
|
+
removeEventListener(event: string, handler: (e: any) => void, options?: any): void
|
|
22
|
+
clientWidth: number
|
|
23
|
+
clientHeight: number
|
|
19
24
|
}
|
|
20
25
|
|
|
21
26
|
export interface HTMLImageElement extends HTMLElement {
|
|
@@ -44,11 +49,29 @@ export interface Document {
|
|
|
44
49
|
clientWidth: number
|
|
45
50
|
clientHeight: number
|
|
46
51
|
}
|
|
52
|
+
addEventListener(event: string, handler: (e: any) => void, options?: any): void
|
|
53
|
+
removeEventListener(event: string, handler: (e: any) => void, options?: any): void
|
|
47
54
|
}
|
|
48
55
|
|
|
49
56
|
// DOM 事件相关
|
|
50
57
|
export interface Event {
|
|
51
58
|
target?: any
|
|
59
|
+
stopPropagation(): void
|
|
60
|
+
preventDefault(): void
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
export interface MouseEvent extends Event {
|
|
64
|
+
clientX: number
|
|
65
|
+
clientY: number
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
export interface Touch {
|
|
69
|
+
clientX: number
|
|
70
|
+
clientY: number
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export interface TouchEvent extends Event {
|
|
74
|
+
touches: Touch[]
|
|
52
75
|
}
|
|
53
76
|
|
|
54
77
|
export interface DOMException {
|