react-magma-dom 4.11.0-next.19 → 4.11.0-next.21

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.
@@ -18489,12 +18489,12 @@
18489
18489
  "typeArguments": [
18490
18490
  {
18491
18491
  "type": "reference",
18492
- "id": 36391,
18492
+ "id": 36392,
18493
18493
  "name": "ToggleButtonTextProps"
18494
18494
  },
18495
18495
  {
18496
18496
  "type": "reference",
18497
- "id": 36675,
18497
+ "id": 36676,
18498
18498
  "name": "ToggleButtonIconProps"
18499
18499
  }
18500
18500
  ],
@@ -19392,6 +19392,15 @@
19392
19392
  "description": "Expand icon styles.",
19393
19393
  "deprecated": false
19394
19394
  },
19395
+ "height": {
19396
+ "name": "height",
19397
+ "required": false,
19398
+ "type": {
19399
+ "name": "number"
19400
+ },
19401
+ "description": "Height of the TreeView container in pixels.\nREQUIRED when enableVirtualization is true.\nWithout a fixed height, virtualization cannot calculate the viewport properly.",
19402
+ "deprecated": false
19403
+ },
19395
19404
  "initialExpandedItems": {
19396
19405
  "name": "initialExpandedItems",
19397
19406
  "required": false,
@@ -19430,7 +19430,7 @@ function useTreeView(props) {
19430
19430
  };
19431
19431
  }
19432
19432
 
