@vuu-ui/vuu-layout 0.0.26
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/LICENSE +201 -0
- package/README.md +1 -0
- package/cjs/Component.js +14 -0
- package/cjs/Component.js.map +1 -0
- package/cjs/DraggableLayout.css.js +6 -0
- package/cjs/DraggableLayout.css.js.map +1 -0
- package/cjs/DraggableLayout.js +33 -0
- package/cjs/DraggableLayout.js.map +1 -0
- package/cjs/dock-layout/DockLayout.css.js +6 -0
- package/cjs/dock-layout/DockLayout.css.js.map +1 -0
- package/cjs/dock-layout/DockLayout.js +36 -0
- package/cjs/dock-layout/DockLayout.js.map +1 -0
- package/cjs/dock-layout/Drawer.css.js +6 -0
- package/cjs/dock-layout/Drawer.css.js.map +1 -0
- package/cjs/dock-layout/Drawer.js +96 -0
- package/cjs/dock-layout/Drawer.js.map +1 -0
- package/cjs/drag-drop/BoxModel.js +422 -0
- package/cjs/drag-drop/BoxModel.js.map +1 -0
- package/cjs/drag-drop/DragState.js +154 -0
- package/cjs/drag-drop/DragState.js.map +1 -0
- package/cjs/drag-drop/Draggable.js +192 -0
- package/cjs/drag-drop/Draggable.js.map +1 -0
- package/cjs/drag-drop/DropMenu.css.js +6 -0
- package/cjs/drag-drop/DropMenu.css.js.map +1 -0
- package/cjs/drag-drop/DropMenu.js +55 -0
- package/cjs/drag-drop/DropMenu.js.map +1 -0
- package/cjs/drag-drop/DropTarget.js +244 -0
- package/cjs/drag-drop/DropTarget.js.map +1 -0
- package/cjs/drag-drop/DropTargetRenderer.js +244 -0
- package/cjs/drag-drop/DropTargetRenderer.js.map +1 -0
- package/cjs/flexbox/Flexbox.css.js +6 -0
- package/cjs/flexbox/Flexbox.css.js.map +1 -0
- package/cjs/flexbox/Flexbox.js +70 -0
- package/cjs/flexbox/Flexbox.js.map +1 -0
- package/cjs/flexbox/FlexboxLayout.js +30 -0
- package/cjs/flexbox/FlexboxLayout.js.map +1 -0
- package/cjs/flexbox/FluidGrid.css.js +6 -0
- package/cjs/flexbox/FluidGrid.css.js.map +1 -0
- package/cjs/flexbox/FluidGrid.js +87 -0
- package/cjs/flexbox/FluidGrid.js.map +1 -0
- package/cjs/flexbox/FluidGridLayout.js +14 -0
- package/cjs/flexbox/FluidGridLayout.js.map +1 -0
- package/cjs/flexbox/Splitter.css.js +6 -0
- package/cjs/flexbox/Splitter.css.js.map +1 -0
- package/cjs/flexbox/Splitter.js +122 -0
- package/cjs/flexbox/Splitter.js.map +1 -0
- package/cjs/flexbox/flexbox-utils.js +109 -0
- package/cjs/flexbox/flexbox-utils.js.map +1 -0
- package/cjs/flexbox/useResponsiveSizing.js +62 -0
- package/cjs/flexbox/useResponsiveSizing.js.map +1 -0
- package/cjs/flexbox/useSplitterResizing.js +209 -0
- package/cjs/flexbox/useSplitterResizing.js.map +1 -0
- package/cjs/index.js +133 -0
- package/cjs/index.js.map +1 -0
- package/cjs/layout-action.js +27 -0
- package/cjs/layout-action.js.map +1 -0
- package/cjs/layout-header/Header.css.js +6 -0
- package/cjs/layout-header/Header.css.js.map +1 -0
- package/cjs/layout-header/Header.js +131 -0
- package/cjs/layout-header/Header.js.map +1 -0
- package/cjs/layout-provider/LayoutProvider.js +178 -0
- package/cjs/layout-provider/LayoutProvider.js.map +1 -0
- package/cjs/layout-provider/LayoutProviderContext.js +14 -0
- package/cjs/layout-provider/LayoutProviderContext.js.map +1 -0
- package/cjs/layout-provider/useLayoutDragDrop.js +172 -0
- package/cjs/layout-provider/useLayoutDragDrop.js.map +1 -0
- package/cjs/layout-reducer/flexUtils.js +219 -0
- package/cjs/layout-reducer/flexUtils.js.map +1 -0
- package/cjs/layout-reducer/insert-layout-element.js +273 -0
- package/cjs/layout-reducer/insert-layout-element.js.map +1 -0
- package/cjs/layout-reducer/layout-reducer.js +198 -0
- package/cjs/layout-reducer/layout-reducer.js.map +1 -0
- package/cjs/layout-reducer/layoutTypes.js +41 -0
- package/cjs/layout-reducer/layoutTypes.js.map +1 -0
- package/cjs/layout-reducer/layoutUtils.js +226 -0
- package/cjs/layout-reducer/layoutUtils.js.map +1 -0
- package/cjs/layout-reducer/move-layout-element.js +31 -0
- package/cjs/layout-reducer/move-layout-element.js.map +1 -0
- package/cjs/layout-reducer/remove-layout-element.js +223 -0
- package/cjs/layout-reducer/remove-layout-element.js.map +1 -0
- package/cjs/layout-reducer/replace-layout-element.js +91 -0
- package/cjs/layout-reducer/replace-layout-element.js.map +1 -0
- package/cjs/layout-reducer/resize-flex-children.js +61 -0
- package/cjs/layout-reducer/resize-flex-children.js.map +1 -0
- package/cjs/layout-reducer/wrap-layout-element.js +212 -0
- package/cjs/layout-reducer/wrap-layout-element.js.map +1 -0
- package/cjs/layout-view/View.css.js +6 -0
- package/cjs/layout-view/View.css.js.map +1 -0
- package/cjs/layout-view/View.js +164 -0
- package/cjs/layout-view/View.js.map +1 -0
- package/cjs/layout-view/useView.js +92 -0
- package/cjs/layout-view/useView.js.map +1 -0
- package/cjs/layout-view/useViewResize.js +42 -0
- package/cjs/layout-view/useViewResize.js.map +1 -0
- package/cjs/layout-view-actions/ViewContext.js +16 -0
- package/cjs/layout-view-actions/ViewContext.js.map +1 -0
- package/cjs/layout-view-actions/useViewActionDispatcher.js +103 -0
- package/cjs/layout-view-actions/useViewActionDispatcher.js.map +1 -0
- package/cjs/palette/Palette.css.js +6 -0
- package/cjs/palette/Palette.css.js.map +1 -0
- package/cjs/palette/Palette.js +127 -0
- package/cjs/palette/Palette.js.map +1 -0
- package/cjs/placeholder/LayoutStartPanel.css.js +6 -0
- package/cjs/placeholder/LayoutStartPanel.css.js.map +1 -0
- package/cjs/placeholder/LayoutStartPanel.js +60 -0
- package/cjs/placeholder/LayoutStartPanel.js.map +1 -0
- package/cjs/placeholder/Placeholder.css.js +6 -0
- package/cjs/placeholder/Placeholder.css.js.map +1 -0
- package/cjs/placeholder/Placeholder.js +34 -0
- package/cjs/placeholder/Placeholder.js.map +1 -0
- package/cjs/registry/ComponentRegistry.js +27 -0
- package/cjs/registry/ComponentRegistry.js.map +1 -0
- package/cjs/responsive/breakpoints.js +36 -0
- package/cjs/responsive/breakpoints.js.map +1 -0
- package/cjs/responsive/use-breakpoints.js +76 -0
- package/cjs/responsive/use-breakpoints.js.map +1 -0
- package/cjs/responsive/useResizeObserver.js +118 -0
- package/cjs/responsive/useResizeObserver.js.map +1 -0
- package/cjs/responsive/utils.js +34 -0
- package/cjs/responsive/utils.js.map +1 -0
- package/cjs/stack/Stack.css.js +6 -0
- package/cjs/stack/Stack.css.js.map +1 -0
- package/cjs/stack/Stack.js +148 -0
- package/cjs/stack/Stack.js.map +1 -0
- package/cjs/stack/StackLayout.js +122 -0
- package/cjs/stack/StackLayout.js.map +1 -0
- package/cjs/use-persistent-state.js +109 -0
- package/cjs/use-persistent-state.js.map +1 -0
- package/cjs/utils/pathUtils.js +293 -0
- package/cjs/utils/pathUtils.js.map +1 -0
- package/cjs/utils/propUtils.js +27 -0
- package/cjs/utils/propUtils.js.map +1 -0
- package/cjs/utils/refUtils.js +12 -0
- package/cjs/utils/refUtils.js.map +1 -0
- package/cjs/utils/styleUtils.js +15 -0
- package/cjs/utils/styleUtils.js.map +1 -0
- package/cjs/utils/typeOf.js +27 -0
- package/cjs/utils/typeOf.js.map +1 -0
- package/esm/Component.js +12 -0
- package/esm/Component.js.map +1 -0
- package/esm/DraggableLayout.css.js +4 -0
- package/esm/DraggableLayout.css.js.map +1 -0
- package/esm/DraggableLayout.js +31 -0
- package/esm/DraggableLayout.js.map +1 -0
- package/esm/dock-layout/DockLayout.css.js +4 -0
- package/esm/dock-layout/DockLayout.css.js.map +1 -0
- package/esm/dock-layout/DockLayout.js +34 -0
- package/esm/dock-layout/DockLayout.js.map +1 -0
- package/esm/dock-layout/Drawer.css.js +4 -0
- package/esm/dock-layout/Drawer.css.js.map +1 -0
- package/esm/dock-layout/Drawer.js +94 -0
- package/esm/dock-layout/Drawer.js.map +1 -0
- package/esm/drag-drop/BoxModel.js +415 -0
- package/esm/drag-drop/BoxModel.js.map +1 -0
- package/esm/drag-drop/DragState.js +152 -0
- package/esm/drag-drop/DragState.js.map +1 -0
- package/esm/drag-drop/Draggable.js +190 -0
- package/esm/drag-drop/Draggable.js.map +1 -0
- package/esm/drag-drop/DropMenu.css.js +4 -0
- package/esm/drag-drop/DropMenu.css.js.map +1 -0
- package/esm/drag-drop/DropMenu.js +52 -0
- package/esm/drag-drop/DropMenu.js.map +1 -0
- package/esm/drag-drop/DropTarget.js +240 -0
- package/esm/drag-drop/DropTarget.js.map +1 -0
- package/esm/drag-drop/DropTargetRenderer.js +242 -0
- package/esm/drag-drop/DropTargetRenderer.js.map +1 -0
- package/esm/flexbox/Flexbox.css.js +4 -0
- package/esm/flexbox/Flexbox.css.js.map +1 -0
- package/esm/flexbox/Flexbox.js +68 -0
- package/esm/flexbox/Flexbox.js.map +1 -0
- package/esm/flexbox/FlexboxLayout.js +28 -0
- package/esm/flexbox/FlexboxLayout.js.map +1 -0
- package/esm/flexbox/FluidGrid.css.js +4 -0
- package/esm/flexbox/FluidGrid.css.js.map +1 -0
- package/esm/flexbox/FluidGrid.js +85 -0
- package/esm/flexbox/FluidGrid.js.map +1 -0
- package/esm/flexbox/FluidGridLayout.js +12 -0
- package/esm/flexbox/FluidGridLayout.js.map +1 -0
- package/esm/flexbox/Splitter.css.js +4 -0
- package/esm/flexbox/Splitter.css.js.map +1 -0
- package/esm/flexbox/Splitter.js +120 -0
- package/esm/flexbox/Splitter.js.map +1 -0
- package/esm/flexbox/flexbox-utils.js +103 -0
- package/esm/flexbox/flexbox-utils.js.map +1 -0
- package/esm/flexbox/useResponsiveSizing.js +60 -0
- package/esm/flexbox/useResponsiveSizing.js.map +1 -0
- package/esm/flexbox/useSplitterResizing.js +207 -0
- package/esm/flexbox/useSplitterResizing.js.map +1 -0
- package/esm/index.js +37 -0
- package/esm/index.js.map +1 -0
- package/esm/layout-action.js +25 -0
- package/esm/layout-action.js.map +1 -0
- package/esm/layout-header/Header.css.js +4 -0
- package/esm/layout-header/Header.css.js.map +1 -0
- package/esm/layout-header/Header.js +129 -0
- package/esm/layout-header/Header.js.map +1 -0
- package/esm/layout-provider/LayoutProvider.js +172 -0
- package/esm/layout-provider/LayoutProvider.js.map +1 -0
- package/esm/layout-provider/LayoutProviderContext.js +12 -0
- package/esm/layout-provider/LayoutProviderContext.js.map +1 -0
- package/esm/layout-provider/useLayoutDragDrop.js +170 -0
- package/esm/layout-provider/useLayoutDragDrop.js.map +1 -0
- package/esm/layout-reducer/flexUtils.js +210 -0
- package/esm/layout-reducer/flexUtils.js.map +1 -0
- package/esm/layout-reducer/insert-layout-element.js +269 -0
- package/esm/layout-reducer/insert-layout-element.js.map +1 -0
- package/esm/layout-reducer/layout-reducer.js +196 -0
- package/esm/layout-reducer/layout-reducer.js.map +1 -0
- package/esm/layout-reducer/layoutTypes.js +37 -0
- package/esm/layout-reducer/layoutTypes.js.map +1 -0
- package/esm/layout-reducer/layoutUtils.js +215 -0
- package/esm/layout-reducer/layoutUtils.js.map +1 -0
- package/esm/layout-reducer/move-layout-element.js +29 -0
- package/esm/layout-reducer/move-layout-element.js.map +1 -0
- package/esm/layout-reducer/remove-layout-element.js +221 -0
- package/esm/layout-reducer/remove-layout-element.js.map +1 -0
- package/esm/layout-reducer/replace-layout-element.js +87 -0
- package/esm/layout-reducer/replace-layout-element.js.map +1 -0
- package/esm/layout-reducer/resize-flex-children.js +58 -0
- package/esm/layout-reducer/resize-flex-children.js.map +1 -0
- package/esm/layout-reducer/wrap-layout-element.js +210 -0
- package/esm/layout-reducer/wrap-layout-element.js.map +1 -0
- package/esm/layout-view/View.css.js +4 -0
- package/esm/layout-view/View.css.js.map +1 -0
- package/esm/layout-view/View.js +162 -0
- package/esm/layout-view/View.js.map +1 -0
- package/esm/layout-view/useView.js +90 -0
- package/esm/layout-view/useView.js.map +1 -0
- package/esm/layout-view/useViewResize.js +40 -0
- package/esm/layout-view/useViewResize.js.map +1 -0
- package/esm/layout-view-actions/ViewContext.js +12 -0
- package/esm/layout-view-actions/ViewContext.js.map +1 -0
- package/esm/layout-view-actions/useViewActionDispatcher.js +101 -0
- package/esm/layout-view-actions/useViewActionDispatcher.js.map +1 -0
- package/esm/palette/Palette.css.js +4 -0
- package/esm/palette/Palette.css.js.map +1 -0
- package/esm/palette/Palette.js +124 -0
- package/esm/palette/Palette.js.map +1 -0
- package/esm/placeholder/LayoutStartPanel.css.js +4 -0
- package/esm/placeholder/LayoutStartPanel.css.js.map +1 -0
- package/esm/placeholder/LayoutStartPanel.js +58 -0
- package/esm/placeholder/LayoutStartPanel.js.map +1 -0
- package/esm/placeholder/Placeholder.css.js +4 -0
- package/esm/placeholder/Placeholder.css.js.map +1 -0
- package/esm/placeholder/Placeholder.js +32 -0
- package/esm/placeholder/Placeholder.js.map +1 -0
- package/esm/registry/ComponentRegistry.js +21 -0
- package/esm/registry/ComponentRegistry.js.map +1 -0
- package/esm/responsive/breakpoints.js +33 -0
- package/esm/responsive/breakpoints.js.map +1 -0
- package/esm/responsive/use-breakpoints.js +74 -0
- package/esm/responsive/use-breakpoints.js.map +1 -0
- package/esm/responsive/useResizeObserver.js +112 -0
- package/esm/responsive/useResizeObserver.js.map +1 -0
- package/esm/responsive/utils.js +31 -0
- package/esm/responsive/utils.js.map +1 -0
- package/esm/stack/Stack.css.js +4 -0
- package/esm/stack/Stack.css.js.map +1 -0
- package/esm/stack/Stack.js +146 -0
- package/esm/stack/Stack.js.map +1 -0
- package/esm/stack/StackLayout.js +120 -0
- package/esm/stack/StackLayout.js.map +1 -0
- package/esm/use-persistent-state.js +104 -0
- package/esm/use-persistent-state.js.map +1 -0
- package/esm/utils/pathUtils.js +280 -0
- package/esm/utils/pathUtils.js.map +1 -0
- package/esm/utils/propUtils.js +23 -0
- package/esm/utils/propUtils.js.map +1 -0
- package/esm/utils/refUtils.js +10 -0
- package/esm/utils/refUtils.js.map +1 -0
- package/esm/utils/styleUtils.js +13 -0
- package/esm/utils/styleUtils.js.map +1 -0
- package/esm/utils/typeOf.js +23 -0
- package/esm/utils/typeOf.js.map +1 -0
- package/package.json +43 -0
- package/types/Component.d.ts +7 -0
- package/types/DraggableLayout.d.ts +6 -0
- package/types/debug.d.ts +2 -0
- package/types/dock-layout/DockLayout.d.ts +9 -0
- package/types/dock-layout/Drawer.d.ts +17 -0
- package/types/dock-layout/index.d.ts +2 -0
- package/types/drag-drop/BoxModel.d.ts +143 -0
- package/types/drag-drop/DragState.d.ts +46 -0
- package/types/drag-drop/Draggable.d.ts +24 -0
- package/types/drag-drop/DropMenu.d.ts +9 -0
- package/types/drag-drop/DropTarget.d.ts +61 -0
- package/types/drag-drop/DropTargetRenderer.d.ts +17 -0
- package/types/drag-drop/dragDropTypes.d.ts +51 -0
- package/types/drag-drop/index.d.ts +4 -0
- package/types/flexbox/Flexbox.d.ts +4 -0
- package/types/flexbox/FlexboxLayout.d.ts +6 -0
- package/types/flexbox/FluidGrid.d.ts +6 -0
- package/types/flexbox/FluidGridLayout.d.ts +6 -0
- package/types/flexbox/Splitter.d.ts +12 -0
- package/types/flexbox/flexbox-utils.d.ts +12 -0
- package/types/flexbox/flexboxTypes.d.ts +51 -0
- package/types/flexbox/index.d.ts +4 -0
- package/types/flexbox/useResponsiveSizing.d.ts +10 -0
- package/types/flexbox/useSplitterResizing.d.ts +2 -0
- package/types/index.d.ts +18 -0
- package/types/layout-action.d.ts +22 -0
- package/types/layout-header/ActionButton.d.ts +8 -0
- package/types/layout-header/Header.d.ts +12 -0
- package/types/layout-header/index.d.ts +1 -0
- package/types/layout-provider/LayoutProvider.d.ts +15 -0
- package/types/layout-provider/LayoutProviderContext.d.ts +9 -0
- package/types/layout-provider/index.d.ts +2 -0
- package/types/layout-provider/useLayoutDragDrop.d.ts +4 -0
- package/types/layout-reducer/flexUtils.d.ts +22 -0
- package/types/layout-reducer/index.d.ts +4 -0
- package/types/layout-reducer/insert-layout-element.d.ts +8 -0
- package/types/layout-reducer/layout-reducer.d.ts +3 -0
- package/types/layout-reducer/layoutTypes.d.ts +193 -0
- package/types/layout-reducer/layoutUtils.d.ts +38 -0
- package/types/layout-reducer/move-layout-element.d.ts +3 -0
- package/types/layout-reducer/remove-layout-element.d.ts +3 -0
- package/types/layout-reducer/replace-layout-element.d.ts +6 -0
- package/types/layout-reducer/resize-flex-children.d.ts +4 -0
- package/types/layout-reducer/wrap-layout-element.d.ts +9 -0
- package/types/layout-view/View.d.ts +10 -0
- package/types/layout-view/index.d.ts +2 -0
- package/types/layout-view/useView.d.ts +21 -0
- package/types/layout-view/useViewResize.d.ts +7 -0
- package/types/layout-view/viewTypes.d.ts +21 -0
- package/types/layout-view-actions/ViewContext.d.ts +33 -0
- package/types/layout-view-actions/index.d.ts +2 -0
- package/types/layout-view-actions/useViewActionDispatcher.d.ts +9 -0
- package/types/palette/Palette.d.ts +21 -0
- package/types/palette/index.d.ts +1 -0
- package/types/placeholder/LayoutStartPanel.d.ts +5 -0
- package/types/placeholder/Placeholder.d.ts +17 -0
- package/types/placeholder/index.d.ts +1 -0
- package/types/registry/ComponentRegistry.d.ts +13 -0
- package/types/registry/index.d.ts +1 -0
- package/types/responsive/breakpoints.d.ts +4 -0
- package/types/responsive/index.d.ts +3 -0
- package/types/responsive/measureMinimumNodeSize.d.ts +1 -0
- package/types/responsive/overflowUtils.d.ts +2 -0
- package/types/responsive/use-breakpoints.d.ts +7 -0
- package/types/responsive/useResizeObserver.d.ts +13 -0
- package/types/responsive/utils.d.ts +6 -0
- package/types/stack/Stack.d.ts +3 -0
- package/types/stack/StackLayout.d.ts +6 -0
- package/types/stack/index.d.ts +3 -0
- package/types/stack/stackTypes.d.ts +22 -0
- package/types/tabs/TabPanel.d.ts +7 -0
- package/types/tabs/index.d.ts +1 -0
- package/types/tools/config-wrapper/ConfigWrapper.d.ts +2 -0
- package/types/tools/config-wrapper/index.d.ts +1 -0
- package/types/tools/devtools-box/layout-configurator.d.ts +31 -0
- package/types/tools/devtools-tree/layout-tree-viewer.d.ts +5 -0
- package/types/tools/index.d.ts +3 -0
- package/types/use-persistent-state.d.ts +11 -0
- package/types/utils/index.d.ts +5 -0
- package/types/utils/pathUtils.d.ts +31 -0
- package/types/utils/propUtils.d.ts +5 -0
- package/types/utils/refUtils.d.ts +2 -0
- package/types/utils/styleUtils.d.ts +3 -0
- package/types/utils/typeOf.d.ts +5 -0
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
import { getUniqueId } from '@vuu-ui/vuu-utils';
|
|
2
|
+
import React, { useRef, useState, useMemo, useCallback } from 'react';
|
|
3
|
+
import { Placeholder } from '../placeholder/Placeholder.js';
|
|
4
|
+
import { Splitter } from './Splitter.js';
|
|
5
|
+
import { identifyResizeParties, gatherChildMeta, findSplitterAndPlaceholderPositions, PLACEHOLDER, SPLITTER } from './flexbox-utils.js';
|
|
6
|
+
|
|
7
|
+
const originalContentOnly = (meta) => !meta.splitter && !meta.placeholder;
|
|
8
|
+
const useSplitterResizing = ({
|
|
9
|
+
children: childrenProp,
|
|
10
|
+
onSplitterMoved,
|
|
11
|
+
style
|
|
12
|
+
}) => {
|
|
13
|
+
const rootRef = useRef(null);
|
|
14
|
+
const metaRef = useRef();
|
|
15
|
+
const contentRef = useRef();
|
|
16
|
+
const assignedKeys = useRef([]);
|
|
17
|
+
const [, forceUpdate] = useState({});
|
|
18
|
+
const setContent = (content) => {
|
|
19
|
+
contentRef.current = content;
|
|
20
|
+
forceUpdate({});
|
|
21
|
+
};
|
|
22
|
+
const isColumn = style?.flexDirection === "column";
|
|
23
|
+
const dimension = isColumn ? "height" : "width";
|
|
24
|
+
const children = useMemo(
|
|
25
|
+
() => Array.isArray(childrenProp) ? childrenProp : React.isValidElement(childrenProp) ? [childrenProp] : [],
|
|
26
|
+
[childrenProp]
|
|
27
|
+
);
|
|
28
|
+
const handleDragStart = useCallback(
|
|
29
|
+
(index) => {
|
|
30
|
+
const { current: contentMeta } = metaRef;
|
|
31
|
+
if (contentMeta) {
|
|
32
|
+
const [participants, bystanders] = identifyResizeParties(
|
|
33
|
+
contentMeta,
|
|
34
|
+
index
|
|
35
|
+
);
|
|
36
|
+
if (participants) {
|
|
37
|
+
participants.forEach((index2) => {
|
|
38
|
+
const el = rootRef.current?.childNodes[index2];
|
|
39
|
+
if (el) {
|
|
40
|
+
const { size, minSize } = measureElement(el, dimension);
|
|
41
|
+
contentMeta[index2].currentSize = size;
|
|
42
|
+
contentMeta[index2].minSize = minSize;
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
if (bystanders) {
|
|
46
|
+
bystanders.forEach((index2) => {
|
|
47
|
+
const el = rootRef.current?.childNodes[index2];
|
|
48
|
+
if (el) {
|
|
49
|
+
const { [dimension]: size } = el.getBoundingClientRect();
|
|
50
|
+
contentMeta[index2].flexBasis = size;
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
[dimension]
|
|
58
|
+
);
|
|
59
|
+
const handleDrag = useCallback(
|
|
60
|
+
(idx, distance) => {
|
|
61
|
+
if (contentRef.current && metaRef.current) {
|
|
62
|
+
setContent(
|
|
63
|
+
resizeContent(
|
|
64
|
+
contentRef.current,
|
|
65
|
+
metaRef.current,
|
|
66
|
+
distance,
|
|
67
|
+
dimension
|
|
68
|
+
)
|
|
69
|
+
);
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
[dimension]
|
|
73
|
+
);
|
|
74
|
+
const handleDragEnd = useCallback(() => {
|
|
75
|
+
const contentMeta = metaRef.current;
|
|
76
|
+
if (contentMeta) {
|
|
77
|
+
onSplitterMoved?.(contentMeta.filter(originalContentOnly));
|
|
78
|
+
}
|
|
79
|
+
contentMeta?.forEach((meta) => {
|
|
80
|
+
meta.currentSize = void 0;
|
|
81
|
+
meta.flexBasis = void 0;
|
|
82
|
+
meta.flexOpen = false;
|
|
83
|
+
});
|
|
84
|
+
}, [onSplitterMoved]);
|
|
85
|
+
const createSplitter = useCallback(
|
|
86
|
+
(i) => {
|
|
87
|
+
return React.createElement(Splitter, {
|
|
88
|
+
column: isColumn,
|
|
89
|
+
index: i,
|
|
90
|
+
key: `splitter-${i}`,
|
|
91
|
+
onDrag: handleDrag,
|
|
92
|
+
onDragEnd: handleDragEnd,
|
|
93
|
+
onDragStart: handleDragStart
|
|
94
|
+
});
|
|
95
|
+
},
|
|
96
|
+
[handleDrag, handleDragEnd, handleDragStart, isColumn]
|
|
97
|
+
);
|
|
98
|
+
useMemo(() => {
|
|
99
|
+
const [content, meta] = buildContent(
|
|
100
|
+
children,
|
|
101
|
+
dimension,
|
|
102
|
+
createSplitter,
|
|
103
|
+
assignedKeys.current
|
|
104
|
+
);
|
|
105
|
+
metaRef.current = meta;
|
|
106
|
+
contentRef.current = content;
|
|
107
|
+
}, [children, createSplitter, dimension]);
|
|
108
|
+
return {
|
|
109
|
+
content: contentRef.current || [],
|
|
110
|
+
rootRef
|
|
111
|
+
};
|
|
112
|
+
};
|
|
113
|
+
function buildContent(children, dimension, createSplitter, keys) {
|
|
114
|
+
const childMeta = gatherChildMeta(children, dimension);
|
|
115
|
+
const splitterAndPlaceholderPositions = findSplitterAndPlaceholderPositions(childMeta);
|
|
116
|
+
const content = [];
|
|
117
|
+
const meta = [];
|
|
118
|
+
for (let i = 0; i < children.length; i++) {
|
|
119
|
+
const child = children[i];
|
|
120
|
+
if (i === 0 && splitterAndPlaceholderPositions[i] & PLACEHOLDER) {
|
|
121
|
+
content.push(createPlaceholder(i));
|
|
122
|
+
meta.push({ placeholder: true, shim: true });
|
|
123
|
+
}
|
|
124
|
+
if (child.key == null) {
|
|
125
|
+
const key = keys[i] || (keys[i] = getUniqueId());
|
|
126
|
+
content.push(React.cloneElement(child, { key }));
|
|
127
|
+
} else {
|
|
128
|
+
content.push(child);
|
|
129
|
+
}
|
|
130
|
+
meta.push(childMeta[i]);
|
|
131
|
+
if (i > 0 && splitterAndPlaceholderPositions[i] & PLACEHOLDER) {
|
|
132
|
+
content.push(createPlaceholder(i));
|
|
133
|
+
meta.push({ placeholder: true });
|
|
134
|
+
} else if (splitterAndPlaceholderPositions[i] & SPLITTER) {
|
|
135
|
+
content.push(createSplitter(content.length));
|
|
136
|
+
meta.push({ splitter: true });
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
return [content, meta];
|
|
140
|
+
}
|
|
141
|
+
function resizeContent(content, contentMeta, distance, dimension) {
|
|
142
|
+
const metaUpdated = updateMeta(contentMeta, distance);
|
|
143
|
+
if (!metaUpdated) {
|
|
144
|
+
return content;
|
|
145
|
+
}
|
|
146
|
+
return content.map((child, idx) => {
|
|
147
|
+
const meta = contentMeta[idx];
|
|
148
|
+
const { currentSize, flexOpen, flexBasis } = meta;
|
|
149
|
+
const hasCurrentSize = currentSize !== void 0;
|
|
150
|
+
if (hasCurrentSize || flexOpen) {
|
|
151
|
+
const { flexBasis: actualFlexBasis } = child.props.style || {};
|
|
152
|
+
const size = hasCurrentSize ? meta.currentSize : flexBasis;
|
|
153
|
+
if (size !== actualFlexBasis) {
|
|
154
|
+
return React.cloneElement(child, {
|
|
155
|
+
style: {
|
|
156
|
+
...child.props.style,
|
|
157
|
+
flexBasis: size,
|
|
158
|
+
[dimension]: "auto"
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
} else {
|
|
162
|
+
return child;
|
|
163
|
+
}
|
|
164
|
+
} else {
|
|
165
|
+
return child;
|
|
166
|
+
}
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
function updateMeta(contentMeta, distance) {
|
|
170
|
+
const resizeTargets = [];
|
|
171
|
+
contentMeta.forEach((meta, idx) => {
|
|
172
|
+
if (meta.currentSize !== void 0) {
|
|
173
|
+
resizeTargets.push(idx);
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
const target1 = distance < 0 ? resizeTargets[0] : resizeTargets[1];
|
|
177
|
+
const { currentSize = 0, minSize = 0 } = contentMeta[target1];
|
|
178
|
+
if (currentSize === minSize) {
|
|
179
|
+
return false;
|
|
180
|
+
} else if (Math.abs(distance) > currentSize - minSize) {
|
|
181
|
+
const multiplier = distance < 0 ? -1 : 1;
|
|
182
|
+
distance = Math.max(0, currentSize - minSize) * multiplier;
|
|
183
|
+
}
|
|
184
|
+
const leadingItem = contentMeta[resizeTargets[0]];
|
|
185
|
+
const { currentSize: leadingSize = 0 } = leadingItem;
|
|
186
|
+
leadingItem.currentSize = leadingSize + distance;
|
|
187
|
+
const trailingItem = contentMeta[resizeTargets[1]];
|
|
188
|
+
const { currentSize: trailingSize = 0 } = trailingItem;
|
|
189
|
+
trailingItem.currentSize = trailingSize - distance;
|
|
190
|
+
return true;
|
|
191
|
+
}
|
|
192
|
+
function createPlaceholder(index) {
|
|
193
|
+
return React.createElement(Placeholder, {
|
|
194
|
+
shim: index === 0,
|
|
195
|
+
key: `placeholder-${index}`
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
function measureElement(el, dimension) {
|
|
199
|
+
const { [dimension]: size } = el.getBoundingClientRect();
|
|
200
|
+
const style = getComputedStyle(el);
|
|
201
|
+
const minSizeVal = style.getPropertyValue(`min-${dimension}`);
|
|
202
|
+
const minSize = minSizeVal.endsWith("px") ? parseInt(minSizeVal, 10) : 0;
|
|
203
|
+
return { size, minSize };
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
export { useSplitterResizing };
|
|
207
|
+
//# sourceMappingURL=useSplitterResizing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useSplitterResizing.js","sources":["../../src/flexbox/useSplitterResizing.ts"],"sourcesContent":["import { getUniqueId } from \"@vuu-ui/vuu-utils\";\nimport React, {\n ReactElement,\n useCallback,\n useMemo,\n useRef,\n useState,\n} 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 metaRef = useRef<ContentMeta[]>();\n const contentRef = useRef<ReactElement[]>();\n const assignedKeys = useRef([]);\n const [, forceUpdate] = useState({});\n\n const setContent = (content: ReactElement[]) => {\n contentRef.current = content;\n forceUpdate({});\n };\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) => {\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 }\n },\n [dimension]\n );\n\n const handleDrag = useCallback(\n (idx, distance) => {\n if (contentRef.current && metaRef.current) {\n setContent(\n resizeContent(\n contentRef.current,\n metaRef.current,\n distance,\n dimension\n )\n );\n }\n },\n [dimension]\n );\n\n const handleDragEnd = useCallback(() => {\n const contentMeta = metaRef.current;\n if (contentMeta) {\n onSplitterMoved?.(contentMeta.filter(originalContentOnly));\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: any[]\n): [any[], 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 resizeContent(\n content: ReactElement[],\n contentMeta: ContentMeta[],\n distance: number,\n dimension: \"width\" | \"height\"\n) {\n const metaUpdated = updateMeta(contentMeta, distance);\n if (!metaUpdated) {\n return content;\n }\n\n return content.map((child, idx) => {\n const meta = contentMeta[idx];\n const { currentSize, flexOpen, flexBasis } = meta;\n const hasCurrentSize = currentSize !== undefined;\n if (hasCurrentSize || flexOpen) {\n const { flexBasis: actualFlexBasis } = child.props.style || {};\n const size = hasCurrentSize ? meta.currentSize : flexBasis;\n if (size !== actualFlexBasis) {\n return React.cloneElement(child, {\n style: {\n ...child.props.style,\n flexBasis: size,\n [dimension]: \"auto\",\n },\n });\n } else {\n return child;\n }\n } else {\n return child;\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 } as any);\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":["index"],"mappings":"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"}
|
package/esm/index.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export { default as DockLayout } from './dock-layout/DockLayout.js';
|
|
2
|
+
export { default as Drawer } from './dock-layout/Drawer.js';
|
|
3
|
+
export { default as Component } from './Component.js';
|
|
4
|
+
export { Draggable } from './drag-drop/Draggable.js';
|
|
5
|
+
export { DropMenu, computeMenuPosition } from './drag-drop/DropMenu.js';
|
|
6
|
+
export { DropTarget, identifyDropTarget, isTabstrip } from './drag-drop/DropTarget.js';
|
|
7
|
+
export { DraggableLayout } from './DraggableLayout.js';
|
|
8
|
+
export { default as Flexbox } from './flexbox/Flexbox.js';
|
|
9
|
+
export { FlexboxLayout } from './flexbox/FlexboxLayout.js';
|
|
10
|
+
export { FluidGrid } from './flexbox/FluidGrid.js';
|
|
11
|
+
export { FluidGridLayout } from './flexbox/FluidGridLayout.js';
|
|
12
|
+
export { Action } from './layout-action.js';
|
|
13
|
+
export { Header } from './layout-header/Header.js';
|
|
14
|
+
export { LayoutProvider, LayoutProviderVersion, useLayoutCreateNewChild, useLayoutProviderDispatch, useLayoutProviderVersion } from './layout-provider/LayoutProvider.js';
|
|
15
|
+
export { LayoutProviderContext } from './layout-provider/LayoutProviderContext.js';
|
|
16
|
+
export { createFlexbox, createPlaceHolder, getFlexDimensions, getFlexOrIntrinsicStyle, getFlexStyle, getIntrinsicSize, hasUnboundedFlexStyle, wrapIntrinsicSizeComponentWithFlexbox } from './layout-reducer/flexUtils.js';
|
|
17
|
+
export { layoutReducer } from './layout-reducer/layout-reducer.js';
|
|
18
|
+
export { LayoutActionType, isApplicationLevelChange, isLayoutLevelChange } from './layout-reducer/layoutTypes.js';
|
|
19
|
+
export { applyLayout, applyLayoutProps, componentToJson, getDefaultTabLabel, getManagedDimension, layoutFromJson, layoutQuery, layoutToJSON, processLayoutElement, serializeProps } from './layout-reducer/layoutUtils.js';
|
|
20
|
+
export { View } from './layout-view/View.js';
|
|
21
|
+
export { useViewActionDispatcher } from './layout-view-actions/useViewActionDispatcher.js';
|
|
22
|
+
export { ViewContext, useViewContext, useViewDispatch } from './layout-view-actions/ViewContext.js';
|
|
23
|
+
export { Palette, PaletteItem } from './palette/Palette.js';
|
|
24
|
+
export { Placeholder } from './placeholder/Placeholder.js';
|
|
25
|
+
export { ComponentRegistry, isContainer, isLayoutComponent, isView, registerComponent } from './registry/ComponentRegistry.js';
|
|
26
|
+
export { useBreakpoints } from './responsive/use-breakpoints.js';
|
|
27
|
+
export { HeightOnly, WidthHeight, WidthOnly, resizeObserver, useResizeObserver } from './responsive/useResizeObserver.js';
|
|
28
|
+
export { extractResponsiveProps, isResponsiveAttribute } from './responsive/utils.js';
|
|
29
|
+
export { Stack } from './stack/Stack.js';
|
|
30
|
+
export { StackLayout } from './stack/StackLayout.js';
|
|
31
|
+
export { getPersistentState, hasPersistentState, setPersistentState, usePersistentState } from './use-persistent-state.js';
|
|
32
|
+
export { containerOf, findTarget, followPath, followPathToComponent, followPathToParent, getChild, nextLeaf, nextStep, previousLeaf, resetPath, resolveJSONPath, resolvePath } from './utils/pathUtils.js';
|
|
33
|
+
export { getChildProp, getProp, getProps } from './utils/propUtils.js';
|
|
34
|
+
export { setRef } from './utils/refUtils.js';
|
|
35
|
+
export { expandFlex } from './utils/styleUtils.js';
|
|
36
|
+
export { isLayoutJSON, isTypeOf, typeOf } from './utils/typeOf.js';
|
|
37
|
+
//# sourceMappingURL=index.js.map
|
package/esm/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
const Action = {
|
|
2
|
+
ADD: "add",
|
|
3
|
+
BLUR: "blur",
|
|
4
|
+
BLUR_SPLITTER: "blur-splitter",
|
|
5
|
+
DRAG_START: "drag-start",
|
|
6
|
+
DRAG_STARTED: "drag-started",
|
|
7
|
+
DRAG_DROP: "drag-drop",
|
|
8
|
+
FOCUS: "focus",
|
|
9
|
+
FOCUS_SPLITTER: "focus-splitter",
|
|
10
|
+
INITIALIZE: "initialize",
|
|
11
|
+
LAYOUT_RESIZE: "layout-resize",
|
|
12
|
+
MAXIMIZE: "maximize",
|
|
13
|
+
MINIMIZE: "minimize",
|
|
14
|
+
REMOVE: "remove",
|
|
15
|
+
REPLACE: "replace",
|
|
16
|
+
RESTORE: "restore",
|
|
17
|
+
SAVE: "save",
|
|
18
|
+
SET_TITLE: "set-title",
|
|
19
|
+
SPLITTER_RESIZE: "splitter-resize",
|
|
20
|
+
SWITCH_TAB: "switch-tab",
|
|
21
|
+
TEAR_OUT: "tear-out"
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export { Action };
|
|
25
|
+
//# sourceMappingURL=layout-action.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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 SET_TITLE: \"set-title\",\n SPLITTER_RESIZE: \"splitter-resize\",\n SWITCH_TAB: \"switch-tab\",\n TEAR_OUT: \"tear-out\",\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,SAAW,EAAA,WAAA;AAAA,EACX,eAAiB,EAAA,iBAAA;AAAA,EACjB,UAAY,EAAA,YAAA;AAAA,EACZ,QAAU,EAAA,UAAA;AACZ;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Header.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { EditableLabel, IconButton } from '@vuu-ui/vuu-ui-controls';
|
|
3
|
+
import cx from 'clsx';
|
|
4
|
+
import { useComponentCssInjection } from '@salt-ds/styles';
|
|
5
|
+
import { useWindow } from '@salt-ds/window';
|
|
6
|
+
import { useRef, useState, cloneElement } from 'react';
|
|
7
|
+
import '@vuu-ui/vuu-utils';
|
|
8
|
+
import '../layout-provider/LayoutProviderContext.js';
|
|
9
|
+
import '../drag-drop/Draggable.js';
|
|
10
|
+
import '../drag-drop/BoxModel.js';
|
|
11
|
+
import { useViewDispatch } from '../layout-view-actions/ViewContext.js';
|
|
12
|
+
import headerCss from './Header.css.js';
|
|
13
|
+
|
|
14
|
+
const classBase = "vuuHeader";
|
|
15
|
+
const Header = ({
|
|
16
|
+
className: classNameProp,
|
|
17
|
+
contributions,
|
|
18
|
+
collapsed,
|
|
19
|
+
closeable,
|
|
20
|
+
onEditTitle,
|
|
21
|
+
orientation: orientationProp = "horizontal",
|
|
22
|
+
style,
|
|
23
|
+
title = "Untitled"
|
|
24
|
+
}) => {
|
|
25
|
+
const targetWindow = useWindow();
|
|
26
|
+
useComponentCssInjection({
|
|
27
|
+
testId: "vuu-header",
|
|
28
|
+
css: headerCss,
|
|
29
|
+
window: targetWindow
|
|
30
|
+
});
|
|
31
|
+
const labelFieldRef = useRef(null);
|
|
32
|
+
const [value, setValue] = useState(title);
|
|
33
|
+
const [editing, setEditing] = useState(false);
|
|
34
|
+
const viewDispatch = useViewDispatch();
|
|
35
|
+
const handleClose = (evt) => viewDispatch?.({ type: "remove" }, evt);
|
|
36
|
+
const handleTitleMouseDown = () => {
|
|
37
|
+
labelFieldRef.current?.focus();
|
|
38
|
+
};
|
|
39
|
+
const handleButtonMouseDown = (evt) => {
|
|
40
|
+
evt.stopPropagation();
|
|
41
|
+
};
|
|
42
|
+
const orientation = collapsed || orientationProp;
|
|
43
|
+
const className = cx(classBase, classNameProp, `${classBase}-${orientation}`);
|
|
44
|
+
const handleEnterEditMode = () => {
|
|
45
|
+
setEditing(true);
|
|
46
|
+
};
|
|
47
|
+
const handleTitleKeyDown = (evt) => {
|
|
48
|
+
if (evt.key === "Enter") {
|
|
49
|
+
setEditing(true);
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
const handleExitEditMode = (originalValue = "", finalValue = "", allowDeactivation = true, editCancelled = false) => {
|
|
53
|
+
setEditing(false);
|
|
54
|
+
if (editCancelled) {
|
|
55
|
+
setValue(originalValue);
|
|
56
|
+
} else if (finalValue !== originalValue) {
|
|
57
|
+
setValue(finalValue);
|
|
58
|
+
onEditTitle?.(finalValue);
|
|
59
|
+
}
|
|
60
|
+
if (allowDeactivation === false) {
|
|
61
|
+
labelFieldRef.current?.focus();
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
const handleMouseDown = (e) => {
|
|
65
|
+
viewDispatch?.({ type: "mousedown" }, e);
|
|
66
|
+
};
|
|
67
|
+
const toolbarItems = [];
|
|
68
|
+
const postTitleContributedItems = [];
|
|
69
|
+
const actionButtons = [];
|
|
70
|
+
contributions?.forEach((contribution, i) => {
|
|
71
|
+
switch (contribution.location) {
|
|
72
|
+
case "pre-title":
|
|
73
|
+
toolbarItems.push(cloneElement(contribution.content, { key: i }));
|
|
74
|
+
break;
|
|
75
|
+
default:
|
|
76
|
+
postTitleContributedItems.push(
|
|
77
|
+
cloneElement(contribution.content, { key: i })
|
|
78
|
+
);
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
title && toolbarItems.push(
|
|
82
|
+
/* @__PURE__ */ jsx(
|
|
83
|
+
EditableLabel,
|
|
84
|
+
{
|
|
85
|
+
className: `${classBase}-title`,
|
|
86
|
+
editing,
|
|
87
|
+
value,
|
|
88
|
+
onChange: setValue,
|
|
89
|
+
onMouseDownCapture: handleTitleMouseDown,
|
|
90
|
+
onEnterEditMode: handleEnterEditMode,
|
|
91
|
+
onExitEditMode: handleExitEditMode,
|
|
92
|
+
onKeyDown: handleTitleKeyDown,
|
|
93
|
+
ref: labelFieldRef,
|
|
94
|
+
tabIndex: 0
|
|
95
|
+
},
|
|
96
|
+
"title"
|
|
97
|
+
)
|
|
98
|
+
);
|
|
99
|
+
closeable && actionButtons.push(
|
|
100
|
+
/* @__PURE__ */ jsx(
|
|
101
|
+
IconButton,
|
|
102
|
+
{
|
|
103
|
+
icon: "close",
|
|
104
|
+
onClick: handleClose,
|
|
105
|
+
onMouseDown: handleButtonMouseDown,
|
|
106
|
+
variant: "secondary"
|
|
107
|
+
},
|
|
108
|
+
"close"
|
|
109
|
+
)
|
|
110
|
+
);
|
|
111
|
+
postTitleContributedItems.length > 0 && toolbarItems.push(
|
|
112
|
+
/* @__PURE__ */ jsx("div", { className: "vuuTooltrayProxy", "data-align": "end", children: postTitleContributedItems }, "contributions")
|
|
113
|
+
);
|
|
114
|
+
actionButtons.length > 0 && toolbarItems.push(
|
|
115
|
+
/* @__PURE__ */ jsx("div", { className: "vuuTooltrayProxy", "data-align": "end", children: actionButtons }, "actions")
|
|
116
|
+
);
|
|
117
|
+
return /* @__PURE__ */ jsx(
|
|
118
|
+
"div",
|
|
119
|
+
{
|
|
120
|
+
className: cx("vuuToolbarProxy", className),
|
|
121
|
+
style,
|
|
122
|
+
onMouseDown: handleMouseDown,
|
|
123
|
+
children: toolbarItems
|
|
124
|
+
}
|
|
125
|
+
);
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
export { Header };
|
|
129
|
+
//# sourceMappingURL=Header.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Header.js","sources":["../../src/layout-header/Header.tsx"],"sourcesContent":["import { EditableLabel, IconButton } from \"@vuu-ui/vuu-ui-controls\";\nimport cx from \"clsx\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport {\n cloneElement,\n HTMLAttributes,\n KeyboardEvent,\n MouseEvent,\n ReactElement,\n useRef,\n useState,\n} from \"react\";\nimport { Contribution, useViewDispatch } from \"../layout-view-actions\";\n\nimport headerCss from \"./Header.css\";\n\nexport interface HeaderProps extends HTMLAttributes<HTMLDivElement> {\n collapsed?: boolean;\n contributions?: Contribution[];\n expanded?: boolean;\n closeable?: boolean;\n onEditTitle: (value: string) => void;\n orientation?: \"horizontal\" | \"vertical\";\n tearOut?: boolean;\n}\n\nconst classBase = \"vuuHeader\";\n\nexport const Header = ({\n className: classNameProp,\n contributions,\n collapsed,\n closeable,\n onEditTitle,\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 labelFieldRef = useRef<HTMLDivElement>(null);\n const [value, setValue] = useState<string>(title);\n const [editing, setEditing] = useState<boolean>(false);\n\n const viewDispatch = useViewDispatch();\n const handleClose = (evt: MouseEvent) =>\n viewDispatch?.({ type: \"remove\" }, evt);\n\n const handleTitleMouseDown = () => {\n labelFieldRef.current?.focus();\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 handleEnterEditMode = () => {\n setEditing(true);\n };\n\n const handleTitleKeyDown = (evt: KeyboardEvent<HTMLDivElement>) => {\n if (evt.key === \"Enter\") {\n setEditing(true);\n }\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 handleMouseDown = (e: MouseEvent) => {\n viewDispatch?.({ type: \"mousedown\" }, e);\n };\n\n const toolbarItems: ReactElement[] = [];\n const postTitleContributedItems: ReactElement[] = [];\n const actionButtons: ReactElement[] = [];\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 title &&\n toolbarItems.push(\n <EditableLabel\n className={`${classBase}-title`}\n editing={editing}\n key=\"title\"\n value={value}\n onChange={setValue}\n onMouseDownCapture={handleTitleMouseDown}\n onEnterEditMode={handleEnterEditMode}\n onExitEditMode={handleExitEditMode}\n onKeyDown={handleTitleKeyDown}\n ref={labelFieldRef}\n tabIndex={0}\n />\n );\n\n closeable &&\n actionButtons.push(\n <IconButton\n icon=\"close\"\n key=\"close\"\n onClick={handleClose}\n onMouseDown={handleButtonMouseDown}\n variant=\"secondary\"\n />\n );\n\n postTitleContributedItems.length > 0 &&\n toolbarItems.push(\n <div className=\"vuuTooltrayProxy\" data-align=\"end\" key=\"contributions\">\n {postTitleContributedItems}\n </div>\n );\n\n actionButtons.length > 0 &&\n toolbarItems.push(\n <div className=\"vuuTooltrayProxy\" 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={handleMouseDown}\n >\n {toolbarItems}\n {/* \n {collapsed === false ? (\n <ActionButton\n aria-label=\"Minimize View\"\n actionId=\"minimize\"\n iconName=\"minimize\"\n onClick={handleAction}\n onMouseDown={handleButtonMouseDown}\n />\n ) : null}\n {collapsed ? (\n <ActionButton\n aria-label=\"Restore View\"\n actionId=\"restore\"\n iconName=\"double-chevron-right\"\n onClick={handleAction}\n onMouseDown={handleButtonMouseDown}\n />\n ) : null}\n {expanded === false ? (\n <ActionButton\n aria-label=\"Maximize View\"\n actionId=\"maximize\"\n iconName=\"maximize\"\n onClick={handleAction}\n onMouseDown={handleButtonMouseDown}\n />\n ) : null}\n {expanded ? (\n <ActionButton\n aria-label=\"Restore View\"\n actionId=\"restore\"\n iconName=\"restore\"\n onClick={handleAction}\n onMouseDown={handleButtonMouseDown}\n />\n ) : null}\n {tearOut ? (\n <ActionButton\n aria-label=\"Tear out View\"\n actionId=\"tearout\"\n iconName=\"tear-out\"\n onClick={handleAction}\n onMouseDown={handleButtonMouseDown}\n />\n ) : null}\n {closeable ? (\n <Button\n aria-label=\"close\"\n data-icon\n onClick={handleClose}\n onMouseDown={handleButtonMouseDown}\n />\n ) : null} */}\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useRef, useState, useCallback, useEffect, useContext } from 'react';
|
|
3
|
+
import '@vuu-ui/vuu-utils';
|
|
4
|
+
import { findTarget } from '../utils/pathUtils.js';
|
|
5
|
+
import { getProps, getChildProp, getProp } from '../utils/propUtils.js';
|
|
6
|
+
import { typeOf } from '../utils/typeOf.js';
|
|
7
|
+
import { layoutReducer } from '../layout-reducer/layout-reducer.js';
|
|
8
|
+
import { LayoutActionType } from '../layout-reducer/layoutTypes.js';
|
|
9
|
+
import { layoutToJSON, layoutQuery, layoutFromJson, processLayoutElement } from '../layout-reducer/layoutUtils.js';
|
|
10
|
+
import { LayoutProviderContext } from './LayoutProviderContext.js';
|
|
11
|
+
import { useLayoutDragDrop } from './useLayoutDragDrop.js';
|
|
12
|
+
|
|
13
|
+
const withDropTarget = (props) => props.dropTarget;
|
|
14
|
+
const shouldSave = (action) => [
|
|
15
|
+
"drag-drop",
|
|
16
|
+
"remove",
|
|
17
|
+
"set-title",
|
|
18
|
+
"splitter-resize",
|
|
19
|
+
"switch-tab"
|
|
20
|
+
].includes(action.type);
|
|
21
|
+
const getLayoutChangeReason = (action) => {
|
|
22
|
+
switch (action.type) {
|
|
23
|
+
case "switch-tab":
|
|
24
|
+
if (action.id === "main-tabs") {
|
|
25
|
+
return "switch-active-layout";
|
|
26
|
+
} else {
|
|
27
|
+
return "switch-active-tab";
|
|
28
|
+
}
|
|
29
|
+
case "save":
|
|
30
|
+
return "save-feature-props";
|
|
31
|
+
case "drag-drop":
|
|
32
|
+
return "drag-drop-operation";
|
|
33
|
+
case "remove":
|
|
34
|
+
return "remove-component";
|
|
35
|
+
case "splitter-resize":
|
|
36
|
+
return "resize-component";
|
|
37
|
+
case "set-title":
|
|
38
|
+
return "edit-feature-title";
|
|
39
|
+
default:
|
|
40
|
+
throw Error("unknown layout action");
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
const LayoutProviderVersion = () => {
|
|
44
|
+
const version = useLayoutProviderVersion();
|
|
45
|
+
return /* @__PURE__ */ jsx("div", { children: `Context: ${version} ` });
|
|
46
|
+
};
|
|
47
|
+
const LayoutProvider = (props) => {
|
|
48
|
+
const { children, createNewChild, pathToDropTarget, layout, onLayoutChange } = props;
|
|
49
|
+
const state = useRef(void 0);
|
|
50
|
+
const childrenRef = useRef(children);
|
|
51
|
+
const [, forceRefresh] = useState(null);
|
|
52
|
+
const serializeState = useCallback(
|
|
53
|
+
(source, layoutChangeReason) => {
|
|
54
|
+
if (onLayoutChange) {
|
|
55
|
+
const targetContainer = findTarget(source, withDropTarget) || state.current;
|
|
56
|
+
const isDraggableLayout = typeOf(targetContainer) === "DraggableLayout";
|
|
57
|
+
const target = isDraggableLayout ? getProps(targetContainer).children[0] : targetContainer;
|
|
58
|
+
const serializedModel = layoutToJSON(target);
|
|
59
|
+
onLayoutChange(serializedModel, layoutChangeReason);
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
[onLayoutChange]
|
|
63
|
+
);
|
|
64
|
+
const dispatchLayoutAction = useCallback(
|
|
65
|
+
(action, suppressSave = false) => {
|
|
66
|
+
const nextState = layoutReducer(state.current, action);
|
|
67
|
+
if (nextState !== state.current) {
|
|
68
|
+
state.current = nextState;
|
|
69
|
+
forceRefresh({});
|
|
70
|
+
if (!suppressSave && shouldSave(action)) {
|
|
71
|
+
serializeState(nextState, getLayoutChangeReason(action));
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
[forceRefresh, serializeState]
|
|
76
|
+
);
|
|
77
|
+
const layoutActionDispatcher = useCallback(
|
|
78
|
+
(action) => {
|
|
79
|
+
switch (action.type) {
|
|
80
|
+
case "drag-start": {
|
|
81
|
+
prepareToDragLayout(action);
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
case "save": {
|
|
85
|
+
serializeState(state.current, getLayoutChangeReason(action));
|
|
86
|
+
break;
|
|
87
|
+
}
|
|
88
|
+
case "query":
|
|
89
|
+
if (action.query === "PARENT_CONTAINER") {
|
|
90
|
+
return layoutQuery(action.query, action.path, state.current);
|
|
91
|
+
}
|
|
92
|
+
break;
|
|
93
|
+
default: {
|
|
94
|
+
dispatchLayoutAction(action);
|
|
95
|
+
break;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
},
|
|
99
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
100
|
+
[dispatchLayoutAction, serializeState]
|
|
101
|
+
);
|
|
102
|
+
const prepareToDragLayout = useLayoutDragDrop(
|
|
103
|
+
state,
|
|
104
|
+
layoutActionDispatcher,
|
|
105
|
+
pathToDropTarget
|
|
106
|
+
);
|
|
107
|
+
useEffect(() => {
|
|
108
|
+
if (layout) {
|
|
109
|
+
const targetContainer = findTarget(
|
|
110
|
+
state.current,
|
|
111
|
+
withDropTarget
|
|
112
|
+
);
|
|
113
|
+
if (targetContainer) {
|
|
114
|
+
const target = getChildProp(targetContainer);
|
|
115
|
+
const newLayout = layoutFromJson(
|
|
116
|
+
layout,
|
|
117
|
+
`${targetContainer.props.path}.0`
|
|
118
|
+
);
|
|
119
|
+
const action = target ? {
|
|
120
|
+
type: LayoutActionType.REPLACE,
|
|
121
|
+
target,
|
|
122
|
+
replacement: newLayout
|
|
123
|
+
} : {
|
|
124
|
+
type: LayoutActionType.ADD,
|
|
125
|
+
path: targetContainer.props.path,
|
|
126
|
+
component: newLayout
|
|
127
|
+
};
|
|
128
|
+
dispatchLayoutAction(action, true);
|
|
129
|
+
} else if (layout.id === getProp(state.current, "id")) {
|
|
130
|
+
const newLayout = layoutFromJson(layout, "0");
|
|
131
|
+
const action = {
|
|
132
|
+
type: LayoutActionType.REPLACE,
|
|
133
|
+
target: state.current,
|
|
134
|
+
replacement: newLayout
|
|
135
|
+
};
|
|
136
|
+
dispatchLayoutAction(action, true);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}, [dispatchLayoutAction, layout]);
|
|
140
|
+
if (state.current === void 0) {
|
|
141
|
+
state.current = processLayoutElement(children);
|
|
142
|
+
} else if (children !== childrenRef.current) {
|
|
143
|
+
state.current = processLayoutElement(children, state.current);
|
|
144
|
+
childrenRef.current = children;
|
|
145
|
+
}
|
|
146
|
+
return /* @__PURE__ */ jsx(
|
|
147
|
+
LayoutProviderContext.Provider,
|
|
148
|
+
{
|
|
149
|
+
value: {
|
|
150
|
+
createNewChild,
|
|
151
|
+
dispatchLayoutProvider: layoutActionDispatcher,
|
|
152
|
+
version: 0
|
|
153
|
+
},
|
|
154
|
+
children: state.current
|
|
155
|
+
}
|
|
156
|
+
);
|
|
157
|
+
};
|
|
158
|
+
const useLayoutProviderDispatch = () => {
|
|
159
|
+
const { dispatchLayoutProvider } = useContext(LayoutProviderContext);
|
|
160
|
+
return dispatchLayoutProvider;
|
|
161
|
+
};
|
|
162
|
+
const useLayoutCreateNewChild = () => {
|
|
163
|
+
const { createNewChild } = useContext(LayoutProviderContext);
|
|
164
|
+
return createNewChild;
|
|
165
|
+
};
|
|
166
|
+
const useLayoutProviderVersion = () => {
|
|
167
|
+
const { version } = useContext(LayoutProviderContext);
|
|
168
|
+
return version;
|
|
169
|
+
};
|
|
170
|
+
|
|
171
|
+
export { LayoutProvider, LayoutProviderVersion, useLayoutCreateNewChild, useLayoutProviderDispatch, useLayoutProviderVersion };
|
|
172
|
+
//# sourceMappingURL=LayoutProvider.js.map
|