react-resizable-panels 2.0.16 → 2.0.17
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/CHANGELOG.md +5 -1
- package/README.md +3 -3
- package/dist/declarations/src/types.d.ts +1 -1
- package/dist/react-resizable-panels.browser.cjs.js +30 -37
- package/dist/react-resizable-panels.browser.development.cjs.js +30 -37
- package/dist/react-resizable-panels.browser.development.esm.js +30 -37
- package/dist/react-resizable-panels.browser.esm.js +30 -37
- package/dist/react-resizable-panels.cjs.js +30 -37
- package/dist/react-resizable-panels.development.cjs.js +30 -37
- package/dist/react-resizable-panels.development.esm.js +30 -37
- package/dist/react-resizable-panels.development.node.cjs.js +30 -37
- package/dist/react-resizable-panels.development.node.esm.js +30 -37
- package/dist/react-resizable-panels.esm.js +30 -37
- package/dist/react-resizable-panels.node.cjs.js +30 -37
- package/dist/react-resizable-panels.node.esm.js +30 -37
- package/package.json +1 -1
- package/src/PanelGroup.ts +2 -2
- package/src/PanelGroupContext.ts +2 -1
- package/src/PanelResizeHandle.test.tsx +11 -11
- package/src/PanelResizeHandleRegistry.ts +13 -21
- package/src/types.ts +2 -1
- package/src/utils/adjustLayoutByDelta.ts +2 -2
- package/src/utils/computePanelFlexBoxStyle.ts +3 -2
- package/src/utils/events/getResizeEventCoordinates.ts +9 -10
- package/src/utils/events/index.ts +4 -4
- package/src/utils/test-utils.ts +3 -0
|
@@ -127,18 +127,18 @@ describe("PanelResizeHandle", () => {
|
|
|
127
127
|
});
|
|
128
128
|
|
|
129
129
|
act(() => {
|
|
130
|
-
dispatchPointerEvent("
|
|
130
|
+
dispatchPointerEvent("pointermove", leftElement);
|
|
131
131
|
});
|
|
132
132
|
expect(onDragging).not.toHaveBeenCalled();
|
|
133
133
|
|
|
134
134
|
act(() => {
|
|
135
|
-
dispatchPointerEvent("
|
|
135
|
+
dispatchPointerEvent("pointerdown", leftElement);
|
|
136
136
|
});
|
|
137
137
|
expect(onDragging).toHaveBeenCalledTimes(1);
|
|
138
138
|
expect(onDragging).toHaveBeenCalledWith(true);
|
|
139
139
|
|
|
140
140
|
act(() => {
|
|
141
|
-
dispatchPointerEvent("
|
|
141
|
+
dispatchPointerEvent("pointerup", leftElement);
|
|
142
142
|
});
|
|
143
143
|
expect(onDragging).toHaveBeenCalledTimes(2);
|
|
144
144
|
expect(onDragging).toHaveBeenCalledWith(false);
|
|
@@ -154,20 +154,20 @@ describe("PanelResizeHandle", () => {
|
|
|
154
154
|
});
|
|
155
155
|
|
|
156
156
|
act(() => {
|
|
157
|
-
dispatchPointerEvent("
|
|
157
|
+
dispatchPointerEvent("pointermove", leftElement);
|
|
158
158
|
});
|
|
159
159
|
expect(onDraggingLeft).not.toHaveBeenCalled();
|
|
160
160
|
expect(onDraggingRight).not.toHaveBeenCalled();
|
|
161
161
|
|
|
162
162
|
act(() => {
|
|
163
|
-
dispatchPointerEvent("
|
|
163
|
+
dispatchPointerEvent("pointerdown", leftElement);
|
|
164
164
|
});
|
|
165
165
|
expect(onDraggingLeft).toHaveBeenCalledTimes(1);
|
|
166
166
|
expect(onDraggingLeft).toHaveBeenCalledWith(true);
|
|
167
167
|
expect(onDraggingRight).not.toHaveBeenCalled();
|
|
168
168
|
|
|
169
169
|
act(() => {
|
|
170
|
-
dispatchPointerEvent("
|
|
170
|
+
dispatchPointerEvent("pointerup", leftElement);
|
|
171
171
|
});
|
|
172
172
|
expect(onDraggingLeft).toHaveBeenCalledTimes(2);
|
|
173
173
|
expect(onDraggingLeft).toHaveBeenCalledWith(false);
|
|
@@ -209,7 +209,7 @@ describe("PanelResizeHandle", () => {
|
|
|
209
209
|
verifyAttribute(rightElement, "data-resize-handle-state", "inactive");
|
|
210
210
|
|
|
211
211
|
act(() => {
|
|
212
|
-
dispatchPointerEvent("
|
|
212
|
+
dispatchPointerEvent("pointermove", leftElement);
|
|
213
213
|
});
|
|
214
214
|
verifyAttribute(leftElement, "data-resize-handle-active", null);
|
|
215
215
|
verifyAttribute(rightElement, "data-resize-handle-active", null);
|
|
@@ -217,7 +217,7 @@ describe("PanelResizeHandle", () => {
|
|
|
217
217
|
verifyAttribute(rightElement, "data-resize-handle-state", "inactive");
|
|
218
218
|
|
|
219
219
|
act(() => {
|
|
220
|
-
dispatchPointerEvent("
|
|
220
|
+
dispatchPointerEvent("pointerdown", leftElement);
|
|
221
221
|
});
|
|
222
222
|
verifyAttribute(leftElement, "data-resize-handle-active", "pointer");
|
|
223
223
|
verifyAttribute(rightElement, "data-resize-handle-active", null);
|
|
@@ -225,7 +225,7 @@ describe("PanelResizeHandle", () => {
|
|
|
225
225
|
verifyAttribute(rightElement, "data-resize-handle-state", "inactive");
|
|
226
226
|
|
|
227
227
|
act(() => {
|
|
228
|
-
dispatchPointerEvent("
|
|
228
|
+
dispatchPointerEvent("pointermove", leftElement);
|
|
229
229
|
});
|
|
230
230
|
verifyAttribute(leftElement, "data-resize-handle-active", "pointer");
|
|
231
231
|
verifyAttribute(rightElement, "data-resize-handle-active", null);
|
|
@@ -233,7 +233,7 @@ describe("PanelResizeHandle", () => {
|
|
|
233
233
|
verifyAttribute(rightElement, "data-resize-handle-state", "inactive");
|
|
234
234
|
|
|
235
235
|
act(() => {
|
|
236
|
-
dispatchPointerEvent("
|
|
236
|
+
dispatchPointerEvent("pointerup", leftElement);
|
|
237
237
|
});
|
|
238
238
|
verifyAttribute(leftElement, "data-resize-handle-active", null);
|
|
239
239
|
verifyAttribute(rightElement, "data-resize-handle-active", null);
|
|
@@ -241,7 +241,7 @@ describe("PanelResizeHandle", () => {
|
|
|
241
241
|
verifyAttribute(rightElement, "data-resize-handle-state", "inactive");
|
|
242
242
|
|
|
243
243
|
act(() => {
|
|
244
|
-
dispatchPointerEvent("
|
|
244
|
+
dispatchPointerEvent("pointermove", rightElement);
|
|
245
245
|
});
|
|
246
246
|
verifyAttribute(leftElement, "data-resize-handle-active", null);
|
|
247
247
|
verifyAttribute(rightElement, "data-resize-handle-active", null);
|
|
@@ -89,6 +89,7 @@ function handlePointerDown(event: ResizeEvent) {
|
|
|
89
89
|
updateResizeHandlerStates("down", event);
|
|
90
90
|
|
|
91
91
|
event.preventDefault();
|
|
92
|
+
event.stopPropagation();
|
|
92
93
|
}
|
|
93
94
|
}
|
|
94
95
|
|
|
@@ -258,16 +259,13 @@ function updateListeners() {
|
|
|
258
259
|
const { body } = ownerDocument;
|
|
259
260
|
|
|
260
261
|
body.removeEventListener("contextmenu", handlePointerUp);
|
|
261
|
-
body.removeEventListener("
|
|
262
|
-
body.removeEventListener("
|
|
263
|
-
body.removeEventListener("
|
|
264
|
-
body.removeEventListener("touchmove", handlePointerMove);
|
|
265
|
-
body.removeEventListener("touchstart", handlePointerDown);
|
|
262
|
+
body.removeEventListener("pointerdown", handlePointerDown);
|
|
263
|
+
body.removeEventListener("pointerleave", handlePointerMove);
|
|
264
|
+
body.removeEventListener("pointermove", handlePointerMove);
|
|
266
265
|
});
|
|
267
266
|
|
|
268
|
-
window.removeEventListener("
|
|
269
|
-
window.removeEventListener("
|
|
270
|
-
window.removeEventListener("touchend", handlePointerUp);
|
|
267
|
+
window.removeEventListener("pointerup", handlePointerUp);
|
|
268
|
+
window.removeEventListener("pointercancel", handlePointerUp);
|
|
271
269
|
|
|
272
270
|
if (registeredResizeHandlers.size > 0) {
|
|
273
271
|
if (isPointerDown) {
|
|
@@ -277,29 +275,23 @@ function updateListeners() {
|
|
|
277
275
|
|
|
278
276
|
if (count > 0) {
|
|
279
277
|
body.addEventListener("contextmenu", handlePointerUp);
|
|
280
|
-
body.addEventListener("
|
|
281
|
-
body.addEventListener("
|
|
282
|
-
body.addEventListener("touchmove", handlePointerMove, {
|
|
283
|
-
passive: false,
|
|
284
|
-
});
|
|
278
|
+
body.addEventListener("pointerleave", handlePointerMove);
|
|
279
|
+
body.addEventListener("pointermove", handlePointerMove);
|
|
285
280
|
}
|
|
286
281
|
});
|
|
287
282
|
}
|
|
288
283
|
|
|
289
|
-
window.addEventListener("
|
|
290
|
-
window.addEventListener("
|
|
291
|
-
window.addEventListener("touchend", handlePointerUp);
|
|
284
|
+
window.addEventListener("pointerup", handlePointerUp);
|
|
285
|
+
window.addEventListener("pointercancel", handlePointerUp);
|
|
292
286
|
} else {
|
|
293
287
|
ownerDocumentCounts.forEach((count, ownerDocument) => {
|
|
294
288
|
const { body } = ownerDocument;
|
|
295
289
|
|
|
296
290
|
if (count > 0) {
|
|
297
|
-
body.addEventListener("
|
|
298
|
-
|
|
299
|
-
body.addEventListener("touchmove", handlePointerMove, {
|
|
300
|
-
passive: false,
|
|
291
|
+
body.addEventListener("pointerdown", handlePointerDown, {
|
|
292
|
+
capture: true,
|
|
301
293
|
});
|
|
302
|
-
body.addEventListener("
|
|
294
|
+
body.addEventListener("pointermove", handlePointerMove);
|
|
303
295
|
}
|
|
304
296
|
});
|
|
305
297
|
}
|
package/src/types.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export type Direction = "horizontal" | "vertical";
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
// The "contextmenu" event is not supported as a PointerEvent in all browsers yet, so MouseEvent still need to be handled
|
|
4
|
+
export type ResizeEvent = KeyboardEvent | PointerEvent | MouseEvent;
|
|
4
5
|
export type ResizeHandler = (event: ResizeEvent) => void;
|
|
@@ -200,8 +200,8 @@ export function adjustLayoutByDelta({
|
|
|
200
200
|
|
|
201
201
|
if (
|
|
202
202
|
deltaApplied
|
|
203
|
-
.
|
|
204
|
-
.localeCompare(Math.abs(delta).
|
|
203
|
+
.toPrecision(3)
|
|
204
|
+
.localeCompare(Math.abs(delta).toPrecision(3), undefined, {
|
|
205
205
|
numeric: true,
|
|
206
206
|
}) >= 0
|
|
207
207
|
) {
|
|
@@ -26,12 +26,13 @@ export function computePanelFlexBoxStyle({
|
|
|
26
26
|
if (size == null) {
|
|
27
27
|
// Initial render (before panels have registered themselves)
|
|
28
28
|
// In order to support server rendering, fall back to default size if provided
|
|
29
|
-
flexGrow =
|
|
29
|
+
flexGrow =
|
|
30
|
+
defaultSize != undefined ? defaultSize.toPrecision(precision) : "1";
|
|
30
31
|
} else if (panelData.length === 1) {
|
|
31
32
|
// Special case: Single panel group should always fill full width/height
|
|
32
33
|
flexGrow = "1";
|
|
33
34
|
} else {
|
|
34
|
-
flexGrow = size.
|
|
35
|
+
flexGrow = size.toPrecision(precision);
|
|
35
36
|
}
|
|
36
37
|
|
|
37
38
|
return {
|
|
@@ -1,20 +1,19 @@
|
|
|
1
1
|
import { ResizeEvent } from "../../types";
|
|
2
|
-
import { isMouseEvent,
|
|
2
|
+
import { isMouseEvent, isPointerEvent } from ".";
|
|
3
3
|
|
|
4
4
|
export function getResizeEventCoordinates(event: ResizeEvent) {
|
|
5
|
-
if (
|
|
5
|
+
if (isPointerEvent(event)) {
|
|
6
|
+
if (event.isPrimary) {
|
|
7
|
+
return {
|
|
8
|
+
x: event.clientX,
|
|
9
|
+
y: event.clientY,
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
} else if (isMouseEvent(event)) {
|
|
6
13
|
return {
|
|
7
14
|
x: event.clientX,
|
|
8
15
|
y: event.clientY,
|
|
9
16
|
};
|
|
10
|
-
} else if (isTouchEvent(event)) {
|
|
11
|
-
const touch = event.touches[0];
|
|
12
|
-
if (touch && touch.clientX && touch.clientY) {
|
|
13
|
-
return {
|
|
14
|
-
x: touch.clientX,
|
|
15
|
-
y: touch.clientY,
|
|
16
|
-
};
|
|
17
|
-
}
|
|
18
17
|
}
|
|
19
18
|
|
|
20
19
|
return {
|
|
@@ -4,10 +4,10 @@ export function isKeyDown(event: ResizeEvent): event is KeyboardEvent {
|
|
|
4
4
|
return event.type === "keydown";
|
|
5
5
|
}
|
|
6
6
|
|
|
7
|
-
export function
|
|
8
|
-
return event.type.startsWith("
|
|
7
|
+
export function isPointerEvent(event: ResizeEvent): event is PointerEvent {
|
|
8
|
+
return event.type.startsWith("pointer");
|
|
9
9
|
}
|
|
10
10
|
|
|
11
|
-
export function
|
|
12
|
-
return event.type.startsWith("
|
|
11
|
+
export function isMouseEvent(event: ResizeEvent): event is MouseEvent {
|
|
12
|
+
return event.type.startsWith("mouse");
|
|
13
13
|
}
|