19433
- var _excluded$1M = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId", "apiRef", "enableVirtualization"];
19433
+ var _excluded$1M = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId", "apiRef", "enableVirtualization", "height"];
19434
19434
  var StyledTreeView = /*#__PURE__*/_styled("ul", {
19435
19435
  target: "e1tyeayj2",
19436
19436
  label: "StyledTreeView"
@@ -19438,13 +19438,13 @@ var StyledTreeView = /*#__PURE__*/_styled("ul", {
19438
19438
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral;
19439
19439
  }, ";position:", function (props) {
19440
19440
  return props.isVirtualized ? 'relative' : 'static';
19441
- }, ";ul{padding:0;margin:0;li{margin:0;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeView.tsx"],"names":[],"mappings":"AAaiC","file":"TreeView.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { useVirtual } from 'react-virtual';\r\nimport { TreeItem } from './TreeItem';\r\nimport { TreeItemHierarchyContext } from './TreeItemHierarchyContext';\r\nimport { TreeViewConfigContext } from './TreeViewConfigContext';\r\nimport { TreeViewExpansionContext } from './TreeViewExpansionContext';\r\nimport { TreeViewSelectionContext } from './TreeViewSelectionContext';\r\nimport { TreeViewSelectable } from './types';\r\nimport { useTreeItem } from './useTreeItem';\r\nimport { useTreeView } from './useTreeView';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nconst StyledTreeView = styled.ul `\n  padding: 0;\n  margin: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral};\n  position: ${props => (props.isVirtualized ? 'relative' : 'static')};\n  ul {\n    padding: 0;\n    margin: 0;\n    li {\n      margin: 0;\n    }\n  }\n`;\r\nconst VirtualContainer = styled.div `\n  width: 100%;\n  position: relative;\n  height: ${props => props.height}px;\n`;\r\nconst VirtualItem = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-height: ${props => props.height}px;\n  transform: ${props => `translateY(${props.transform}px)`};\n\n  /* Ensure dropdowns and other floating elements appear above items */\n  &:focus-within {\n    z-index: 1;\n  }\n  &[data-testid='popoverContent'] {\n    z-index: 1;\n  }\n`;\r\nexport const TreeView = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, ariaLabelledBy, children, isInverse: isInverseProp, onExpandedChange, onSelectedItemChange, selectable, testId, apiRef, enableVirtualization = false, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const { selectionContextValue, expansionContextValue, configContextValue } = useTreeView(props);\r\n    useTreeItem({ label: ariaLabel, itemId: '' }, ref);\r\n    const inverseContextValue = React.useMemo(() => ({ isInverse }), [isInverse]);\r\n    const parentRef = React.useRef(null);\r\n    const itemHeightsByIdRef = React.useRef(new Map());\r\n    const measurementRefs = React.useRef(new Map());\r\n    // Flatten tree structure for virtualization\r\n    const flattenedItems = React.useMemo(() => {\r\n        if (!enableVirtualization)\r\n            return [];\r\n        const items = [];\r\n        const flatten = (childrenToFlatten, depth = 0) => {\r\n            React.Children.forEach(childrenToFlatten, (child, index) => {\r\n                if (!React.isValidElement(child) || child.type !== TreeItem) {\r\n                    return;\r\n                }\r\n                const itemId = child.props.itemId;\r\n                const itemKey = `${itemId}-${depth}`;\r\n                // Clone the child without its children to prevent double rendering\r\n                const childWithoutNested = React.cloneElement(child, {\r\n                    ...child.props,\r\n                    children: null,\r\n                });\r\n                items.push({\r\n                    child: childWithoutNested,\r\n                    depth,\r\n                    index,\r\n                    key: itemKey,\r\n                    itemId,\r\n                });\r\n                // Check if item has children and is expanded\r\n                const isExpanded = expansionContextValue.expandedSet?.has(itemId);\r\n                if (isExpanded && child.props.children) {\r\n                    flatten(child.props.children, depth + 1);\r\n                }\r\n            });\r\n        };\r\n        flatten(children);\r\n        return items;\r\n    }, [children, enableVirtualization, expansionContextValue.expandedSet]);\r\n    const rowVirtualizer = useVirtual({\r\n        size: flattenedItems.length,\r\n        parentRef,\r\n        estimateSize: React.useCallback((index) => {\r\n            const itemId = flattenedItems[index]?.itemId;\r\n            if (!itemId) {\r\n                return 32;\r\n            }\r\n            return itemHeightsByIdRef.current.get(itemId) ?? 32;\r\n        }, [flattenedItems]),\r\n        overscan: 6,\r\n    });\r\n    // Measure item heights after render\r\n    React.useEffect(() => {\r\n        if (!enableVirtualization) {\r\n            measurementRefs.current.clear();\r\n            itemHeightsByIdRef.current.clear();\r\n            return;\r\n        }\r\n        const measureHeights = () => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        };\r\n        const timeoutId = setTimeout(() => {\r\n            measureHeights();\r\n        }, 0);\r\n        if (typeof window !== 'undefined' && 'ResizeObserver' in window) {\r\n            const resizeObserver = new window.ResizeObserver(() => {\r\n                measureHeights();\r\n            });\r\n            measurementRefs.current.forEach(element => {\r\n                if (element) {\r\n                    resizeObserver.observe(element);\r\n                }\r\n            });\r\n            return () => {\r\n                clearTimeout(timeoutId);\r\n                resizeObserver.disconnect();\r\n            };\r\n        }\r\n        return () => {\r\n            clearTimeout(timeoutId);\r\n        };\r\n    }, [enableVirtualization, flattenedItems, rowVirtualizer]);\r\n    const processedChildren = React.useMemo(() => {\r\n        let treeItemIndex = 0;\r\n        return React.Children.map(children, child => {\r\n            if (!React.isValidElement(child)) {\r\n                return null;\r\n            }\r\n            if (child.type === TreeItem) {\r\n                const currentIndex = treeItemIndex++;\r\n                const hierarchyValue = {\r\n                    depth: 0,\r\n                    parentDepth: 0,\r\n                    isTopLevel: true,\r\n                    index: currentIndex,\r\n                };\r\n                // Wrap in context provider instead of cloning\r\n                return (React.createElement(TreeItemHierarchyContext.Provider, { key: `tree-item-${currentIndex}`, value: hierarchyValue }, child));\r\n            }\r\n            return null;\r\n        });\r\n    }, [children]);\r\n    React.useEffect(() => {\r\n        // Force measurement on children change\r\n        const timeoutId = setTimeout(() => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        }, 100); // Small delay to ensure DOM is updated\r\n        return () => clearTimeout(timeoutId);\r\n    }, [children, rowVirtualizer]);\r\n    return (React.createElement(InverseContext.Provider, { value: inverseContextValue },\r\n        React.createElement(TreeViewSelectionContext.Provider, { value: selectionContextValue },\r\n            React.createElement(TreeViewExpansionContext.Provider, { value: expansionContextValue },\r\n                React.createElement(TreeViewConfigContext.Provider, { value: configContextValue },\r\n                    React.createElement(StyledTreeView, Object.assign({}, rest, { \"aria-label\": ariaLabel, \"aria-labelledby\": ariaLabelledBy, \"aria-multiselectable\": selectable === TreeViewSelectable.multi, \"data-testid\": testId, isInverse: isInverse, isVirtualized: enableVirtualization, ref: mergedRefs => {\r\n                            if (typeof ref === 'function') {\r\n                                ref(mergedRefs);\r\n                            }\r\n                            else if (ref) {\r\n                                ref.current =\r\n                                    mergedRefs;\r\n                            }\r\n                            parentRef.current = mergedRefs;\r\n                        }, role: \"tree\", theme: theme }), enableVirtualization ? (React.createElement(VirtualContainer, { height: rowVirtualizer.totalSize }, rowVirtualizer.virtualItems.map(virtualItem => {\r\n                        const item = flattenedItems[virtualItem.index];\r\n                        const hierarchyValue = {\r\n                            depth: item.depth,\r\n                            parentDepth: Math.max(0, item.depth - 1),\r\n                            isTopLevel: item.depth === 0,\r\n                            index: item.index,\r\n                            isVirtualized: true,\r\n                        };\r\n                        return (React.createElement(VirtualItem, { key: item.key, height: virtualItem.size, transform: virtualItem.start, ref: (el) => {\r\n                                if (el) {\r\n                                    measurementRefs.current.set(item.itemId, el);\r\n                                }\r\n                                else {\r\n                                    measurementRefs.current.delete(item.itemId);\r\n                                }\r\n                            } },\r\n                            React.createElement(TreeItemHierarchyContext.Provider, { value: hierarchyValue }, item.child)));\r\n                    }))) : (processedChildren)))))));\r\n});\r\n//# sourceMappingURL=TreeView.js.map"]} */"));
19441
+ }, ";ul{padding:0;margin:0;li{margin:0;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeView.tsx"],"names":[],"mappings":"AAaiC","file":"TreeView.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { useVirtual } from 'react-virtual';\r\nimport { TreeItem } from './TreeItem';\r\nimport { TreeItemHierarchyContext } from './TreeItemHierarchyContext';\r\nimport { TreeViewConfigContext } from './TreeViewConfigContext';\r\nimport { TreeViewExpansionContext } from './TreeViewExpansionContext';\r\nimport { TreeViewSelectionContext } from './TreeViewSelectionContext';\r\nimport { TreeViewSelectable } from './types';\r\nimport { useTreeItem } from './useTreeItem';\r\nimport { useTreeView } from './useTreeView';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nconst StyledTreeView = styled.ul `\n  padding: 0;\n  margin: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral};\n  position: ${props => (props.isVirtualized ? 'relative' : 'static')};\n  ul {\n    padding: 0;\n    margin: 0;\n    li {\n      margin: 0;\n    }\n  }\n`;\r\nconst VirtualContainer = styled.div `\n  width: 100%;\n  position: relative;\n  height: ${props => props.height}px;\n`;\r\nconst VirtualItem = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-height: ${props => props.height}px;\n  transform: ${props => `translateY(${props.transform}px)`};\n\n  /* Ensure dropdowns and other floating elements appear above items */\n  &:focus-within {\n    z-index: 1;\n  }\n  &[data-testid='popoverContent'] {\n    z-index: 1;\n  }\n`;\r\nexport const TreeView = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, ariaLabelledBy, children, isInverse: isInverseProp, onExpandedChange, onSelectedItemChange, selectable, testId, apiRef, enableVirtualization = false, height, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const { selectionContextValue, expansionContextValue, configContextValue } = useTreeView(props);\r\n    useTreeItem({ label: ariaLabel, itemId: '' }, ref);\r\n    const inverseContextValue = React.useMemo(() => ({ isInverse }), [isInverse]);\r\n    const parentRef = React.useRef(null);\r\n    const itemHeightsByIdRef = React.useRef(new Map());\r\n    const measurementRefs = React.useRef(new Map());\r\n    // Flatten tree structure for virtualization\r\n    const flattenedItems = React.useMemo(() => {\r\n        if (!enableVirtualization)\r\n            return [];\r\n        const items = [];\r\n        const flatten = (childrenToFlatten, depth = 0) => {\r\n            React.Children.forEach(childrenToFlatten, (child, index) => {\r\n                if (!React.isValidElement(child) || child.type !== TreeItem) {\r\n                    return;\r\n                }\r\n                const itemId = child.props.itemId;\r\n                const itemKey = `${itemId}-${depth}`;\r\n                // Clone the child without its children to prevent double rendering\r\n                const childWithoutNested = React.cloneElement(child, {\r\n                    ...child.props,\r\n                    children: null,\r\n                });\r\n                items.push({\r\n                    child: childWithoutNested,\r\n                    depth,\r\n                    index,\r\n                    key: itemKey,\r\n                    itemId,\r\n                });\r\n                // Check if item has children and is expanded\r\n                const isExpanded = expansionContextValue.expandedSet?.has(itemId);\r\n                if (isExpanded && child.props.children) {\r\n                    flatten(child.props.children, depth + 1);\r\n                }\r\n            });\r\n        };\r\n        flatten(children);\r\n        return items;\r\n    }, [children, enableVirtualization, expansionContextValue.expandedSet]);\r\n    const rowVirtualizer = useVirtual({\r\n        size: flattenedItems.length,\r\n        parentRef,\r\n        estimateSize: React.useCallback((index) => {\r\n            const itemId = flattenedItems[index]?.itemId;\r\n            if (!itemId) {\r\n                return 32;\r\n            }\r\n            return itemHeightsByIdRef.current.get(itemId) ?? 32;\r\n        }, [flattenedItems]),\r\n        overscan: 3,\r\n    });\r\n    // Measure item heights after render\r\n    React.useEffect(() => {\r\n        if (!enableVirtualization) {\r\n            measurementRefs.current.clear();\r\n            itemHeightsByIdRef.current.clear();\r\n            return;\r\n        }\r\n        const measureHeights = () => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        };\r\n        const timeoutId = setTimeout(() => {\r\n            measureHeights();\r\n        }, 0);\r\n        if (typeof window !== 'undefined' && 'ResizeObserver' in window) {\r\n            const resizeObserver = new window.ResizeObserver(() => {\r\n                measureHeights();\r\n            });\r\n            measurementRefs.current.forEach(element => {\r\n                if (element) {\r\n                    resizeObserver.observe(element);\r\n                }\r\n            });\r\n            return () => {\r\n                clearTimeout(timeoutId);\r\n                resizeObserver.disconnect();\r\n            };\r\n        }\r\n        return () => {\r\n            clearTimeout(timeoutId);\r\n        };\r\n    }, [enableVirtualization, flattenedItems, rowVirtualizer]);\r\n    const processedChildren = React.useMemo(() => {\r\n        let treeItemIndex = 0;\r\n        return React.Children.map(children, child => {\r\n            if (!React.isValidElement(child)) {\r\n                return null;\r\n            }\r\n            if (child.type === TreeItem) {\r\n                const currentIndex = treeItemIndex++;\r\n                const hierarchyValue = {\r\n                    depth: 0,\r\n                    parentDepth: 0,\r\n                    isTopLevel: true,\r\n                    index: currentIndex,\r\n                };\r\n                // Wrap in context provider instead of cloning\r\n                return (React.createElement(TreeItemHierarchyContext.Provider, { key: `tree-item-${currentIndex}`, value: hierarchyValue }, child));\r\n            }\r\n            return null;\r\n        });\r\n    }, [children]);\r\n    React.useEffect(() => {\r\n        // Force measurement on children change\r\n        const timeoutId = setTimeout(() => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        }, 100); // Small delay to ensure DOM is updated\r\n        return () => clearTimeout(timeoutId);\r\n    }, [children, rowVirtualizer]);\r\n    return (React.createElement(InverseContext.Provider, { value: inverseContextValue },\r\n        React.createElement(TreeViewSelectionContext.Provider, { value: selectionContextValue },\r\n            React.createElement(TreeViewExpansionContext.Provider, { value: expansionContextValue },\r\n                React.createElement(TreeViewConfigContext.Provider, { value: configContextValue },\r\n                    React.createElement(StyledTreeView, Object.assign({}, rest, { \"aria-label\": ariaLabel, \"aria-labelledby\": ariaLabelledBy, \"aria-multiselectable\": selectable === TreeViewSelectable.multi, \"data-testid\": testId, isInverse: isInverse, isVirtualized: enableVirtualization, ref: mergedRefs => {\r\n                            if (typeof ref === 'function') {\r\n                                ref(mergedRefs);\r\n                            }\r\n                            else if (ref) {\r\n                                ref.current =\r\n                                    mergedRefs;\r\n                            }\r\n                            parentRef.current = mergedRefs;\r\n                        }, role: \"tree\", theme: theme, style: {\r\n                            ...rest.style,\r\n                            ...(enableVirtualization && height\r\n                                ? { height: `${height}px`, overflow: 'auto' }\r\n                                : {}),\r\n                        } }), enableVirtualization ? (React.createElement(VirtualContainer, { height: rowVirtualizer.totalSize }, rowVirtualizer.virtualItems.map(virtualItem => {\r\n                        const item = flattenedItems[virtualItem.index];\r\n                        const hierarchyValue = {\r\n                            depth: item.depth,\r\n                            parentDepth: Math.max(0, item.depth - 1),\r\n                            isTopLevel: item.depth === 0,\r\n                            index: item.index,\r\n                            isVirtualized: true,\r\n                        };\r\n                        return (React.createElement(VirtualItem, { key: item.key, height: virtualItem.size, transform: virtualItem.start, ref: (el) => {\r\n                                if (el) {\r\n                                    measurementRefs.current.set(item.itemId, el);\r\n                                }\r\n                                else {\r\n                                    measurementRefs.current.delete(item.itemId);\r\n                                }\r\n                            } },\r\n                            React.createElement(TreeItemHierarchyContext.Provider, { value: hierarchyValue }, item.child)));\r\n                    }))) : (processedChildren)))))));\r\n});\r\n//# sourceMappingURL=TreeView.js.map"]} */"));
19442
19442
  var VirtualContainer = /*#__PURE__*/_styled("div", {
19443
19443
  target: "e1tyeayj1",
19444
19444
  label: "VirtualContainer"
19445
19445
  })("width:100%;position:relative;height:", function (props) {
19446
19446
  return props.height;
19447
- }, "px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeView.tsx"],"names":[],"mappings":"AA4BoC","file":"TreeView.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { useVirtual } from 'react-virtual';\r\nimport { TreeItem } from './TreeItem';\r\nimport { TreeItemHierarchyContext } from './TreeItemHierarchyContext';\r\nimport { TreeViewConfigContext } from './TreeViewConfigContext';\r\nimport { TreeViewExpansionContext } from './TreeViewExpansionContext';\r\nimport { TreeViewSelectionContext } from './TreeViewSelectionContext';\r\nimport { TreeViewSelectable } from './types';\r\nimport { useTreeItem } from './useTreeItem';\r\nimport { useTreeView } from './useTreeView';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nconst StyledTreeView = styled.ul `\n  padding: 0;\n  margin: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral};\n  position: ${props => (props.isVirtualized ? 'relative' : 'static')};\n  ul {\n    padding: 0;\n    margin: 0;\n    li {\n      margin: 0;\n    }\n  }\n`;\r\nconst VirtualContainer = styled.div `\n  width: 100%;\n  position: relative;\n  height: ${props => props.height}px;\n`;\r\nconst VirtualItem = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-height: ${props => props.height}px;\n  transform: ${props => `translateY(${props.transform}px)`};\n\n  /* Ensure dropdowns and other floating elements appear above items */\n  &:focus-within {\n    z-index: 1;\n  }\n  &[data-testid='popoverContent'] {\n    z-index: 1;\n  }\n`;\r\nexport const TreeView = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, ariaLabelledBy, children, isInverse: isInverseProp, onExpandedChange, onSelectedItemChange, selectable, testId, apiRef, enableVirtualization = false, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const { selectionContextValue, expansionContextValue, configContextValue } = useTreeView(props);\r\n    useTreeItem({ label: ariaLabel, itemId: '' }, ref);\r\n    const inverseContextValue = React.useMemo(() => ({ isInverse }), [isInverse]);\r\n    const parentRef = React.useRef(null);\r\n    const itemHeightsByIdRef = React.useRef(new Map());\r\n    const measurementRefs = React.useRef(new Map());\r\n    // Flatten tree structure for virtualization\r\n    const flattenedItems = React.useMemo(() => {\r\n        if (!enableVirtualization)\r\n            return [];\r\n        const items = [];\r\n        const flatten = (childrenToFlatten, depth = 0) => {\r\n            React.Children.forEach(childrenToFlatten, (child, index) => {\r\n                if (!React.isValidElement(child) || child.type !== TreeItem) {\r\n                    return;\r\n                }\r\n                const itemId = child.props.itemId;\r\n                const itemKey = `${itemId}-${depth}`;\r\n                // Clone the child without its children to prevent double rendering\r\n                const childWithoutNested = React.cloneElement(child, {\r\n                    ...child.props,\r\n                    children: null,\r\n                });\r\n                items.push({\r\n                    child: childWithoutNested,\r\n                    depth,\r\n                    index,\r\n                    key: itemKey,\r\n                    itemId,\r\n                });\r\n                // Check if item has children and is expanded\r\n                const isExpanded = expansionContextValue.expandedSet?.has(itemId);\r\n                if (isExpanded && child.props.children) {\r\n                    flatten(child.props.children, depth + 1);\r\n                }\r\n            });\r\n        };\r\n        flatten(children);\r\n        return items;\r\n    }, [children, enableVirtualization, expansionContextValue.expandedSet]);\r\n    const rowVirtualizer = useVirtual({\r\n        size: flattenedItems.length,\r\n        parentRef,\r\n        estimateSize: React.useCallback((index) => {\r\n            const itemId = flattenedItems[index]?.itemId;\r\n            if (!itemId) {\r\n                return 32;\r\n            }\r\n            return itemHeightsByIdRef.current.get(itemId) ?? 32;\r\n        }, [flattenedItems]),\r\n        overscan: 6,\r\n    });\r\n    // Measure item heights after render\r\n    React.useEffect(() => {\r\n        if (!enableVirtualization) {\r\n            measurementRefs.current.clear();\r\n            itemHeightsByIdRef.current.clear();\r\n            return;\r\n        }\r\n        const measureHeights = () => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        };\r\n        const timeoutId = setTimeout(() => {\r\n            measureHeights();\r\n        }, 0);\r\n        if (typeof window !== 'undefined' && 'ResizeObserver' in window) {\r\n            const resizeObserver = new window.ResizeObserver(() => {\r\n                measureHeights();\r\n            });\r\n            measurementRefs.current.forEach(element => {\r\n                if (element) {\r\n                    resizeObserver.observe(element);\r\n                }\r\n            });\r\n            return () => {\r\n                clearTimeout(timeoutId);\r\n                resizeObserver.disconnect();\r\n            };\r\n        }\r\n        return () => {\r\n            clearTimeout(timeoutId);\r\n        };\r\n    }, [enableVirtualization, flattenedItems, rowVirtualizer]);\r\n    const processedChildren = React.useMemo(() => {\r\n        let treeItemIndex = 0;\r\n        return React.Children.map(children, child => {\r\n            if (!React.isValidElement(child)) {\r\n                return null;\r\n            }\r\n            if (child.type === TreeItem) {\r\n                const currentIndex = treeItemIndex++;\r\n                const hierarchyValue = {\r\n                    depth: 0,\r\n                    parentDepth: 0,\r\n                    isTopLevel: true,\r\n                    index: currentIndex,\r\n                };\r\n                // Wrap in context provider instead of cloning\r\n                return (React.createElement(TreeItemHierarchyContext.Provider, { key: `tree-item-${currentIndex}`, value: hierarchyValue }, child));\r\n            }\r\n            return null;\r\n        });\r\n    }, [children]);\r\n    React.useEffect(() => {\r\n        // Force measurement on children change\r\n        const timeoutId = setTimeout(() => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        }, 100); // Small delay to ensure DOM is updated\r\n        return () => clearTimeout(timeoutId);\r\n    }, [children, rowVirtualizer]);\r\n    return (React.createElement(InverseContext.Provider, { value: inverseContextValue },\r\n        React.createElement(TreeViewSelectionContext.Provider, { value: selectionContextValue },\r\n            React.createElement(TreeViewExpansionContext.Provider, { value: expansionContextValue },\r\n                React.createElement(TreeViewConfigContext.Provider, { value: configContextValue },\r\n                    React.createElement(StyledTreeView, Object.assign({}, rest, { \"aria-label\": ariaLabel, \"aria-labelledby\": ariaLabelledBy, \"aria-multiselectable\": selectable === TreeViewSelectable.multi, \"data-testid\": testId, isInverse: isInverse, isVirtualized: enableVirtualization, ref: mergedRefs => {\r\n                            if (typeof ref === 'function') {\r\n                                ref(mergedRefs);\r\n                            }\r\n                            else if (ref) {\r\n                                ref.current =\r\n                                    mergedRefs;\r\n                            }\r\n                            parentRef.current = mergedRefs;\r\n                        }, role: \"tree\", theme: theme }), enableVirtualization ? (React.createElement(VirtualContainer, { height: rowVirtualizer.totalSize }, rowVirtualizer.virtualItems.map(virtualItem => {\r\n                        const item = flattenedItems[virtualItem.index];\r\n                        const hierarchyValue = {\r\n                            depth: item.depth,\r\n                            parentDepth: Math.max(0, item.depth - 1),\r\n                            isTopLevel: item.depth === 0,\r\n                            index: item.index,\r\n                            isVirtualized: true,\r\n                        };\r\n                        return (React.createElement(VirtualItem, { key: item.key, height: virtualItem.size, transform: virtualItem.start, ref: (el) => {\r\n                                if (el) {\r\n                                    measurementRefs.current.set(item.itemId, el);\r\n                                }\r\n                                else {\r\n                                    measurementRefs.current.delete(item.itemId);\r\n                                }\r\n                            } },\r\n                            React.createElement(TreeItemHierarchyContext.Provider, { value: hierarchyValue }, item.child)));\r\n                    }))) : (processedChildren)))))));\r\n});\r\n//# sourceMappingURL=TreeView.js.map"]} */"));
19447
+ }, "px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeView.tsx"],"names":[],"mappings":"AA4BoC","file":"TreeView.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { useVirtual } from 'react-virtual';\r\nimport { TreeItem } from './TreeItem';\r\nimport { TreeItemHierarchyContext } from './TreeItemHierarchyContext';\r\nimport { TreeViewConfigContext } from './TreeViewConfigContext';\r\nimport { TreeViewExpansionContext } from './TreeViewExpansionContext';\r\nimport { TreeViewSelectionContext } from './TreeViewSelectionContext';\r\nimport { TreeViewSelectable } from './types';\r\nimport { useTreeItem } from './useTreeItem';\r\nimport { useTreeView } from './useTreeView';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nconst StyledTreeView = styled.ul `\n  padding: 0;\n  margin: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral};\n  position: ${props => (props.isVirtualized ? 'relative' : 'static')};\n  ul {\n    padding: 0;\n    margin: 0;\n    li {\n      margin: 0;\n    }\n  }\n`;\r\nconst VirtualContainer = styled.div `\n  width: 100%;\n  position: relative;\n  height: ${props => props.height}px;\n`;\r\nconst VirtualItem = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-height: ${props => props.height}px;\n  transform: ${props => `translateY(${props.transform}px)`};\n\n  /* Ensure dropdowns and other floating elements appear above items */\n  &:focus-within {\n    z-index: 1;\n  }\n  &[data-testid='popoverContent'] {\n    z-index: 1;\n  }\n`;\r\nexport const TreeView = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, ariaLabelledBy, children, isInverse: isInverseProp, onExpandedChange, onSelectedItemChange, selectable, testId, apiRef, enableVirtualization = false, height, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const { selectionContextValue, expansionContextValue, configContextValue } = useTreeView(props);\r\n    useTreeItem({ label: ariaLabel, itemId: '' }, ref);\r\n    const inverseContextValue = React.useMemo(() => ({ isInverse }), [isInverse]);\r\n    const parentRef = React.useRef(null);\r\n    const itemHeightsByIdRef = React.useRef(new Map());\r\n    const measurementRefs = React.useRef(new Map());\r\n    // Flatten tree structure for virtualization\r\n    const flattenedItems = React.useMemo(() => {\r\n        if (!enableVirtualization)\r\n            return [];\r\n        const items = [];\r\n        const flatten = (childrenToFlatten, depth = 0) => {\r\n            React.Children.forEach(childrenToFlatten, (child, index) => {\r\n                if (!React.isValidElement(child) || child.type !== TreeItem) {\r\n                    return;\r\n                }\r\n                const itemId = child.props.itemId;\r\n                const itemKey = `${itemId}-${depth}`;\r\n                // Clone the child without its children to prevent double rendering\r\n                const childWithoutNested = React.cloneElement(child, {\r\n                    ...child.props,\r\n                    children: null,\r\n                });\r\n                items.push({\r\n                    child: childWithoutNested,\r\n                    depth,\r\n                    index,\r\n                    key: itemKey,\r\n                    itemId,\r\n                });\r\n                // Check if item has children and is expanded\r\n                const isExpanded = expansionContextValue.expandedSet?.has(itemId);\r\n                if (isExpanded && child.props.children) {\r\n                    flatten(child.props.children, depth + 1);\r\n                }\r\n            });\r\n        };\r\n        flatten(children);\r\n        return items;\r\n    }, [children, enableVirtualization, expansionContextValue.expandedSet]);\r\n    const rowVirtualizer = useVirtual({\r\n        size: flattenedItems.length,\r\n        parentRef,\r\n        estimateSize: React.useCallback((index) => {\r\n            const itemId = flattenedItems[index]?.itemId;\r\n            if (!itemId) {\r\n                return 32;\r\n            }\r\n            return itemHeightsByIdRef.current.get(itemId) ?? 32;\r\n        }, [flattenedItems]),\r\n        overscan: 3,\r\n    });\r\n    // Measure item heights after render\r\n    React.useEffect(() => {\r\n        if (!enableVirtualization) {\r\n            measurementRefs.current.clear();\r\n            itemHeightsByIdRef.current.clear();\r\n            return;\r\n        }\r\n        const measureHeights = () => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        };\r\n        const timeoutId = setTimeout(() => {\r\n            measureHeights();\r\n        }, 0);\r\n        if (typeof window !== 'undefined' && 'ResizeObserver' in window) {\r\n            const resizeObserver = new window.ResizeObserver(() => {\r\n                measureHeights();\r\n            });\r\n            measurementRefs.current.forEach(element => {\r\n                if (element) {\r\n                    resizeObserver.observe(element);\r\n                }\r\n            });\r\n            return () => {\r\n                clearTimeout(timeoutId);\r\n                resizeObserver.disconnect();\r\n            };\r\n        }\r\n        return () => {\r\n            clearTimeout(timeoutId);\r\n        };\r\n    }, [enableVirtualization, flattenedItems, rowVirtualizer]);\r\n    const processedChildren = React.useMemo(() => {\r\n        let treeItemIndex = 0;\r\n        return React.Children.map(children, child => {\r\n            if (!React.isValidElement(child)) {\r\n                return null;\r\n            }\r\n            if (child.type === TreeItem) {\r\n                const currentIndex = treeItemIndex++;\r\n                const hierarchyValue = {\r\n                    depth: 0,\r\n                    parentDepth: 0,\r\n                    isTopLevel: true,\r\n                    index: currentIndex,\r\n                };\r\n                // Wrap in context provider instead of cloning\r\n                return (React.createElement(TreeItemHierarchyContext.Provider, { key: `tree-item-${currentIndex}`, value: hierarchyValue }, child));\r\n            }\r\n            return null;\r\n        });\r\n    }, [children]);\r\n    React.useEffect(() => {\r\n        // Force measurement on children change\r\n        const timeoutId = setTimeout(() => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        }, 100); // Small delay to ensure DOM is updated\r\n        return () => clearTimeout(timeoutId);\r\n    }, [children, rowVirtualizer]);\r\n    return (React.createElement(InverseContext.Provider, { value: inverseContextValue },\r\n        React.createElement(TreeViewSelectionContext.Provider, { value: selectionContextValue },\r\n            React.createElement(TreeViewExpansionContext.Provider, { value: expansionContextValue },\r\n                React.createElement(TreeViewConfigContext.Provider, { value: configContextValue },\r\n                    React.createElement(StyledTreeView, Object.assign({}, rest, { \"aria-label\": ariaLabel, \"aria-labelledby\": ariaLabelledBy, \"aria-multiselectable\": selectable === TreeViewSelectable.multi, \"data-testid\": testId, isInverse: isInverse, isVirtualized: enableVirtualization, ref: mergedRefs => {\r\n                            if (typeof ref === 'function') {\r\n                                ref(mergedRefs);\r\n                            }\r\n                            else if (ref) {\r\n                                ref.current =\r\n                                    mergedRefs;\r\n                            }\r\n                            parentRef.current = mergedRefs;\r\n                        }, role: \"tree\", theme: theme, style: {\r\n                            ...rest.style,\r\n                            ...(enableVirtualization && height\r\n                                ? { height: `${height}px`, overflow: 'auto' }\r\n                                : {}),\r\n                        } }), enableVirtualization ? (React.createElement(VirtualContainer, { height: rowVirtualizer.totalSize }, rowVirtualizer.virtualItems.map(virtualItem => {\r\n                        const item = flattenedItems[virtualItem.index];\r\n                        const hierarchyValue = {\r\n                            depth: item.depth,\r\n                            parentDepth: Math.max(0, item.depth - 1),\r\n                            isTopLevel: item.depth === 0,\r\n                            index: item.index,\r\n                            isVirtualized: true,\r\n                        };\r\n                        return (React.createElement(VirtualItem, { key: item.key, height: virtualItem.size, transform: virtualItem.start, ref: (el) => {\r\n                                if (el) {\r\n                                    measurementRefs.current.set(item.itemId, el);\r\n                                }\r\n                                else {\r\n                                    measurementRefs.current.delete(item.itemId);\r\n                                }\r\n                            } },\r\n                            React.createElement(TreeItemHierarchyContext.Provider, { value: hierarchyValue }, item.child)));\r\n                    }))) : (processedChildren)))))));\r\n});\r\n//# sourceMappingURL=TreeView.js.map"]} */"));
19448
19448
  var VirtualItem = /*#__PURE__*/_styled("div", {
19449
19449
  target: "e1tyeayj0",
19450
19450
  label: "VirtualItem"
@@ -19452,7 +19452,7 @@ var VirtualItem = /*#__PURE__*/_styled("div", {
19452
19452
  return props.height;
19453
19453
  }, "px;transform:", function (props) {
19454
19454
  return "translateY(" + props.transform + "px)";
19455
- }, ";&:focus-within{z-index:1;}&[data-testid='popoverContent']{z-index:1;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeView.tsx"],"names":[],"mappings":"AAiC+B","file":"TreeView.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { useVirtual } from 'react-virtual';\r\nimport { TreeItem } from './TreeItem';\r\nimport { TreeItemHierarchyContext } from './TreeItemHierarchyContext';\r\nimport { TreeViewConfigContext } from './TreeViewConfigContext';\r\nimport { TreeViewExpansionContext } from './TreeViewExpansionContext';\r\nimport { TreeViewSelectionContext } from './TreeViewSelectionContext';\r\nimport { TreeViewSelectable } from './types';\r\nimport { useTreeItem } from './useTreeItem';\r\nimport { useTreeView } from './useTreeView';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nconst StyledTreeView = styled.ul `\n  padding: 0;\n  margin: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral};\n  position: ${props => (props.isVirtualized ? 'relative' : 'static')};\n  ul {\n    padding: 0;\n    margin: 0;\n    li {\n      margin: 0;\n    }\n  }\n`;\r\nconst VirtualContainer = styled.div `\n  width: 100%;\n  position: relative;\n  height: ${props => props.height}px;\n`;\r\nconst VirtualItem = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-height: ${props => props.height}px;\n  transform: ${props => `translateY(${props.transform}px)`};\n\n  /* Ensure dropdowns and other floating elements appear above items */\n  &:focus-within {\n    z-index: 1;\n  }\n  &[data-testid='popoverContent'] {\n    z-index: 1;\n  }\n`;\r\nexport const TreeView = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, ariaLabelledBy, children, isInverse: isInverseProp, onExpandedChange, onSelectedItemChange, selectable, testId, apiRef, enableVirtualization = false, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const { selectionContextValue, expansionContextValue, configContextValue } = useTreeView(props);\r\n    useTreeItem({ label: ariaLabel, itemId: '' }, ref);\r\n    const inverseContextValue = React.useMemo(() => ({ isInverse }), [isInverse]);\r\n    const parentRef = React.useRef(null);\r\n    const itemHeightsByIdRef = React.useRef(new Map());\r\n    const measurementRefs = React.useRef(new Map());\r\n    // Flatten tree structure for virtualization\r\n    const flattenedItems = React.useMemo(() => {\r\n        if (!enableVirtualization)\r\n            return [];\r\n        const items = [];\r\n        const flatten = (childrenToFlatten, depth = 0) => {\r\n            React.Children.forEach(childrenToFlatten, (child, index) => {\r\n                if (!React.isValidElement(child) || child.type !== TreeItem) {\r\n                    return;\r\n                }\r\n                const itemId = child.props.itemId;\r\n                const itemKey = `${itemId}-${depth}`;\r\n                // Clone the child without its children to prevent double rendering\r\n                const childWithoutNested = React.cloneElement(child, {\r\n                    ...child.props,\r\n                    children: null,\r\n                });\r\n                items.push({\r\n                    child: childWithoutNested,\r\n                    depth,\r\n                    index,\r\n                    key: itemKey,\r\n                    itemId,\r\n                });\r\n                // Check if item has children and is expanded\r\n                const isExpanded = expansionContextValue.expandedSet?.has(itemId);\r\n                if (isExpanded && child.props.children) {\r\n                    flatten(child.props.children, depth + 1);\r\n                }\r\n            });\r\n        };\r\n        flatten(children);\r\n        return items;\r\n    }, [children, enableVirtualization, expansionContextValue.expandedSet]);\r\n    const rowVirtualizer = useVirtual({\r\n        size: flattenedItems.length,\r\n        parentRef,\r\n        estimateSize: React.useCallback((index) => {\r\n            const itemId = flattenedItems[index]?.itemId;\r\n            if (!itemId) {\r\n                return 32;\r\n            }\r\n            return itemHeightsByIdRef.current.get(itemId) ?? 32;\r\n        }, [flattenedItems]),\r\n        overscan: 6,\r\n    });\r\n    // Measure item heights after render\r\n    React.useEffect(() => {\r\n        if (!enableVirtualization) {\r\n            measurementRefs.current.clear();\r\n            itemHeightsByIdRef.current.clear();\r\n            return;\r\n        }\r\n        const measureHeights = () => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        };\r\n        const timeoutId = setTimeout(() => {\r\n            measureHeights();\r\n        }, 0);\r\n        if (typeof window !== 'undefined' && 'ResizeObserver' in window) {\r\n            const resizeObserver = new window.ResizeObserver(() => {\r\n                measureHeights();\r\n            });\r\n            measurementRefs.current.forEach(element => {\r\n                if (element) {\r\n                    resizeObserver.observe(element);\r\n                }\r\n            });\r\n            return () => {\r\n                clearTimeout(timeoutId);\r\n                resizeObserver.disconnect();\r\n            };\r\n        }\r\n        return () => {\r\n            clearTimeout(timeoutId);\r\n        };\r\n    }, [enableVirtualization, flattenedItems, rowVirtualizer]);\r\n    const processedChildren = React.useMemo(() => {\r\n        let treeItemIndex = 0;\r\n        return React.Children.map(children, child => {\r\n            if (!React.isValidElement(child)) {\r\n                return null;\r\n            }\r\n            if (child.type === TreeItem) {\r\n                const currentIndex = treeItemIndex++;\r\n                const hierarchyValue = {\r\n                    depth: 0,\r\n                    parentDepth: 0,\r\n                    isTopLevel: true,\r\n                    index: currentIndex,\r\n                };\r\n                // Wrap in context provider instead of cloning\r\n                return (React.createElement(TreeItemHierarchyContext.Provider, { key: `tree-item-${currentIndex}`, value: hierarchyValue }, child));\r\n            }\r\n            return null;\r\n        });\r\n    }, [children]);\r\n    React.useEffect(() => {\r\n        // Force measurement on children change\r\n        const timeoutId = setTimeout(() => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        }, 100); // Small delay to ensure DOM is updated\r\n        return () => clearTimeout(timeoutId);\r\n    }, [children, rowVirtualizer]);\r\n    return (React.createElement(InverseContext.Provider, { value: inverseContextValue },\r\n        React.createElement(TreeViewSelectionContext.Provider, { value: selectionContextValue },\r\n            React.createElement(TreeViewExpansionContext.Provider, { value: expansionContextValue },\r\n                React.createElement(TreeViewConfigContext.Provider, { value: configContextValue },\r\n                    React.createElement(StyledTreeView, Object.assign({}, rest, { \"aria-label\": ariaLabel, \"aria-labelledby\": ariaLabelledBy, \"aria-multiselectable\": selectable === TreeViewSelectable.multi, \"data-testid\": testId, isInverse: isInverse, isVirtualized: enableVirtualization, ref: mergedRefs => {\r\n                            if (typeof ref === 'function') {\r\n                                ref(mergedRefs);\r\n                            }\r\n                            else if (ref) {\r\n                                ref.current =\r\n                                    mergedRefs;\r\n                            }\r\n                            parentRef.current = mergedRefs;\r\n                        }, role: \"tree\", theme: theme }), enableVirtualization ? (React.createElement(VirtualContainer, { height: rowVirtualizer.totalSize }, rowVirtualizer.virtualItems.map(virtualItem => {\r\n                        const item = flattenedItems[virtualItem.index];\r\n                        const hierarchyValue = {\r\n                            depth: item.depth,\r\n                            parentDepth: Math.max(0, item.depth - 1),\r\n                            isTopLevel: item.depth === 0,\r\n                            index: item.index,\r\n                            isVirtualized: true,\r\n                        };\r\n                        return (React.createElement(VirtualItem, { key: item.key, height: virtualItem.size, transform: virtualItem.start, ref: (el) => {\r\n                                if (el) {\r\n                                    measurementRefs.current.set(item.itemId, el);\r\n                                }\r\n                                else {\r\n                                    measurementRefs.current.delete(item.itemId);\r\n                                }\r\n                            } },\r\n                            React.createElement(TreeItemHierarchyContext.Provider, { value: hierarchyValue }, item.child)));\r\n                    }))) : (processedChildren)))))));\r\n});\r\n//# sourceMappingURL=TreeView.js.map"]} */"));
19455
+ }, ";&:focus-within{z-index:1;}&[data-testid='popoverContent']{z-index:1;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeView.tsx"],"names":[],"mappings":"AAiC+B","file":"TreeView.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { useVirtual } from 'react-virtual';\r\nimport { TreeItem } from './TreeItem';\r\nimport { TreeItemHierarchyContext } from './TreeItemHierarchyContext';\r\nimport { TreeViewConfigContext } from './TreeViewConfigContext';\r\nimport { TreeViewExpansionContext } from './TreeViewExpansionContext';\r\nimport { TreeViewSelectionContext } from './TreeViewSelectionContext';\r\nimport { TreeViewSelectable } from './types';\r\nimport { useTreeItem } from './useTreeItem';\r\nimport { useTreeView } from './useTreeView';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nconst StyledTreeView = styled.ul `\n  padding: 0;\n  margin: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral};\n  position: ${props => (props.isVirtualized ? 'relative' : 'static')};\n  ul {\n    padding: 0;\n    margin: 0;\n    li {\n      margin: 0;\n    }\n  }\n`;\r\nconst VirtualContainer = styled.div `\n  width: 100%;\n  position: relative;\n  height: ${props => props.height}px;\n`;\r\nconst VirtualItem = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-height: ${props => props.height}px;\n  transform: ${props => `translateY(${props.transform}px)`};\n\n  /* Ensure dropdowns and other floating elements appear above items */\n  &:focus-within {\n    z-index: 1;\n  }\n  &[data-testid='popoverContent'] {\n    z-index: 1;\n  }\n`;\r\nexport const TreeView = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, ariaLabelledBy, children, isInverse: isInverseProp, onExpandedChange, onSelectedItemChange, selectable, testId, apiRef, enableVirtualization = false, height, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const { selectionContextValue, expansionContextValue, configContextValue } = useTreeView(props);\r\n    useTreeItem({ label: ariaLabel, itemId: '' }, ref);\r\n    const inverseContextValue = React.useMemo(() => ({ isInverse }), [isInverse]);\r\n    const parentRef = React.useRef(null);\r\n    const itemHeightsByIdRef = React.useRef(new Map());\r\n    const measurementRefs = React.useRef(new Map());\r\n    // Flatten tree structure for virtualization\r\n    const flattenedItems = React.useMemo(() => {\r\n        if (!enableVirtualization)\r\n            return [];\r\n        const items = [];\r\n        const flatten = (childrenToFlatten, depth = 0) => {\r\n            React.Children.forEach(childrenToFlatten, (child, index) => {\r\n                if (!React.isValidElement(child) || child.type !== TreeItem) {\r\n                    return;\r\n                }\r\n                const itemId = child.props.itemId;\r\n                const itemKey = `${itemId}-${depth}`;\r\n                // Clone the child without its children to prevent double rendering\r\n                const childWithoutNested = React.cloneElement(child, {\r\n                    ...child.props,\r\n                    children: null,\r\n                });\r\n                items.push({\r\n                    child: childWithoutNested,\r\n                    depth,\r\n                    index,\r\n                    key: itemKey,\r\n                    itemId,\r\n                });\r\n                // Check if item has children and is expanded\r\n                const isExpanded = expansionContextValue.expandedSet?.has(itemId);\r\n                if (isExpanded && child.props.children) {\r\n                    flatten(child.props.children, depth + 1);\r\n                }\r\n            });\r\n        };\r\n        flatten(children);\r\n        return items;\r\n    }, [children, enableVirtualization, expansionContextValue.expandedSet]);\r\n    const rowVirtualizer = useVirtual({\r\n        size: flattenedItems.length,\r\n        parentRef,\r\n        estimateSize: React.useCallback((index) => {\r\n            const itemId = flattenedItems[index]?.itemId;\r\n            if (!itemId) {\r\n                return 32;\r\n            }\r\n            return itemHeightsByIdRef.current.get(itemId) ?? 32;\r\n        }, [flattenedItems]),\r\n        overscan: 3,\r\n    });\r\n    // Measure item heights after render\r\n    React.useEffect(() => {\r\n        if (!enableVirtualization) {\r\n            measurementRefs.current.clear();\r\n            itemHeightsByIdRef.current.clear();\r\n            return;\r\n        }\r\n        const measureHeights = () => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        };\r\n        const timeoutId = setTimeout(() => {\r\n            measureHeights();\r\n        }, 0);\r\n        if (typeof window !== 'undefined' && 'ResizeObserver' in window) {\r\n            const resizeObserver = new window.ResizeObserver(() => {\r\n                measureHeights();\r\n            });\r\n            measurementRefs.current.forEach(element => {\r\n                if (element) {\r\n                    resizeObserver.observe(element);\r\n                }\r\n            });\r\n            return () => {\r\n                clearTimeout(timeoutId);\r\n                resizeObserver.disconnect();\r\n            };\r\n        }\r\n        return () => {\r\n            clearTimeout(timeoutId);\r\n        };\r\n    }, [enableVirtualization, flattenedItems, rowVirtualizer]);\r\n    const processedChildren = React.useMemo(() => {\r\n        let treeItemIndex = 0;\r\n        return React.Children.map(children, child => {\r\n            if (!React.isValidElement(child)) {\r\n                return null;\r\n            }\r\n            if (child.type === TreeItem) {\r\n                const currentIndex = treeItemIndex++;\r\n                const hierarchyValue = {\r\n                    depth: 0,\r\n                    parentDepth: 0,\r\n                    isTopLevel: true,\r\n                    index: currentIndex,\r\n                };\r\n                // Wrap in context provider instead of cloning\r\n                return (React.createElement(TreeItemHierarchyContext.Provider, { key: `tree-item-${currentIndex}`, value: hierarchyValue }, child));\r\n            }\r\n            return null;\r\n        });\r\n    }, [children]);\r\n    React.useEffect(() => {\r\n        // Force measurement on children change\r\n        const timeoutId = setTimeout(() => {\r\n            let hasChanges = false;\r\n            measurementRefs.current.forEach((element, itemId) => {\r\n                if (element) {\r\n                    const height = element.offsetHeight;\r\n                    const currentHeight = itemHeightsByIdRef.current.get(itemId);\r\n                    if (currentHeight !== height && height > 0) {\r\n                        itemHeightsByIdRef.current.set(itemId, height);\r\n                        hasChanges = true;\r\n                    }\r\n                }\r\n            });\r\n            if (hasChanges) {\r\n                rowVirtualizer.measure();\r\n            }\r\n        }, 100); // Small delay to ensure DOM is updated\r\n        return () => clearTimeout(timeoutId);\r\n    }, [children, rowVirtualizer]);\r\n    return (React.createElement(InverseContext.Provider, { value: inverseContextValue },\r\n        React.createElement(TreeViewSelectionContext.Provider, { value: selectionContextValue },\r\n            React.createElement(TreeViewExpansionContext.Provider, { value: expansionContextValue },\r\n                React.createElement(TreeViewConfigContext.Provider, { value: configContextValue },\r\n                    React.createElement(StyledTreeView, Object.assign({}, rest, { \"aria-label\": ariaLabel, \"aria-labelledby\": ariaLabelledBy, \"aria-multiselectable\": selectable === TreeViewSelectable.multi, \"data-testid\": testId, isInverse: isInverse, isVirtualized: enableVirtualization, ref: mergedRefs => {\r\n                            if (typeof ref === 'function') {\r\n                                ref(mergedRefs);\r\n                            }\r\n                            else if (ref) {\r\n                                ref.current =\r\n                                    mergedRefs;\r\n                            }\r\n                            parentRef.current = mergedRefs;\r\n                        }, role: \"tree\", theme: theme, style: {\r\n                            ...rest.style,\r\n                            ...(enableVirtualization && height\r\n                                ? { height: `${height}px`, overflow: 'auto' }\r\n                                : {}),\r\n                        } }), enableVirtualization ? (React.createElement(VirtualContainer, { height: rowVirtualizer.totalSize }, rowVirtualizer.virtualItems.map(virtualItem => {\r\n                        const item = flattenedItems[virtualItem.index];\r\n                        const hierarchyValue = {\r\n                            depth: item.depth,\r\n                            parentDepth: Math.max(0, item.depth - 1),\r\n                            isTopLevel: item.depth === 0,\r\n                            index: item.index,\r\n                            isVirtualized: true,\r\n                        };\r\n                        return (React.createElement(VirtualItem, { key: item.key, height: virtualItem.size, transform: virtualItem.start, ref: (el) => {\r\n                                if (el) {\r\n                                    measurementRefs.current.set(item.itemId, el);\r\n                                }\r\n                                else {\r\n                                    measurementRefs.current.delete(item.itemId);\r\n                                }\r\n                            } },\r\n                            React.createElement(TreeItemHierarchyContext.Provider, { value: hierarchyValue }, item.child)));\r\n                    }))) : (processedChildren)))))));\r\n});\r\n//# sourceMappingURL=TreeView.js.map"]} */"));
19456
19456
  var TreeView = /*#__PURE__*/React.forwardRef(function (props, _ref) {
19457
19457
  var ariaLabel = props.ariaLabel,
19458
19458
  ariaLabelledBy = props.ariaLabelledBy,
@@ -19462,6 +19462,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, _ref) {
19462
19462
  testId = props.testId,
19463
19463
  _props$enableVirtuali = props.enableVirtualization,
19464
19464
  enableVirtualization = _props$enableVirtuali === void 0 ? false : _props$enableVirtuali,
19465
+ height = props.height,
19465
19466
  rest = _objectWithoutPropertiesLoose(props, _excluded$1M);
19466
19467
  var theme = React.useContext(ThemeContext);
19467
19468
  var isInverse = useIsInverse(isInverseProp);
@@ -19528,7 +19529,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, _ref) {
19528
19529
  }
19529
19530
  return (_itemHeightsByIdRef$c = itemHeightsByIdRef.current.get(itemId)) != null ? _itemHeightsByIdRef$c : 32;
19530
19531
  }, [flattenedItems]),
