@vuu-ui/vuu-layout 0.13.7 → 0.13.8
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/cjs/index.js +5513 -113
- package/cjs/index.js.map +1 -1
- package/esm/index.js +5436 -32
- package/esm/index.js.map +1 -1
- package/package.json +9 -9
- package/cjs/Component.js +0 -14
- package/cjs/Component.js.map +0 -1
- package/cjs/LayoutContainer.css.js +0 -6
- package/cjs/LayoutContainer.css.js.map +0 -1
- package/cjs/LayoutContainer.js +0 -33
- package/cjs/LayoutContainer.js.map +0 -1
- package/cjs/dock-layout/DockLayout.css.js +0 -6
- package/cjs/dock-layout/DockLayout.css.js.map +0 -1
- package/cjs/dock-layout/DockLayout.js +0 -41
- package/cjs/dock-layout/DockLayout.js.map +0 -1
- package/cjs/dock-layout/Drawer.css.js +0 -6
- package/cjs/dock-layout/Drawer.css.js.map +0 -1
- package/cjs/dock-layout/Drawer.js +0 -95
- package/cjs/dock-layout/Drawer.js.map +0 -1
- package/cjs/drag-drop/BoxModel.js +0 -416
- package/cjs/drag-drop/BoxModel.js.map +0 -1
- package/cjs/drag-drop/DragState.js +0 -161
- package/cjs/drag-drop/DragState.js.map +0 -1
- package/cjs/drag-drop/Draggable.js +0 -192
- package/cjs/drag-drop/Draggable.js.map +0 -1
- package/cjs/drag-drop/DropTarget.js +0 -257
- package/cjs/drag-drop/DropTarget.js.map +0 -1
- package/cjs/drag-drop/DropTargetRenderer.js +0 -218
- package/cjs/drag-drop/DropTargetRenderer.js.map +0 -1
- package/cjs/flexbox/Flexbox.css.js +0 -6
- package/cjs/flexbox/Flexbox.css.js.map +0 -1
- package/cjs/flexbox/Flexbox.js +0 -69
- package/cjs/flexbox/Flexbox.js.map +0 -1
- package/cjs/flexbox/FlexboxLayout.js +0 -30
- package/cjs/flexbox/FlexboxLayout.js.map +0 -1
- package/cjs/flexbox/Splitter.css.js +0 -6
- package/cjs/flexbox/Splitter.css.js.map +0 -1
- package/cjs/flexbox/Splitter.js +0 -122
- package/cjs/flexbox/Splitter.js.map +0 -1
- package/cjs/flexbox/flexbox-utils.js +0 -95
- package/cjs/flexbox/flexbox-utils.js.map +0 -1
- package/cjs/flexbox/useSplitterResizing.js +0 -198
- package/cjs/flexbox/useSplitterResizing.js.map +0 -1
- package/cjs/layout-action.js +0 -24
- package/cjs/layout-action.js.map +0 -1
- package/cjs/layout-header/Header.css.js +0 -6
- package/cjs/layout-header/Header.css.js.map +0 -1
- package/cjs/layout-header/Header.js +0 -152
- package/cjs/layout-header/Header.js.map +0 -1
- package/cjs/layout-header/useHeader.js +0 -86
- package/cjs/layout-header/useHeader.js.map +0 -1
- package/cjs/layout-provider/LayoutProvider.js +0 -306
- package/cjs/layout-provider/LayoutProvider.js.map +0 -1
- package/cjs/layout-provider/LayoutProviderContext.js +0 -23
- package/cjs/layout-provider/LayoutProviderContext.js.map +0 -1
- package/cjs/layout-provider/useLayoutDragDrop.js +0 -177
- package/cjs/layout-provider/useLayoutDragDrop.js.map +0 -1
- package/cjs/layout-reducer/flexUtils.js +0 -227
- package/cjs/layout-reducer/flexUtils.js.map +0 -1
- package/cjs/layout-reducer/insert-layout-element.js +0 -286
- package/cjs/layout-reducer/insert-layout-element.js.map +0 -1
- package/cjs/layout-reducer/layout-reducer.js +0 -202
- package/cjs/layout-reducer/layout-reducer.js.map +0 -1
- package/cjs/layout-reducer/layoutTypes.js +0 -40
- package/cjs/layout-reducer/layoutTypes.js.map +0 -1
- package/cjs/layout-reducer/layoutUtils.js +0 -237
- package/cjs/layout-reducer/layoutUtils.js.map +0 -1
- package/cjs/layout-reducer/move-layout-element.js +0 -31
- package/cjs/layout-reducer/move-layout-element.js.map +0 -1
- package/cjs/layout-reducer/remove-layout-element.js +0 -237
- package/cjs/layout-reducer/remove-layout-element.js.map +0 -1
- package/cjs/layout-reducer/replace-layout-element.js +0 -96
- package/cjs/layout-reducer/replace-layout-element.js.map +0 -1
- package/cjs/layout-reducer/resize-flex-children.js +0 -62
- package/cjs/layout-reducer/resize-flex-children.js.map +0 -1
- package/cjs/layout-reducer/wrap-layout-element.js +0 -211
- package/cjs/layout-reducer/wrap-layout-element.js.map +0 -1
- package/cjs/layout-view/View.css.js +0 -6
- package/cjs/layout-view/View.css.js.map +0 -1
- package/cjs/layout-view/View.js +0 -167
- package/cjs/layout-view/View.js.map +0 -1
- package/cjs/layout-view/useView.js +0 -91
- package/cjs/layout-view/useView.js.map +0 -1
- package/cjs/layout-view/useViewBroadcastChannel.js +0 -35
- package/cjs/layout-view/useViewBroadcastChannel.js.map +0 -1
- package/cjs/layout-view/useViewResize.js +0 -42
- package/cjs/layout-view/useViewResize.js.map +0 -1
- package/cjs/layout-view-actions/ViewContext.js +0 -16
- package/cjs/layout-view-actions/ViewContext.js.map +0 -1
- package/cjs/layout-view-actions/useViewActionDispatcher.js +0 -129
- package/cjs/layout-view-actions/useViewActionDispatcher.js.map +0 -1
- package/cjs/palette/Palette.css.js +0 -6
- package/cjs/palette/Palette.css.js.map +0 -1
- package/cjs/palette/Palette.js +0 -132
- package/cjs/palette/Palette.js.map +0 -1
- package/cjs/placeholder/LayoutStartPanel.css.js +0 -6
- package/cjs/placeholder/LayoutStartPanel.css.js.map +0 -1
- package/cjs/placeholder/LayoutStartPanel.js +0 -56
- package/cjs/placeholder/LayoutStartPanel.js.map +0 -1
- package/cjs/placeholder/Placeholder.css.js +0 -6
- package/cjs/placeholder/Placeholder.css.js.map +0 -1
- package/cjs/placeholder/Placeholder.js +0 -34
- package/cjs/placeholder/Placeholder.js.map +0 -1
- package/cjs/responsive/useResizeObserver.js +0 -118
- package/cjs/responsive/useResizeObserver.js.map +0 -1
- package/cjs/responsive/utils.js +0 -34
- package/cjs/responsive/utils.js.map +0 -1
- package/cjs/stack/Stack.css.js +0 -6
- package/cjs/stack/Stack.css.js.map +0 -1
- package/cjs/stack/Stack.js +0 -150
- package/cjs/stack/Stack.js.map +0 -1
- package/cjs/stack/StackLayout.js +0 -118
- package/cjs/stack/StackLayout.js.map +0 -1
- package/cjs/use-persistent-state.js +0 -112
- package/cjs/use-persistent-state.js.map +0 -1
- package/cjs/utils/pathUtils.js +0 -293
- package/cjs/utils/pathUtils.js.map +0 -1
- package/cjs/utils/propUtils.js +0 -27
- package/cjs/utils/propUtils.js.map +0 -1
- package/cjs/utils/refUtils.js +0 -12
- package/cjs/utils/refUtils.js.map +0 -1
- package/cjs/utils/styleUtils.js +0 -15
- package/cjs/utils/styleUtils.js.map +0 -1
- package/cjs/utils/typeOf.js +0 -27
- package/cjs/utils/typeOf.js.map +0 -1
- package/esm/Component.js +0 -12
- package/esm/Component.js.map +0 -1
- package/esm/LayoutContainer.css.js +0 -4
- package/esm/LayoutContainer.css.js.map +0 -1
- package/esm/LayoutContainer.js +0 -31
- package/esm/LayoutContainer.js.map +0 -1
- package/esm/dock-layout/DockLayout.css.js +0 -4
- package/esm/dock-layout/DockLayout.css.js.map +0 -1
- package/esm/dock-layout/DockLayout.js +0 -39
- package/esm/dock-layout/DockLayout.js.map +0 -1
- package/esm/dock-layout/Drawer.css.js +0 -4
- package/esm/dock-layout/Drawer.css.js.map +0 -1
- package/esm/dock-layout/Drawer.js +0 -93
- package/esm/dock-layout/Drawer.js.map +0 -1
- package/esm/drag-drop/BoxModel.js +0 -409
- package/esm/drag-drop/BoxModel.js.map +0 -1
- package/esm/drag-drop/DragState.js +0 -159
- package/esm/drag-drop/DragState.js.map +0 -1
- package/esm/drag-drop/Draggable.js +0 -190
- package/esm/drag-drop/Draggable.js.map +0 -1
- package/esm/drag-drop/DropTarget.js +0 -253
- package/esm/drag-drop/DropTarget.js.map +0 -1
- package/esm/drag-drop/DropTargetRenderer.js +0 -216
- package/esm/drag-drop/DropTargetRenderer.js.map +0 -1
- package/esm/flexbox/Flexbox.css.js +0 -4
- package/esm/flexbox/Flexbox.css.js.map +0 -1
- package/esm/flexbox/Flexbox.js +0 -67
- package/esm/flexbox/Flexbox.js.map +0 -1
- package/esm/flexbox/FlexboxLayout.js +0 -28
- package/esm/flexbox/FlexboxLayout.js.map +0 -1
- package/esm/flexbox/Splitter.css.js +0 -4
- package/esm/flexbox/Splitter.css.js.map +0 -1
- package/esm/flexbox/Splitter.js +0 -120
- package/esm/flexbox/Splitter.js.map +0 -1
- package/esm/flexbox/flexbox-utils.js +0 -89
- package/esm/flexbox/flexbox-utils.js.map +0 -1
- package/esm/flexbox/useSplitterResizing.js +0 -196
- package/esm/flexbox/useSplitterResizing.js.map +0 -1
- package/esm/layout-action.js +0 -22
- package/esm/layout-action.js.map +0 -1
- package/esm/layout-header/Header.css.js +0 -4
- package/esm/layout-header/Header.css.js.map +0 -1
- package/esm/layout-header/Header.js +0 -150
- package/esm/layout-header/Header.js.map +0 -1
- package/esm/layout-header/useHeader.js +0 -84
- package/esm/layout-header/useHeader.js.map +0 -1
- package/esm/layout-provider/LayoutProvider.js +0 -299
- package/esm/layout-provider/LayoutProvider.js.map +0 -1
- package/esm/layout-provider/LayoutProviderContext.js +0 -20
- package/esm/layout-provider/LayoutProviderContext.js.map +0 -1
- package/esm/layout-provider/useLayoutDragDrop.js +0 -175
- package/esm/layout-provider/useLayoutDragDrop.js.map +0 -1
- package/esm/layout-reducer/flexUtils.js +0 -218
- package/esm/layout-reducer/flexUtils.js.map +0 -1
- package/esm/layout-reducer/insert-layout-element.js +0 -282
- package/esm/layout-reducer/insert-layout-element.js.map +0 -1
- package/esm/layout-reducer/layout-reducer.js +0 -200
- package/esm/layout-reducer/layout-reducer.js.map +0 -1
- package/esm/layout-reducer/layoutTypes.js +0 -36
- package/esm/layout-reducer/layoutTypes.js.map +0 -1
- package/esm/layout-reducer/layoutUtils.js +0 -226
- package/esm/layout-reducer/layoutUtils.js.map +0 -1
- package/esm/layout-reducer/move-layout-element.js +0 -29
- package/esm/layout-reducer/move-layout-element.js.map +0 -1
- package/esm/layout-reducer/remove-layout-element.js +0 -235
- package/esm/layout-reducer/remove-layout-element.js.map +0 -1
- package/esm/layout-reducer/replace-layout-element.js +0 -92
- package/esm/layout-reducer/replace-layout-element.js.map +0 -1
- package/esm/layout-reducer/resize-flex-children.js +0 -59
- package/esm/layout-reducer/resize-flex-children.js.map +0 -1
- package/esm/layout-reducer/wrap-layout-element.js +0 -209
- package/esm/layout-reducer/wrap-layout-element.js.map +0 -1
- package/esm/layout-view/View.css.js +0 -4
- package/esm/layout-view/View.css.js.map +0 -1
- package/esm/layout-view/View.js +0 -165
- package/esm/layout-view/View.js.map +0 -1
- package/esm/layout-view/useView.js +0 -89
- package/esm/layout-view/useView.js.map +0 -1
- package/esm/layout-view/useViewBroadcastChannel.js +0 -33
- package/esm/layout-view/useViewBroadcastChannel.js.map +0 -1
- package/esm/layout-view/useViewResize.js +0 -40
- package/esm/layout-view/useViewResize.js.map +0 -1
- package/esm/layout-view-actions/ViewContext.js +0 -12
- package/esm/layout-view-actions/ViewContext.js.map +0 -1
- package/esm/layout-view-actions/useViewActionDispatcher.js +0 -127
- package/esm/layout-view-actions/useViewActionDispatcher.js.map +0 -1
- package/esm/palette/Palette.css.js +0 -4
- package/esm/palette/Palette.css.js.map +0 -1
- package/esm/palette/Palette.js +0 -129
- package/esm/palette/Palette.js.map +0 -1
- package/esm/placeholder/LayoutStartPanel.css.js +0 -4
- package/esm/placeholder/LayoutStartPanel.css.js.map +0 -1
- package/esm/placeholder/LayoutStartPanel.js +0 -54
- package/esm/placeholder/LayoutStartPanel.js.map +0 -1
- package/esm/placeholder/Placeholder.css.js +0 -4
- package/esm/placeholder/Placeholder.css.js.map +0 -1
- package/esm/placeholder/Placeholder.js +0 -32
- package/esm/placeholder/Placeholder.js.map +0 -1
- package/esm/responsive/useResizeObserver.js +0 -112
- package/esm/responsive/useResizeObserver.js.map +0 -1
- package/esm/responsive/utils.js +0 -31
- package/esm/responsive/utils.js.map +0 -1
- package/esm/stack/Stack.css.js +0 -4
- package/esm/stack/Stack.css.js.map +0 -1
- package/esm/stack/Stack.js +0 -148
- package/esm/stack/Stack.js.map +0 -1
- package/esm/stack/StackLayout.js +0 -116
- package/esm/stack/StackLayout.js.map +0 -1
- package/esm/use-persistent-state.js +0 -107
- package/esm/use-persistent-state.js.map +0 -1
- package/esm/utils/pathUtils.js +0 -280
- package/esm/utils/pathUtils.js.map +0 -1
- package/esm/utils/propUtils.js +0 -23
- package/esm/utils/propUtils.js.map +0 -1
- package/esm/utils/refUtils.js +0 -10
- package/esm/utils/refUtils.js.map +0 -1
- package/esm/utils/styleUtils.js +0 -13
- package/esm/utils/styleUtils.js.map +0 -1
- package/esm/utils/typeOf.js +0 -23
- package/esm/utils/typeOf.js.map +0 -1
|
@@ -1,198 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var vuuUtils = require('@vuu-ui/vuu-utils');
|
|
4
|
-
var React = require('react');
|
|
5
|
-
var Placeholder = require('../placeholder/Placeholder.js');
|
|
6
|
-
var Splitter = require('./Splitter.js');
|
|
7
|
-
var flexboxUtils = require('./flexbox-utils.js');
|
|
8
|
-
|
|
9
|
-
const originalContentOnly = (meta) => !meta.splitter && !meta.placeholder;
|
|
10
|
-
const useSplitterResizing = ({
|
|
11
|
-
children: childrenProp,
|
|
12
|
-
onSplitterMoved,
|
|
13
|
-
style
|
|
14
|
-
}) => {
|
|
15
|
-
const rootRef = React.useRef(null);
|
|
16
|
-
const flexElementsRef = React.useRef(void 0);
|
|
17
|
-
const metaRef = React.useRef(void 0);
|
|
18
|
-
const contentRef = React.useRef(void 0);
|
|
19
|
-
const assignedKeys = React.useRef([]);
|
|
20
|
-
const isColumn = style?.flexDirection === "column";
|
|
21
|
-
const dimension = isColumn ? "height" : "width";
|
|
22
|
-
const children = React.useMemo(
|
|
23
|
-
() => Array.isArray(childrenProp) ? childrenProp : React.isValidElement(childrenProp) ? [childrenProp] : [],
|
|
24
|
-
[childrenProp]
|
|
25
|
-
);
|
|
26
|
-
const handleDragStart = React.useCallback(
|
|
27
|
-
(index) => {
|
|
28
|
-
const { current: contentMeta } = metaRef;
|
|
29
|
-
if (contentMeta) {
|
|
30
|
-
const [participants, bystanders] = flexboxUtils.identifyResizeParties(
|
|
31
|
-
contentMeta,
|
|
32
|
-
index
|
|
33
|
-
);
|
|
34
|
-
if (participants) {
|
|
35
|
-
participants.forEach((index2) => {
|
|
36
|
-
const el = rootRef.current?.childNodes[index2];
|
|
37
|
-
if (el) {
|
|
38
|
-
const { size, minSize } = measureElement(el, dimension);
|
|
39
|
-
contentMeta[index2].currentSize = size;
|
|
40
|
-
contentMeta[index2].minSize = minSize;
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
if (bystanders) {
|
|
44
|
-
bystanders.forEach((index2) => {
|
|
45
|
-
const el = rootRef.current?.childNodes[index2];
|
|
46
|
-
if (el) {
|
|
47
|
-
const { [dimension]: size } = el.getBoundingClientRect();
|
|
48
|
-
contentMeta[index2].flexBasis = size;
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
if (rootRef.current) {
|
|
53
|
-
rootRef.current.classList.add("vuuSplitterResizing");
|
|
54
|
-
console.log({ root: rootRef.current });
|
|
55
|
-
flexElementsRef.current = Array.from(
|
|
56
|
-
rootRef.current.querySelectorAll(":scope > div")
|
|
57
|
-
);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
},
|
|
62
|
-
[dimension]
|
|
63
|
-
);
|
|
64
|
-
const handleDrag = React.useCallback((idx, distance) => {
|
|
65
|
-
const { current: flexElements = [] } = flexElementsRef;
|
|
66
|
-
if (contentRef.current && metaRef.current) {
|
|
67
|
-
resizeElements(
|
|
68
|
-
flexElements,
|
|
69
|
-
metaRef.current,
|
|
70
|
-
distance
|
|
71
|
-
/*, dimension*/
|
|
72
|
-
);
|
|
73
|
-
}
|
|
74
|
-
}, []);
|
|
75
|
-
const handleDragEnd = React.useCallback(() => {
|
|
76
|
-
const contentMeta = metaRef.current;
|
|
77
|
-
if (contentMeta) {
|
|
78
|
-
onSplitterMoved?.(contentMeta.filter(originalContentOnly));
|
|
79
|
-
if (rootRef.current) {
|
|
80
|
-
rootRef.current.classList.remove("vuuSplitterResizing");
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
contentMeta?.forEach((meta) => {
|
|
84
|
-
meta.currentSize = void 0;
|
|
85
|
-
meta.flexBasis = void 0;
|
|
86
|
-
meta.flexOpen = false;
|
|
87
|
-
});
|
|
88
|
-
}, [onSplitterMoved]);
|
|
89
|
-
const createSplitter = React.useCallback(
|
|
90
|
-
(i) => {
|
|
91
|
-
return React.createElement(Splitter.Splitter, {
|
|
92
|
-
column: isColumn,
|
|
93
|
-
index: i,
|
|
94
|
-
key: `splitter-${i}`,
|
|
95
|
-
onDrag: handleDrag,
|
|
96
|
-
onDragEnd: handleDragEnd,
|
|
97
|
-
onDragStart: handleDragStart
|
|
98
|
-
});
|
|
99
|
-
},
|
|
100
|
-
[handleDrag, handleDragEnd, handleDragStart, isColumn]
|
|
101
|
-
);
|
|
102
|
-
React.useMemo(() => {
|
|
103
|
-
const [content, meta] = buildContent(
|
|
104
|
-
children,
|
|
105
|
-
dimension,
|
|
106
|
-
createSplitter,
|
|
107
|
-
assignedKeys.current
|
|
108
|
-
);
|
|
109
|
-
metaRef.current = meta;
|
|
110
|
-
contentRef.current = content;
|
|
111
|
-
}, [children, createSplitter, dimension]);
|
|
112
|
-
return {
|
|
113
|
-
content: contentRef.current || [],
|
|
114
|
-
rootRef
|
|
115
|
-
};
|
|
116
|
-
};
|
|
117
|
-
function buildContent(children, dimension, createSplitter, keys) {
|
|
118
|
-
const childMeta = flexboxUtils.gatherChildMeta(children, dimension);
|
|
119
|
-
const splitterAndPlaceholderPositions = flexboxUtils.findSplitterAndPlaceholderPositions(childMeta);
|
|
120
|
-
const content = [];
|
|
121
|
-
const meta = [];
|
|
122
|
-
for (let i = 0; i < children.length; i++) {
|
|
123
|
-
const child = children[i];
|
|
124
|
-
if (i === 0 && splitterAndPlaceholderPositions[i] & flexboxUtils.PLACEHOLDER) {
|
|
125
|
-
content.push(createPlaceholder(i));
|
|
126
|
-
meta.push({ placeholder: true, shim: true });
|
|
127
|
-
}
|
|
128
|
-
if (child.key == null) {
|
|
129
|
-
const key = keys[i] || (keys[i] = vuuUtils.getUniqueId());
|
|
130
|
-
content.push(React.cloneElement(child, { key }));
|
|
131
|
-
} else {
|
|
132
|
-
content.push(child);
|
|
133
|
-
}
|
|
134
|
-
meta.push(childMeta[i]);
|
|
135
|
-
if (i > 0 && splitterAndPlaceholderPositions[i] & flexboxUtils.PLACEHOLDER) {
|
|
136
|
-
content.push(createPlaceholder(i));
|
|
137
|
-
meta.push({ placeholder: true });
|
|
138
|
-
} else if (splitterAndPlaceholderPositions[i] & flexboxUtils.SPLITTER) {
|
|
139
|
-
content.push(createSplitter(content.length));
|
|
140
|
-
meta.push({ splitter: true });
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
return [content, meta];
|
|
144
|
-
}
|
|
145
|
-
function resizeElements(flexElements, contentMeta, distance) {
|
|
146
|
-
const metaUpdated = updateMeta(contentMeta, distance);
|
|
147
|
-
if (!metaUpdated) {
|
|
148
|
-
return;
|
|
149
|
-
}
|
|
150
|
-
flexElements.forEach((element, idx) => {
|
|
151
|
-
const meta = contentMeta[idx];
|
|
152
|
-
const { currentSize, flexOpen, flexBasis, splitter } = meta;
|
|
153
|
-
const hasCurrentSize = currentSize !== void 0;
|
|
154
|
-
if (!splitter && (hasCurrentSize || flexOpen)) {
|
|
155
|
-
const size = hasCurrentSize ? meta.currentSize : flexBasis;
|
|
156
|
-
element.style.flexBasis = `${size}px`;
|
|
157
|
-
}
|
|
158
|
-
});
|
|
159
|
-
}
|
|
160
|
-
function updateMeta(contentMeta, distance) {
|
|
161
|
-
const resizeTargets = [];
|
|
162
|
-
contentMeta.forEach((meta, idx) => {
|
|
163
|
-
if (meta.currentSize !== void 0) {
|
|
164
|
-
resizeTargets.push(idx);
|
|
165
|
-
}
|
|
166
|
-
});
|
|
167
|
-
const target1 = distance < 0 ? resizeTargets[0] : resizeTargets[1];
|
|
168
|
-
const { currentSize = 0, minSize = 0 } = contentMeta[target1];
|
|
169
|
-
if (currentSize === minSize) {
|
|
170
|
-
return false;
|
|
171
|
-
} else if (Math.abs(distance) > currentSize - minSize) {
|
|
172
|
-
const multiplier = distance < 0 ? -1 : 1;
|
|
173
|
-
distance = Math.max(0, currentSize - minSize) * multiplier;
|
|
174
|
-
}
|
|
175
|
-
const leadingItem = contentMeta[resizeTargets[0]];
|
|
176
|
-
const { currentSize: leadingSize = 0 } = leadingItem;
|
|
177
|
-
leadingItem.currentSize = leadingSize + distance;
|
|
178
|
-
const trailingItem = contentMeta[resizeTargets[1]];
|
|
179
|
-
const { currentSize: trailingSize = 0 } = trailingItem;
|
|
180
|
-
trailingItem.currentSize = trailingSize - distance;
|
|
181
|
-
return true;
|
|
182
|
-
}
|
|
183
|
-
function createPlaceholder(index) {
|
|
184
|
-
return React.createElement(Placeholder.Placeholder, {
|
|
185
|
-
shim: index === 0,
|
|
186
|
-
key: `placeholder-${index}`
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
function measureElement(el, dimension) {
|
|
190
|
-
const { [dimension]: size } = el.getBoundingClientRect();
|
|
191
|
-
const style = getComputedStyle(el);
|
|
192
|
-
const minSizeVal = style.getPropertyValue(`min-${dimension}`);
|
|
193
|
-
const minSize = minSizeVal.endsWith("px") ? parseInt(minSizeVal, 10) : 0;
|
|
194
|
-
return { size, minSize };
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
exports.useSplitterResizing = useSplitterResizing;
|
|
198
|
-
//# sourceMappingURL=useSplitterResizing.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useSplitterResizing.js","sources":["../../src/flexbox/useSplitterResizing.ts"],"sourcesContent":["import { getUniqueId } from \"@vuu-ui/vuu-utils\";\nimport React, { ReactElement, useCallback, useMemo, useRef } from \"react\";\nimport { Placeholder } from \"../placeholder\";\nimport { Splitter } from \"./Splitter\";\n\nimport {\n findSplitterAndPlaceholderPositions,\n gatherChildMeta,\n identifyResizeParties,\n PLACEHOLDER,\n SPLITTER,\n} from \"./flexbox-utils\";\nimport {\n ContentMeta,\n FlexSize,\n SplitterFactory,\n SplitterHookProps,\n SplitterHookResult,\n} from \"./flexboxTypes\";\n\nconst originalContentOnly = (meta: ContentMeta) =>\n !meta.splitter && !meta.placeholder;\n\nexport const useSplitterResizing = ({\n children: childrenProp,\n onSplitterMoved,\n style,\n}: SplitterHookProps): SplitterHookResult => {\n const rootRef = useRef<HTMLDivElement>(null);\n const flexElementsRef = useRef<HTMLDivElement[]>(undefined);\n const metaRef = useRef<ContentMeta[]>(undefined);\n const contentRef = useRef<ReactElement[]>(undefined);\n const assignedKeys = useRef<string[]>([]);\n\n const isColumn = style?.flexDirection === \"column\";\n const dimension = isColumn ? \"height\" : \"width\";\n const children = useMemo(\n () =>\n Array.isArray(childrenProp)\n ? childrenProp\n : React.isValidElement(childrenProp)\n ? [childrenProp]\n : [],\n [childrenProp],\n );\n\n const handleDragStart = useCallback(\n (index: number) => {\n const { current: contentMeta } = metaRef;\n if (contentMeta) {\n const [participants, bystanders] = identifyResizeParties(\n contentMeta,\n index,\n );\n if (participants) {\n participants.forEach((index) => {\n const el = rootRef.current?.childNodes[index] as HTMLElement;\n if (el) {\n const { size, minSize } = measureElement(el, dimension);\n contentMeta[index].currentSize = size;\n contentMeta[index].minSize = minSize;\n }\n });\n if (bystanders) {\n bystanders.forEach((index) => {\n const el = rootRef.current?.childNodes[index] as HTMLElement;\n if (el) {\n const { [dimension]: size } = el.getBoundingClientRect();\n contentMeta[index].flexBasis = size;\n }\n });\n }\n\n if (rootRef.current) {\n rootRef.current.classList.add(\"vuuSplitterResizing\");\n console.log({ root: rootRef.current });\n flexElementsRef.current = Array.from(\n rootRef.current.querySelectorAll<HTMLDivElement>(\":scope > div\"),\n );\n }\n }\n }\n },\n [dimension],\n );\n\n const handleDrag = useCallback((idx: number, distance: number) => {\n const { current: flexElements = [] } = flexElementsRef;\n\n if (contentRef.current && metaRef.current) {\n resizeElements(flexElements, metaRef.current, distance /*, dimension*/);\n }\n }, []);\n\n const handleDragEnd = useCallback(() => {\n const contentMeta = metaRef.current;\n if (contentMeta) {\n onSplitterMoved?.(contentMeta.filter(originalContentOnly));\n if (rootRef.current) {\n rootRef.current.classList.remove(\"vuuSplitterResizing\");\n }\n }\n contentMeta?.forEach((meta) => {\n meta.currentSize = undefined;\n meta.flexBasis = undefined;\n meta.flexOpen = false;\n });\n }, [onSplitterMoved]);\n\n const createSplitter: SplitterFactory = useCallback(\n (i) => {\n return React.createElement(Splitter, {\n column: isColumn,\n index: i,\n key: `splitter-${i}`,\n onDrag: handleDrag,\n onDragEnd: handleDragEnd,\n onDragStart: handleDragStart,\n });\n },\n [handleDrag, handleDragEnd, handleDragStart, isColumn],\n );\n\n useMemo(() => {\n const [content, meta] = buildContent(\n children,\n dimension,\n createSplitter,\n assignedKeys.current,\n );\n metaRef.current = meta;\n contentRef.current = content;\n }, [children, createSplitter, dimension]);\n\n return {\n content: contentRef.current || [],\n rootRef,\n };\n};\n\nfunction buildContent(\n children: ReactElement[],\n dimension: \"width\" | \"height\",\n createSplitter: SplitterFactory,\n keys: string[],\n): [ReactElement[], ContentMeta[]] {\n const childMeta = gatherChildMeta(children, dimension);\n const splitterAndPlaceholderPositions =\n findSplitterAndPlaceholderPositions(childMeta);\n const content = [];\n const meta: ContentMeta[] = [];\n for (let i = 0; i < children.length; i++) {\n const child = children[i];\n if (i === 0 && splitterAndPlaceholderPositions[i] & PLACEHOLDER) {\n content.push(createPlaceholder(i));\n meta.push({ placeholder: true, shim: true });\n }\n if (child.key == null) {\n const key = keys[i] || (keys[i] = getUniqueId());\n content.push(React.cloneElement(child, { key }));\n } else {\n content.push(child);\n }\n meta.push(childMeta[i]);\n\n if (i > 0 && splitterAndPlaceholderPositions[i] & PLACEHOLDER) {\n content.push(createPlaceholder(i));\n meta.push({ placeholder: true });\n } else if (splitterAndPlaceholderPositions[i] & SPLITTER) {\n content.push(createSplitter(content.length));\n meta.push({ splitter: true });\n }\n }\n return [content, meta];\n}\n\nfunction resizeElements(\n flexElements: HTMLDivElement[],\n contentMeta: ContentMeta[],\n distance: number,\n) {\n const metaUpdated = updateMeta(contentMeta, distance);\n if (!metaUpdated) {\n return;\n }\n\n flexElements.forEach((element, idx) => {\n const meta = contentMeta[idx];\n const { currentSize, flexOpen, flexBasis, splitter } = meta;\n const hasCurrentSize = currentSize !== undefined;\n if (!splitter && (hasCurrentSize || flexOpen)) {\n const size = hasCurrentSize ? meta.currentSize : flexBasis;\n element.style.flexBasis = `${size}px`;\n }\n });\n}\n\n//TODO detect cursor move beyond drag limit and suspend further resize until cursoe re-engages with splitter\nfunction updateMeta(contentMeta: ContentMeta[], distance: number) {\n const resizeTargets: number[] = [];\n\n contentMeta.forEach((meta, idx) => {\n if (meta.currentSize !== undefined) {\n resizeTargets.push(idx);\n }\n });\n\n // we want the target being reduced first, this may limit the distance we can apply\n const target1 = distance < 0 ? resizeTargets[0] : resizeTargets[1];\n\n const { currentSize = 0, minSize = 0 } = contentMeta[target1];\n if (currentSize === minSize) {\n // size is already 0, we cannot go further\n return false;\n } else if (Math.abs(distance) > currentSize - minSize) {\n // reduce to 0\n const multiplier = distance < 0 ? -1 : 1;\n distance = Math.max(0, currentSize - minSize) * multiplier;\n }\n\n const leadingItem = contentMeta[resizeTargets[0]] as ContentMeta;\n const { currentSize: leadingSize = 0 } = leadingItem;\n leadingItem.currentSize = leadingSize + distance;\n\n const trailingItem = contentMeta[resizeTargets[1]] as ContentMeta;\n const { currentSize: trailingSize = 0 } = trailingItem;\n trailingItem.currentSize = trailingSize - distance;\n\n return true;\n}\n\nfunction createPlaceholder(index: number) {\n return React.createElement(Placeholder, {\n shim: index === 0,\n key: `placeholder-${index}`,\n });\n}\n\nfunction measureElement(\n el: HTMLElement,\n dimension: \"width\" | \"height\",\n): FlexSize {\n const { [dimension]: size } = el.getBoundingClientRect();\n const style = getComputedStyle(el);\n const minSizeVal = style.getPropertyValue(`min-${dimension}`);\n const minSize = minSizeVal.endsWith(\"px\") ? parseInt(minSizeVal, 10) : 0;\n return { size, minSize };\n}\n"],"names":["useRef","useMemo","useCallback","identifyResizeParties","index","Splitter","gatherChildMeta","findSplitterAndPlaceholderPositions","PLACEHOLDER","getUniqueId","SPLITTER","Placeholder"],"mappings":";;;;;;;;AAoBA,MAAM,sBAAsB,CAAC,IAAA,KAC3B,CAAC,IAAK,CAAA,QAAA,IAAY,CAAC,IAAK,CAAA,WAAA;AAEnB,MAAM,sBAAsB,CAAC;AAAA,EAClC,QAAU,EAAA,YAAA;AAAA,EACV,eAAA;AAAA,EACA;AACF,CAA6C,KAAA;AAC3C,EAAM,MAAA,OAAA,GAAUA,aAAuB,IAAI,CAAA;AAC3C,EAAM,MAAA,eAAA,GAAkBA,aAAyB,KAAS,CAAA,CAAA;AAC1D,EAAM,MAAA,OAAA,GAAUA,aAAsB,KAAS,CAAA,CAAA;AAC/C,EAAM,MAAA,UAAA,GAAaA,aAAuB,KAAS,CAAA,CAAA;AACnD,EAAM,MAAA,YAAA,GAAeA,YAAiB,CAAA,EAAE,CAAA;AAExC,EAAM,MAAA,QAAA,GAAW,OAAO,aAAkB,KAAA,QAAA;AAC1C,EAAM,MAAA,SAAA,GAAY,WAAW,QAAW,GAAA,OAAA;AACxC,EAAA,MAAM,QAAW,GAAAC,aAAA;AAAA,IACf,MACE,KAAA,CAAM,OAAQ,CAAA,YAAY,CACtB,GAAA,YAAA,GACA,KAAM,CAAA,cAAA,CAAe,YAAY,CAAA,GAC/B,CAAC,YAAY,IACb,EAAC;AAAA,IACT,CAAC,YAAY;AAAA,GACf;AAEA,EAAA,MAAM,eAAkB,GAAAC,iBAAA;AAAA,IACtB,CAAC,KAAkB,KAAA;AACjB,MAAM,MAAA,EAAE,OAAS,EAAA,WAAA,EAAgB,GAAA,OAAA;AACjC,MAAA,IAAI,WAAa,EAAA;AACf,QAAM,MAAA,CAAC,YAAc,EAAA,UAAU,CAAI,GAAAC,kCAAA;AAAA,UACjC,WAAA;AAAA,UACA;AAAA,SACF;AACA,QAAA,IAAI,YAAc,EAAA;AAChB,UAAa,YAAA,CAAA,OAAA,CAAQ,CAACC,MAAU,KAAA;AAC9B,YAAA,MAAM,EAAK,GAAA,OAAA,CAAQ,OAAS,EAAA,UAAA,CAAWA,MAAK,CAAA;AAC5C,YAAA,IAAI,EAAI,EAAA;AACN,cAAA,MAAM,EAAE,IAAM,EAAA,OAAA,EAAY,GAAA,cAAA,CAAe,IAAI,SAAS,CAAA;AACtD,cAAYA,WAAAA,CAAAA,MAAK,EAAE,WAAc,GAAA,IAAA;AACjC,cAAYA,WAAAA,CAAAA,MAAK,EAAE,OAAU,GAAA,OAAA;AAAA;AAC/B,WACD,CAAA;AACD,UAAA,IAAI,UAAY,EAAA;AACd,YAAW,UAAA,CAAA,OAAA,CAAQ,CAACA,MAAU,KAAA;AAC5B,cAAA,MAAM,EAAK,GAAA,OAAA,CAAQ,OAAS,EAAA,UAAA,CAAWA,MAAK,CAAA;AAC5C,cAAA,IAAI,EAAI,EAAA;AACN,gBAAA,MAAM,EAAE,CAAC,SAAS,GAAG,IAAK,EAAA,GAAI,GAAG,qBAAsB,EAAA;AACvD,gBAAYA,WAAAA,CAAAA,MAAK,EAAE,SAAY,GAAA,IAAA;AAAA;AACjC,aACD,CAAA;AAAA;AAGH,UAAA,IAAI,QAAQ,OAAS,EAAA;AACnB,YAAQ,OAAA,CAAA,OAAA,CAAQ,SAAU,CAAA,GAAA,CAAI,qBAAqB,CAAA;AACnD,YAAA,OAAA,CAAQ,GAAI,CAAA,EAAE,IAAM,EAAA,OAAA,CAAQ,SAAS,CAAA;AACrC,YAAA,eAAA,CAAgB,UAAU,KAAM,CAAA,IAAA;AAAA,cAC9B,OAAA,CAAQ,OAAQ,CAAA,gBAAA,CAAiC,cAAc;AAAA,aACjE;AAAA;AACF;AACF;AACF,KACF;AAAA,IACA,CAAC,SAAS;AAAA,GACZ;AAEA,EAAA,MAAM,UAAa,GAAAF,iBAAA,CAAY,CAAC,GAAA,EAAa,QAAqB,KAAA;AAChE,IAAA,MAAM,EAAE,OAAA,EAAS,YAAe,GAAA,IAAO,GAAA,eAAA;AAEvC,IAAI,IAAA,UAAA,CAAW,OAAW,IAAA,OAAA,CAAQ,OAAS,EAAA;AACzC,MAAA,cAAA;AAAA,QAAe,YAAA;AAAA,QAAc,OAAQ,CAAA,OAAA;AAAA,QAAS;AAAA;AAAA,OAAwB;AAAA;AACxE,GACF,EAAG,EAAE,CAAA;AAEL,EAAM,MAAA,aAAA,GAAgBA,kBAAY,MAAM;AACtC,IAAA,MAAM,cAAc,OAAQ,CAAA,OAAA;AAC5B,IAAA,IAAI,WAAa,EAAA;AACf,MAAkB,eAAA,GAAA,WAAA,CAAY,MAAO,CAAA,mBAAmB,CAAC,CAAA;AACzD,MAAA,IAAI,QAAQ,OAAS,EAAA;AACnB,QAAQ,OAAA,CAAA,OAAA,CAAQ,SAAU,CAAA,MAAA,CAAO,qBAAqB,CAAA;AAAA;AACxD;AAEF,IAAa,WAAA,EAAA,OAAA,CAAQ,CAAC,IAAS,KAAA;AAC7B,MAAA,IAAA,CAAK,WAAc,GAAA,KAAA,CAAA;AACnB,MAAA,IAAA,CAAK,SAAY,GAAA,KAAA,CAAA;AACjB,MAAA,IAAA,CAAK,QAAW,GAAA,KAAA;AAAA,KACjB,CAAA;AAAA,GACH,EAAG,CAAC,eAAe,CAAC,CAAA;AAEpB,EAAA,MAAM,cAAkC,GAAAA,iBAAA;AAAA,IACtC,CAAC,CAAM,KAAA;AACL,MAAO,OAAA,KAAA,CAAM,cAAcG,iBAAU,EAAA;AAAA,QACnC,MAAQ,EAAA,QAAA;AAAA,QACR,KAAO,EAAA,CAAA;AAAA,QACP,GAAA,EAAK,YAAY,CAAC,CAAA,CAAA;AAAA,QAClB,MAAQ,EAAA,UAAA;AAAA,QACR,SAAW,EAAA,aAAA;AAAA,QACX,WAAa,EAAA;AAAA,OACd,CAAA;AAAA,KACH;AAAA,IACA,CAAC,UAAA,EAAY,aAAe,EAAA,eAAA,EAAiB,QAAQ;AAAA,GACvD;AAEA,EAAAJ,aAAA,CAAQ,MAAM;AACZ,IAAM,MAAA,CAAC,OAAS,EAAA,IAAI,CAAI,GAAA,YAAA;AAAA,MACtB,QAAA;AAAA,MACA,SAAA;AAAA,MACA,cAAA;AAAA,MACA,YAAa,CAAA;AAAA,KACf;AACA,IAAA,OAAA,CAAQ,OAAU,GAAA,IAAA;AAClB,IAAA,UAAA,CAAW,OAAU,GAAA,OAAA;AAAA,GACpB,EAAA,CAAC,QAAU,EAAA,cAAA,EAAgB,SAAS,CAAC,CAAA;AAExC,EAAO,OAAA;AAAA,IACL,OAAA,EAAS,UAAW,CAAA,OAAA,IAAW,EAAC;AAAA,IAChC;AAAA,GACF;AACF;AAEA,SAAS,YACP,CAAA,QAAA,EACA,SACA,EAAA,cAAA,EACA,IACiC,EAAA;AACjC,EAAM,MAAA,SAAA,GAAYK,4BAAgB,CAAA,QAAA,EAAU,SAAS,CAAA;AACrD,EAAM,MAAA,+BAAA,GACJC,iDAAoC,SAAS,CAAA;AAC/C,EAAA,MAAM,UAAU,EAAC;AACjB,EAAA,MAAM,OAAsB,EAAC;AAC7B,EAAA,KAAA,IAAS,CAAI,GAAA,CAAA,EAAG,CAAI,GAAA,QAAA,CAAS,QAAQ,CAAK,EAAA,EAAA;AACxC,IAAM,MAAA,KAAA,GAAQ,SAAS,CAAC,CAAA;AACxB,IAAA,IAAI,CAAM,KAAA,CAAA,IAAK,+BAAgC,CAAA,CAAC,IAAIC,wBAAa,EAAA;AAC/D,MAAQ,OAAA,CAAA,IAAA,CAAK,iBAAkB,CAAA,CAAC,CAAC,CAAA;AACjC,MAAA,IAAA,CAAK,KAAK,EAAE,WAAA,EAAa,IAAM,EAAA,IAAA,EAAM,MAAM,CAAA;AAAA;AAE7C,IAAI,IAAA,KAAA,CAAM,OAAO,IAAM,EAAA;AACrB,MAAA,MAAM,MAAM,IAAK,CAAA,CAAC,MAAM,IAAK,CAAA,CAAC,IAAIC,oBAAY,EAAA,CAAA;AAC9C,MAAA,OAAA,CAAQ,KAAK,KAAM,CAAA,YAAA,CAAa,OAAO,EAAE,GAAA,EAAK,CAAC,CAAA;AAAA,KAC1C,MAAA;AACL,MAAA,OAAA,CAAQ,KAAK,KAAK,CAAA;AAAA;AAEpB,IAAK,IAAA,CAAA,IAAA,CAAK,SAAU,CAAA,CAAC,CAAC,CAAA;AAEtB,IAAA,IAAI,CAAI,GAAA,CAAA,IAAK,+BAAgC,CAAA,CAAC,IAAID,wBAAa,EAAA;AAC7D,MAAQ,OAAA,CAAA,IAAA,CAAK,iBAAkB,CAAA,CAAC,CAAC,CAAA;AACjC,MAAA,IAAA,CAAK,IAAK,CAAA,EAAE,WAAa,EAAA,IAAA,EAAM,CAAA;AAAA,KACtB,MAAA,IAAA,+BAAA,CAAgC,CAAC,CAAA,GAAIE,qBAAU,EAAA;AACxD,MAAA,OAAA,CAAQ,IAAK,CAAA,cAAA,CAAe,OAAQ,CAAA,MAAM,CAAC,CAAA;AAC3C,MAAA,IAAA,CAAK,IAAK,CAAA,EAAE,QAAU,EAAA,IAAA,EAAM,CAAA;AAAA;AAC9B;AAEF,EAAO,OAAA,CAAC,SAAS,IAAI,CAAA;AACvB;AAEA,SAAS,cAAA,CACP,YACA,EAAA,WAAA,EACA,QACA,EAAA;AACA,EAAM,MAAA,WAAA,GAAc,UAAW,CAAA,WAAA,EAAa,QAAQ,CAAA;AACpD,EAAA,IAAI,CAAC,WAAa,EAAA;AAChB,IAAA;AAAA;AAGF,EAAa,YAAA,CAAA,OAAA,CAAQ,CAAC,OAAA,EAAS,GAAQ,KAAA;AACrC,IAAM,MAAA,IAAA,GAAO,YAAY,GAAG,CAAA;AAC5B,IAAA,MAAM,EAAE,WAAA,EAAa,QAAU,EAAA,SAAA,EAAW,UAAa,GAAA,IAAA;AACvD,IAAA,MAAM,iBAAiB,WAAgB,KAAA,KAAA,CAAA;AACvC,IAAI,IAAA,CAAC,QAAa,KAAA,cAAA,IAAkB,QAAW,CAAA,EAAA;AAC7C,MAAM,MAAA,IAAA,GAAO,cAAiB,GAAA,IAAA,CAAK,WAAc,GAAA,SAAA;AACjD,MAAQ,OAAA,CAAA,KAAA,CAAM,SAAY,GAAA,CAAA,EAAG,IAAI,CAAA,EAAA,CAAA;AAAA;AACnC,GACD,CAAA;AACH;AAGA,SAAS,UAAA,CAAW,aAA4B,QAAkB,EAAA;AAChE,EAAA,MAAM,gBAA0B,EAAC;AAEjC,EAAY,WAAA,CAAA,OAAA,CAAQ,CAAC,IAAA,EAAM,GAAQ,KAAA;AACjC,IAAI,IAAA,IAAA,CAAK,gBAAgB,KAAW,CAAA,EAAA;AAClC,MAAA,aAAA,CAAc,KAAK,GAAG,CAAA;AAAA;AACxB,GACD,CAAA;AAGD,EAAA,MAAM,UAAU,QAAW,GAAA,CAAA,GAAI,cAAc,CAAC,CAAA,GAAI,cAAc,CAAC,CAAA;AAEjE,EAAA,MAAM,EAAE,WAAc,GAAA,CAAA,EAAG,UAAU,CAAE,EAAA,GAAI,YAAY,OAAO,CAAA;AAC5D,EAAA,IAAI,gBAAgB,OAAS,EAAA;AAE3B,IAAO,OAAA,KAAA;AAAA,aACE,IAAK,CAAA,GAAA,CAAI,QAAQ,CAAA,GAAI,cAAc,OAAS,EAAA;AAErD,IAAM,MAAA,UAAA,GAAa,QAAW,GAAA,CAAA,GAAI,CAAK,CAAA,GAAA,CAAA;AACvC,IAAA,QAAA,GAAW,IAAK,CAAA,GAAA,CAAI,CAAG,EAAA,WAAA,GAAc,OAAO,CAAI,GAAA,UAAA;AAAA;AAGlD,EAAA,MAAM,WAAc,GAAA,WAAA,CAAY,aAAc,CAAA,CAAC,CAAC,CAAA;AAChD,EAAA,MAAM,EAAE,WAAA,EAAa,WAAc,GAAA,CAAA,EAAM,GAAA,WAAA;AACzC,EAAA,WAAA,CAAY,cAAc,WAAc,GAAA,QAAA;AAExC,EAAA,MAAM,YAAe,GAAA,WAAA,CAAY,aAAc,CAAA,CAAC,CAAC,CAAA;AACjD,EAAA,MAAM,EAAE,WAAA,EAAa,YAAe,GAAA,CAAA,EAAM,GAAA,YAAA;AAC1C,EAAA,YAAA,CAAa,cAAc,YAAe,GAAA,QAAA;AAE1C,EAAO,OAAA,IAAA;AACT;AAEA,SAAS,kBAAkB,KAAe,EAAA;AACxC,EAAO,OAAA,KAAA,CAAM,cAAcC,uBAAa,EAAA;AAAA,IACtC,MAAM,KAAU,KAAA,CAAA;AAAA,IAChB,GAAA,EAAK,eAAe,KAAK,CAAA;AAAA,GAC1B,CAAA;AACH;AAEA,SAAS,cAAA,CACP,IACA,SACU,EAAA;AACV,EAAA,MAAM,EAAE,CAAC,SAAS,GAAG,IAAK,EAAA,GAAI,GAAG,qBAAsB,EAAA;AACvD,EAAM,MAAA,KAAA,GAAQ,iBAAiB,EAAE,CAAA;AACjC,EAAA,MAAM,UAAa,GAAA,KAAA,CAAM,gBAAiB,CAAA,CAAA,IAAA,EAAO,SAAS,CAAE,CAAA,CAAA;AAC5D,EAAM,MAAA,OAAA,GAAU,WAAW,QAAS,CAAA,IAAI,IAAI,QAAS,CAAA,UAAA,EAAY,EAAE,CAAI,GAAA,CAAA;AACvE,EAAO,OAAA,EAAE,MAAM,OAAQ,EAAA;AACzB;;;;"}
|
package/cjs/layout-action.js
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const Action = {
|
|
4
|
-
ADD: "add",
|
|
5
|
-
BLUR: "blur",
|
|
6
|
-
BLUR_SPLITTER: "blur-splitter",
|
|
7
|
-
DRAG_START: "drag-start",
|
|
8
|
-
DRAG_STARTED: "drag-started",
|
|
9
|
-
DRAG_DROP: "drag-drop",
|
|
10
|
-
FOCUS: "focus",
|
|
11
|
-
FOCUS_SPLITTER: "focus-splitter",
|
|
12
|
-
INITIALIZE: "initialize",
|
|
13
|
-
LAYOUT_RESIZE: "layout-resize",
|
|
14
|
-
MAXIMIZE: "maximize",
|
|
15
|
-
MINIMIZE: "minimize",
|
|
16
|
-
REMOVE: "remove",
|
|
17
|
-
REPLACE: "replace",
|
|
18
|
-
RESTORE: "restore",
|
|
19
|
-
SAVE: "save",
|
|
20
|
-
SPLITTER_RESIZE: "splitter-resize"
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
exports.Action = Action;
|
|
24
|
-
//# sourceMappingURL=layout-action.js.map
|
package/cjs/layout-action.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"layout-action.js","sources":["../src/layout-action.ts"],"sourcesContent":["export const Action = {\n ADD: \"add\",\n BLUR: \"blur\",\n BLUR_SPLITTER: \"blur-splitter\",\n DRAG_START: \"drag-start\",\n DRAG_STARTED: \"drag-started\",\n DRAG_DROP: \"drag-drop\",\n FOCUS: \"focus\",\n FOCUS_SPLITTER: \"focus-splitter\",\n INITIALIZE: \"initialize\",\n LAYOUT_RESIZE: \"layout-resize\",\n MAXIMIZE: \"maximize\",\n MINIMIZE: \"minimize\",\n REMOVE: \"remove\",\n REPLACE: \"replace\",\n RESTORE: \"restore\",\n SAVE: \"save\",\n SPLITTER_RESIZE: \"splitter-resize\",\n};\n"],"names":[],"mappings":";;AAAO,MAAM,MAAS,GAAA;AAAA,EACpB,GAAK,EAAA,KAAA;AAAA,EACL,IAAM,EAAA,MAAA;AAAA,EACN,aAAe,EAAA,eAAA;AAAA,EACf,UAAY,EAAA,YAAA;AAAA,EACZ,YAAc,EAAA,cAAA;AAAA,EACd,SAAW,EAAA,WAAA;AAAA,EACX,KAAO,EAAA,OAAA;AAAA,EACP,cAAgB,EAAA,gBAAA;AAAA,EAChB,UAAY,EAAA,YAAA;AAAA,EACZ,aAAe,EAAA,eAAA;AAAA,EACf,QAAU,EAAA,UAAA;AAAA,EACV,QAAU,EAAA,UAAA;AAAA,EACV,MAAQ,EAAA,QAAA;AAAA,EACR,OAAS,EAAA,SAAA;AAAA,EACT,OAAS,EAAA,SAAA;AAAA,EACT,IAAM,EAAA,MAAA;AAAA,EACN,eAAiB,EAAA;AACnB;;;;"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var headerCss = ".vuuHeader {\n --saltButton-height: 24px;\n --saltButton-width: 24px;\n\n padding: 0 var(--salt-spacing-100);\n\n [data-align=\"end\"] {\n margin-left: auto;\n }\n [data-align=\"end\"] ~ [data-align=\"end\"] {\n margin-left: 0;\n }\n\n &:hover {\n .vuuHeader-edit {\n visibility: visible;\n }\n }\n}\n\n.vuuHeader-edit {\n visibility: hidden;\n}\n\n.salt-density-high .vuuHeader {\n --saltToolbarField-marginTop: 0;\n}\n";
|
|
4
|
-
|
|
5
|
-
module.exports = headerCss;
|
|
6
|
-
//# sourceMappingURL=Header.css.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Header.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
|
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
-
var vuuUiControls = require('@vuu-ui/vuu-ui-controls');
|
|
5
|
-
var styles = require('@salt-ds/styles');
|
|
6
|
-
var window = require('@salt-ds/window');
|
|
7
|
-
var cx = require('clsx');
|
|
8
|
-
var React = require('react');
|
|
9
|
-
var useHeader = require('./useHeader.js');
|
|
10
|
-
var Header$1 = require('./Header.css.js');
|
|
11
|
-
|
|
12
|
-
const classBase = "vuuHeader";
|
|
13
|
-
const Header = ({
|
|
14
|
-
allowRename = false,
|
|
15
|
-
className: classNameProp,
|
|
16
|
-
contributions,
|
|
17
|
-
collapsed,
|
|
18
|
-
closeable,
|
|
19
|
-
onCollapse,
|
|
20
|
-
onEditTitle,
|
|
21
|
-
onExpand,
|
|
22
|
-
orientation: orientationProp = "horizontal",
|
|
23
|
-
style,
|
|
24
|
-
title = "Untitled"
|
|
25
|
-
}) => {
|
|
26
|
-
const targetWindow = window.useWindow();
|
|
27
|
-
styles.useComponentCssInjection({
|
|
28
|
-
testId: "vuu-header",
|
|
29
|
-
css: Header$1,
|
|
30
|
-
window: targetWindow
|
|
31
|
-
});
|
|
32
|
-
const {
|
|
33
|
-
editing,
|
|
34
|
-
focusTitle,
|
|
35
|
-
labelFieldRef,
|
|
36
|
-
onClickEdit,
|
|
37
|
-
onClose,
|
|
38
|
-
onExitEditMode,
|
|
39
|
-
onMouseDown,
|
|
40
|
-
onTitleKeyDown,
|
|
41
|
-
onToggleCollapse,
|
|
42
|
-
onToggleExpand,
|
|
43
|
-
setValue,
|
|
44
|
-
value
|
|
45
|
-
} = useHeader.useHeader({
|
|
46
|
-
onCollapse,
|
|
47
|
-
onEditTitle,
|
|
48
|
-
onExpand,
|
|
49
|
-
title
|
|
50
|
-
});
|
|
51
|
-
const handleButtonMouseDown = (evt) => {
|
|
52
|
-
evt.stopPropagation();
|
|
53
|
-
};
|
|
54
|
-
const orientation = collapsed || orientationProp;
|
|
55
|
-
const className = cx(classBase, classNameProp, `${classBase}-${orientation}`);
|
|
56
|
-
const toolbarItems = [];
|
|
57
|
-
const postTitleContributedItems = [];
|
|
58
|
-
const actionButtons = [];
|
|
59
|
-
const allowCollapse = typeof collapsed === "boolean" || typeof collapsed === "string";
|
|
60
|
-
contributions?.forEach((contribution, i) => {
|
|
61
|
-
switch (contribution.location) {
|
|
62
|
-
case "pre-title":
|
|
63
|
-
toolbarItems.push(React.cloneElement(contribution.content, { key: i }));
|
|
64
|
-
break;
|
|
65
|
-
default:
|
|
66
|
-
postTitleContributedItems.push(
|
|
67
|
-
React.cloneElement(contribution.content, { key: i })
|
|
68
|
-
);
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
allowCollapse && toolbarItems.push(
|
|
72
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
73
|
-
vuuUiControls.IconButton,
|
|
74
|
-
{
|
|
75
|
-
className: cx(`${classBase}-toggle`, {
|
|
76
|
-
[`${classBase}-collapsed`]: collapsed
|
|
77
|
-
}),
|
|
78
|
-
"data-embedded": true,
|
|
79
|
-
icon: collapsed ? "chevron-open" : "chevron-down",
|
|
80
|
-
onClick: collapsed ? onToggleExpand : onToggleCollapse,
|
|
81
|
-
size: 20,
|
|
82
|
-
tabIndex: 0,
|
|
83
|
-
appearance: "transparent",
|
|
84
|
-
sentiment: "neutral"
|
|
85
|
-
},
|
|
86
|
-
"collapse-button"
|
|
87
|
-
)
|
|
88
|
-
);
|
|
89
|
-
title && toolbarItems.push(
|
|
90
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
91
|
-
vuuUiControls.EditableLabel,
|
|
92
|
-
{
|
|
93
|
-
className: `${classBase}-title`,
|
|
94
|
-
editing,
|
|
95
|
-
value,
|
|
96
|
-
onChange: setValue,
|
|
97
|
-
onMouseDownCapture: focusTitle,
|
|
98
|
-
onExitEditMode,
|
|
99
|
-
onKeyDown: onTitleKeyDown,
|
|
100
|
-
ref: labelFieldRef
|
|
101
|
-
},
|
|
102
|
-
"title"
|
|
103
|
-
)
|
|
104
|
-
);
|
|
105
|
-
allowRename && toolbarItems.push(
|
|
106
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
107
|
-
vuuUiControls.IconButton,
|
|
108
|
-
{
|
|
109
|
-
className: `${classBase}-edit`,
|
|
110
|
-
"data-embedded": true,
|
|
111
|
-
icon: "edit",
|
|
112
|
-
onClick: onClickEdit,
|
|
113
|
-
onMouseDown: handleButtonMouseDown,
|
|
114
|
-
tabIndex: 0,
|
|
115
|
-
variant: "secondary"
|
|
116
|
-
},
|
|
117
|
-
"edit-button"
|
|
118
|
-
)
|
|
119
|
-
);
|
|
120
|
-
closeable && actionButtons.push(
|
|
121
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
122
|
-
vuuUiControls.IconButton,
|
|
123
|
-
{
|
|
124
|
-
appearance: "transparent",
|
|
125
|
-
"data-embedded": true,
|
|
126
|
-
icon: "close",
|
|
127
|
-
onClick: onClose,
|
|
128
|
-
onMouseDown: handleButtonMouseDown,
|
|
129
|
-
sentiment: "neutral"
|
|
130
|
-
},
|
|
131
|
-
"close"
|
|
132
|
-
)
|
|
133
|
-
);
|
|
134
|
-
postTitleContributedItems.length > 0 && toolbarItems.push(
|
|
135
|
-
/* @__PURE__ */ jsxRuntime.jsx("div", { "data-align": "end", children: postTitleContributedItems }, "contributions")
|
|
136
|
-
);
|
|
137
|
-
actionButtons.length > 0 && toolbarItems.push(
|
|
138
|
-
/* @__PURE__ */ jsxRuntime.jsx("div", { "data-align": "end", children: actionButtons }, "actions")
|
|
139
|
-
);
|
|
140
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
141
|
-
"div",
|
|
142
|
-
{
|
|
143
|
-
className: cx("vuuToolbarProxy", className),
|
|
144
|
-
style,
|
|
145
|
-
onMouseDown,
|
|
146
|
-
children: toolbarItems
|
|
147
|
-
}
|
|
148
|
-
);
|
|
149
|
-
};
|
|
150
|
-
|
|
151
|
-
exports.Header = Header;
|
|
152
|
-
//# sourceMappingURL=Header.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Header.js","sources":["../../src/layout-header/Header.tsx"],"sourcesContent":["import { EditableLabel, IconButton } from \"@vuu-ui/vuu-ui-controls\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport cx from \"clsx\";\nimport { HTMLAttributes, MouseEvent, ReactElement, cloneElement } from \"react\";\nimport { Contribution } from \"../layout-view\";\nimport { useHeader } from \"./useHeader\";\n\nimport headerCss from \"./Header.css\";\n\nexport interface HeaderProps extends HTMLAttributes<HTMLDivElement> {\n allowRename?: boolean;\n collapsed?: boolean;\n contributions?: Contribution[];\n expanded?: boolean;\n closeable?: boolean;\n onCollapse?: () => void;\n onEditTitle?: (value: string) => void;\n onExpand?: () => void;\n orientation?: \"horizontal\" | \"vertical\";\n tearOut?: boolean;\n}\n\nconst classBase = \"vuuHeader\";\n\nexport const Header = ({\n allowRename = false,\n className: classNameProp,\n contributions,\n collapsed,\n closeable,\n onCollapse,\n onEditTitle,\n onExpand,\n orientation: orientationProp = \"horizontal\",\n style,\n title = \"Untitled\",\n}: HeaderProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-header\",\n css: headerCss,\n window: targetWindow,\n });\n\n const {\n editing,\n focusTitle,\n labelFieldRef,\n onClickEdit,\n onClose,\n onExitEditMode,\n onMouseDown,\n onTitleKeyDown,\n onToggleCollapse,\n onToggleExpand,\n setValue,\n value,\n } = useHeader({\n onCollapse,\n onEditTitle,\n onExpand,\n title,\n });\n\n const handleButtonMouseDown = (evt: MouseEvent) => {\n // do not allow drag to be initiated\n evt.stopPropagation();\n };\n\n const orientation = collapsed || orientationProp;\n\n const className = cx(classBase, classNameProp, `${classBase}-${orientation}`);\n\n const toolbarItems: ReactElement[] = [];\n const postTitleContributedItems: ReactElement[] = [];\n const actionButtons: ReactElement[] = [];\n const allowCollapse =\n typeof collapsed === \"boolean\" || typeof collapsed === \"string\";\n\n contributions?.forEach((contribution, i) => {\n switch (contribution.location) {\n case \"pre-title\":\n toolbarItems.push(cloneElement(contribution.content, { key: i }));\n break;\n default:\n postTitleContributedItems.push(\n cloneElement(contribution.content, { key: i }),\n );\n }\n });\n\n allowCollapse &&\n toolbarItems.push(\n <IconButton\n className={cx(`${classBase}-toggle`, {\n [`${classBase}-collapsed`]: collapsed,\n })}\n data-embedded\n icon={collapsed ? \"chevron-open\" : \"chevron-down\"}\n key=\"collapse-button\"\n onClick={collapsed ? onToggleExpand : onToggleCollapse}\n size={20}\n tabIndex={0}\n appearance=\"transparent\"\n sentiment=\"neutral\"\n />,\n );\n\n title &&\n toolbarItems.push(\n <EditableLabel\n className={`${classBase}-title`}\n editing={editing}\n key=\"title\"\n value={value}\n onChange={setValue}\n onMouseDownCapture={focusTitle}\n onExitEditMode={onExitEditMode}\n onKeyDown={onTitleKeyDown}\n ref={labelFieldRef}\n />,\n );\n\n allowRename &&\n toolbarItems.push(\n <IconButton\n className={`${classBase}-edit`}\n data-embedded\n icon=\"edit\"\n key=\"edit-button\"\n onClick={onClickEdit}\n onMouseDown={handleButtonMouseDown}\n tabIndex={0}\n variant=\"secondary\"\n />,\n );\n\n closeable &&\n actionButtons.push(\n <IconButton\n appearance=\"transparent\"\n data-embedded\n icon=\"close\"\n key=\"close\"\n onClick={onClose}\n onMouseDown={handleButtonMouseDown}\n sentiment=\"neutral\"\n />,\n );\n\n postTitleContributedItems.length > 0 &&\n toolbarItems.push(\n <div data-align=\"end\" key=\"contributions\">\n {postTitleContributedItems}\n </div>,\n );\n\n actionButtons.length > 0 &&\n toolbarItems.push(\n <div data-align=\"end\" key=\"actions\">\n {actionButtons}\n </div>,\n );\n\n return (\n <div\n className={cx(\"vuuToolbarProxy\", className)}\n style={style}\n onMouseDown={onMouseDown}\n >\n {toolbarItems}\n </div>\n );\n};\n"],"names":["useWindow","useComponentCssInjection","headerCss","useHeader","cloneElement","jsx","IconButton","EditableLabel"],"mappings":"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"}
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var React = require('react');
|
|
4
|
-
require('../layout-provider/LayoutProvider.js');
|
|
5
|
-
var ViewContext = require('../layout-view-actions/ViewContext.js');
|
|
6
|
-
var vuuUtils = require('@vuu-ui/vuu-utils');
|
|
7
|
-
|
|
8
|
-
const useHeader = ({
|
|
9
|
-
onCollapse,
|
|
10
|
-
onEditTitle,
|
|
11
|
-
onExpand,
|
|
12
|
-
title
|
|
13
|
-
}) => {
|
|
14
|
-
const [editing, setEditing] = React.useState(false);
|
|
15
|
-
const [value, setValue] = React.useState(title);
|
|
16
|
-
const labelFieldRef = React.useRef(null);
|
|
17
|
-
const viewDispatch = ViewContext.useViewDispatch();
|
|
18
|
-
const handleClose = React.useCallback(
|
|
19
|
-
(evt) => viewDispatch?.({ type: "remove" }, evt),
|
|
20
|
-
[viewDispatch]
|
|
21
|
-
);
|
|
22
|
-
const focusTitle = React.useCallback(() => {
|
|
23
|
-
labelFieldRef.current?.focus();
|
|
24
|
-
}, []);
|
|
25
|
-
const handleClickEdit = React.useCallback(() => {
|
|
26
|
-
focusTitle();
|
|
27
|
-
setEditing((isEditing) => !isEditing);
|
|
28
|
-
}, [focusTitle]);
|
|
29
|
-
const handleTitleKeyDown = (evt) => {
|
|
30
|
-
if (evt.key === "Enter") {
|
|
31
|
-
setEditing(true);
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
const handleMouseDown = React.useCallback(
|
|
35
|
-
(e) => {
|
|
36
|
-
const button = vuuUtils.queryClosest(e.target, ".saltButton");
|
|
37
|
-
if (button === null) {
|
|
38
|
-
viewDispatch?.({ type: "mousedown" }, e);
|
|
39
|
-
}
|
|
40
|
-
},
|
|
41
|
-
[viewDispatch]
|
|
42
|
-
);
|
|
43
|
-
const handleExitEditMode = (originalValue = "", finalValue = "", allowDeactivation = true, editCancelled = false) => {
|
|
44
|
-
setEditing(false);
|
|
45
|
-
if (editCancelled) {
|
|
46
|
-
setValue(originalValue);
|
|
47
|
-
} else if (finalValue !== originalValue) {
|
|
48
|
-
setValue(finalValue);
|
|
49
|
-
onEditTitle?.(finalValue);
|
|
50
|
-
}
|
|
51
|
-
if (allowDeactivation === false) {
|
|
52
|
-
labelFieldRef.current?.focus();
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
const handleToggleCollapse = React.useCallback(
|
|
56
|
-
(e) => {
|
|
57
|
-
viewDispatch?.({ type: "collapse" }, e);
|
|
58
|
-
onCollapse?.();
|
|
59
|
-
},
|
|
60
|
-
[onCollapse, viewDispatch]
|
|
61
|
-
);
|
|
62
|
-
const handleToggleExpand = React.useCallback(
|
|
63
|
-
(e) => {
|
|
64
|
-
viewDispatch?.({ type: "expand" }, e);
|
|
65
|
-
onExpand?.();
|
|
66
|
-
},
|
|
67
|
-
[onExpand, viewDispatch]
|
|
68
|
-
);
|
|
69
|
-
return {
|
|
70
|
-
editing,
|
|
71
|
-
focusTitle,
|
|
72
|
-
labelFieldRef,
|
|
73
|
-
onClickEdit: handleClickEdit,
|
|
74
|
-
onClose: handleClose,
|
|
75
|
-
onExitEditMode: handleExitEditMode,
|
|
76
|
-
onMouseDown: handleMouseDown,
|
|
77
|
-
onToggleCollapse: handleToggleCollapse,
|
|
78
|
-
onToggleExpand: handleToggleExpand,
|
|
79
|
-
onTitleKeyDown: handleTitleKeyDown,
|
|
80
|
-
setValue,
|
|
81
|
-
value
|
|
82
|
-
};
|
|
83
|
-
};
|
|
84
|
-
|
|
85
|
-
exports.useHeader = useHeader;
|
|
86
|
-
//# sourceMappingURL=useHeader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useHeader.js","sources":["../../src/layout-header/useHeader.ts"],"sourcesContent":["import {\n KeyboardEvent,\n MouseEventHandler,\n useCallback,\n useRef,\n useState,\n} from \"react\";\nimport type { HeaderProps } from \"./Header\";\nimport { useViewDispatch } from \"../layout-view-actions\";\nimport { queryClosest } from \"@vuu-ui/vuu-utils\";\n\nexport interface HeaderHookProps\n extends Pick<HeaderProps, \"onCollapse\" | \"onEditTitle\" | \"onExpand\"> {\n debugString?: string;\n title: string;\n}\n\nexport const useHeader = ({\n onCollapse,\n onEditTitle,\n onExpand,\n title,\n}: HeaderHookProps) => {\n const [editing, setEditing] = useState<boolean>(false);\n const [value, setValue] = useState<string>(title);\n const labelFieldRef = useRef<HTMLDivElement>(null);\n\n const viewDispatch = useViewDispatch();\n const handleClose = useCallback<MouseEventHandler>(\n (evt) => viewDispatch?.({ type: \"remove\" }, evt),\n [viewDispatch],\n );\n\n const focusTitle = useCallback(() => {\n labelFieldRef.current?.focus();\n }, []);\n\n const handleClickEdit = useCallback(() => {\n focusTitle();\n setEditing((isEditing) => !isEditing);\n }, [focusTitle]);\n\n const handleTitleKeyDown = (evt: KeyboardEvent<HTMLDivElement>) => {\n if (evt.key === \"Enter\") {\n setEditing(true);\n }\n };\n\n const handleMouseDown = useCallback<MouseEventHandler>(\n (e) => {\n const button = queryClosest(e.target, \".saltButton\");\n if (button === null) {\n // This is for drag start detection.\n viewDispatch?.({ type: \"mousedown\" }, e);\n }\n },\n [viewDispatch],\n );\n\n const handleExitEditMode = (\n originalValue = \"\",\n finalValue = \"\",\n allowDeactivation = true,\n editCancelled = false,\n ) => {\n setEditing(false);\n if (editCancelled) {\n setValue(originalValue);\n } else if (finalValue !== originalValue) {\n setValue(finalValue);\n onEditTitle?.(finalValue);\n }\n if (allowDeactivation === false) {\n labelFieldRef.current?.focus();\n }\n };\n\n const handleToggleCollapse = useCallback<MouseEventHandler>(\n (e) => {\n viewDispatch?.({ type: \"collapse\" }, e);\n onCollapse?.();\n },\n [onCollapse, viewDispatch],\n );\n\n const handleToggleExpand = useCallback<MouseEventHandler>(\n (e) => {\n viewDispatch?.({ type: \"expand\" }, e);\n onExpand?.();\n },\n [onExpand, viewDispatch],\n );\n\n return {\n editing,\n focusTitle,\n labelFieldRef,\n onClickEdit: handleClickEdit,\n onClose: handleClose,\n onExitEditMode: handleExitEditMode,\n onMouseDown: handleMouseDown,\n onToggleCollapse: handleToggleCollapse,\n onToggleExpand: handleToggleExpand,\n onTitleKeyDown: handleTitleKeyDown,\n setValue,\n value,\n };\n};\n"],"names":["useState","useRef","useViewDispatch","useCallback","queryClosest"],"mappings":"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"}
|