19531
- overscan: 6
19532
+ overscan: 3
19532
19533
  });
19533
19534
  // Measure item heights after render
19534
19535
  React.useEffect(function () {
@@ -19541,10 +19542,10 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, _ref) {
19541
19542
  var hasChanges = false;
19542
19543
  measurementRefs.current.forEach(function (element, itemId) {
19543
19544
  if (element) {
19544
- var height = element.offsetHeight;
19545
+ var _height = element.offsetHeight;
19545
19546
  var currentHeight = itemHeightsByIdRef.current.get(itemId);
19546
- if (currentHeight !== height && height > 0) {
19547
- itemHeightsByIdRef.current.set(itemId, height);
19547
+ if (currentHeight !== _height && _height > 0) {
19548
+ itemHeightsByIdRef.current.set(itemId, _height);
19548
19549
  hasChanges = true;
19549
19550
  }
19550
19551
  }
@@ -19603,10 +19604,10 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, _ref) {
19603
19604
  var hasChanges = false;
19604
19605
  measurementRefs.current.forEach(function (element, itemId) {
19605
19606
  if (element) {
19606
- var height = element.offsetHeight;
19607
+ var _height2 = element.offsetHeight;
19607
19608
  var currentHeight = itemHeightsByIdRef.current.get(itemId);
19608
- if (currentHeight !== height && height > 0) {
19609
- itemHeightsByIdRef.current.set(itemId, height);
19609
+ if (currentHeight !== _height2 && _height2 > 0) {
19610
+ itemHeightsByIdRef.current.set(itemId, _height2);
19610
19611
  hasChanges = true;
19611
19612
  }
19612
19613
  }
@@ -19643,7 +19644,11 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, _ref) {
19643
19644
  parentRef.current = mergedRefs;
19644
19645
  },
19645
19646
  role: "tree",
19646
- theme: theme
19647
+ theme: theme,
19648
+ style: _extends({}, rest.style, enableVirtualization && height ? {
19649
+ height: height + "px",
19650
+ overflow: 'auto'
19651
+ } : {})
19647
19652
  }), enableVirtualization ? React.createElement(VirtualContainer, {
19648
19653
  height: rowVirtualizer.totalSize
19649
19654
  }, rowVirtualizer.virtualItems.map(function (virtualItem) {