@mui/x-tree-view 8.22.0 → 8.24.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +312 -0
- package/RichTreeView/RichTreeView.d.ts +1 -1
- package/RichTreeView/RichTreeView.js +41 -28
- package/RichTreeView/RichTreeView.types.d.ts +6 -4
- package/RichTreeView/index.d.ts +1 -3
- package/RichTreeView/index.js +1 -13
- package/RichTreeView/useExtractRichTreeViewParameters.d.ts +294 -0
- package/RichTreeView/useExtractRichTreeViewParameters.js +91 -0
- package/SimpleTreeView/SimpleTreeView.d.ts +1 -1
- package/SimpleTreeView/SimpleTreeView.js +30 -24
- package/SimpleTreeView/SimpleTreeView.types.d.ts +5 -4
- package/SimpleTreeView/useExtractSimpleTreeViewParameters.d.ts +293 -0
- package/SimpleTreeView/useExtractSimpleTreeViewParameters.js +78 -0
- package/TreeItem/TreeItem.d.ts +1 -1
- package/TreeItem/TreeItem.js +9 -2
- package/TreeItemProvider/TreeItemProvider.js +3 -10
- package/esm/RichTreeView/RichTreeView.d.ts +1 -1
- package/esm/RichTreeView/RichTreeView.js +40 -27
- package/esm/RichTreeView/RichTreeView.types.d.ts +6 -4
- package/esm/RichTreeView/index.d.ts +1 -3
- package/esm/RichTreeView/index.js +1 -1
- package/esm/RichTreeView/useExtractRichTreeViewParameters.d.ts +294 -0
- package/esm/RichTreeView/useExtractRichTreeViewParameters.js +83 -0
- package/esm/SimpleTreeView/SimpleTreeView.d.ts +1 -1
- package/esm/SimpleTreeView/SimpleTreeView.js +29 -23
- package/esm/SimpleTreeView/SimpleTreeView.types.d.ts +5 -4
- package/esm/SimpleTreeView/useExtractSimpleTreeViewParameters.d.ts +293 -0
- package/esm/SimpleTreeView/useExtractSimpleTreeViewParameters.js +70 -0
- package/esm/TreeItem/TreeItem.d.ts +1 -1
- package/esm/TreeItem/TreeItem.js +9 -2
- package/esm/TreeItemProvider/TreeItemProvider.js +3 -10
- package/esm/hooks/useApplyPropagationToSelectedItemsOnMount.js +2 -2
- package/esm/hooks/useRichTreeViewApiRef.d.ts +2 -2
- package/esm/hooks/useSimpleTreeViewApiRef.d.ts +2 -3
- package/esm/hooks/useTreeItemModel.d.ts +2 -2
- package/esm/hooks/useTreeItemModel.js +1 -1
- package/esm/hooks/useTreeItemUtils/useTreeItemUtils.d.ts +9 -19
- package/esm/hooks/useTreeItemUtils/useTreeItemUtils.js +26 -35
- package/esm/hooks/useTreeViewApiRef.d.ts +3 -5
- package/esm/hooks/useTreeViewApiRef.js +4 -3
- package/esm/index.d.ts +0 -1
- package/esm/index.js +1 -2
- package/esm/internals/MinimalTreeViewStore/MinimalTreeViewStore.d.ts +90 -0
- package/esm/internals/MinimalTreeViewStore/MinimalTreeViewStore.js +126 -0
- package/esm/internals/MinimalTreeViewStore/MinimalTreeViewStore.types.d.ts +272 -0
- package/esm/internals/MinimalTreeViewStore/MinimalTreeViewStore.utils.d.ts +21 -0
- package/esm/internals/MinimalTreeViewStore/MinimalTreeViewStore.utils.js +49 -0
- package/esm/internals/MinimalTreeViewStore/TimeoutManager.d.ts +9 -0
- package/esm/internals/MinimalTreeViewStore/TimeoutManager.js +39 -0
- package/esm/internals/MinimalTreeViewStore/TreeViewItemPluginManager.d.ts +12 -0
- package/esm/internals/MinimalTreeViewStore/TreeViewItemPluginManager.js +16 -0
- package/esm/internals/MinimalTreeViewStore/index.d.ts +2 -0
- package/esm/internals/MinimalTreeViewStore/index.js +2 -0
- package/esm/internals/RichTreeViewStore/RichTreeViewStore.d.ts +53 -0
- package/esm/internals/RichTreeViewStore/RichTreeViewStore.js +21 -0
- package/esm/internals/RichTreeViewStore/RichTreeViewStore.types.d.ts +34 -0
- package/esm/internals/RichTreeViewStore/RichTreeViewStore.utils.d.ts +3 -0
- package/esm/internals/RichTreeViewStore/RichTreeViewStore.utils.js +15 -0
- package/esm/internals/RichTreeViewStore/index.d.ts +3 -0
- package/esm/internals/RichTreeViewStore/index.js +3 -0
- package/esm/internals/SimpleTreeViewStore/SimpleTreeViewStore.d.ts +8 -0
- package/esm/internals/SimpleTreeViewStore/SimpleTreeViewStore.js +18 -0
- package/esm/internals/SimpleTreeViewStore/SimpleTreeViewStore.types.d.ts +9 -0
- package/esm/internals/SimpleTreeViewStore/SimpleTreeViewStore.utils.d.ts +3 -0
- package/esm/internals/SimpleTreeViewStore/SimpleTreeViewStore.utils.js +5 -0
- package/esm/internals/SimpleTreeViewStore/index.d.ts +2 -0
- package/esm/internals/SimpleTreeViewStore/index.js +2 -0
- package/esm/internals/TreeViewItemDepthContext/TreeViewItemDepthContext.d.ts +2 -3
- package/esm/internals/TreeViewProvider/TreeViewChildrenItemProvider.js +2 -3
- package/esm/internals/TreeViewProvider/TreeViewContext.d.ts +3 -3
- package/esm/internals/TreeViewProvider/TreeViewProvider.d.ts +2 -2
- package/esm/internals/TreeViewProvider/TreeViewProvider.js +11 -6
- package/esm/internals/TreeViewProvider/TreeViewProvider.types.d.ts +8 -10
- package/esm/internals/TreeViewProvider/index.d.ts +1 -1
- package/esm/internals/TreeViewProvider/useTreeViewBuildContext.d.ts +16 -0
- package/esm/internals/{useTreeView → TreeViewProvider}/useTreeViewBuildContext.js +25 -39
- package/esm/internals/components/RichTreeViewItems.js +3 -3
- package/esm/internals/hooks/useTreeViewRootProps.d.ts +287 -0
- package/esm/internals/hooks/useTreeViewRootProps.js +30 -0
- package/esm/internals/hooks/useTreeViewStore.d.ts +10 -0
- package/esm/internals/hooks/useTreeViewStore.js +19 -0
- package/esm/internals/index.d.ts +15 -21
- package/esm/internals/index.js +11 -14
- package/esm/internals/models/events.d.ts +24 -3
- package/esm/internals/models/index.d.ts +2 -3
- package/esm/internals/models/index.js +2 -3
- package/esm/internals/models/itemPlugin.d.ts +9 -0
- package/esm/internals/models/treeView.d.ts +6 -9
- package/esm/internals/plugins/expansion/TreeViewExpansionPlugin.d.ts +69 -0
- package/esm/internals/plugins/expansion/TreeViewExpansionPlugin.js +124 -0
- package/esm/internals/plugins/expansion/index.d.ts +2 -0
- package/esm/internals/plugins/expansion/index.js +2 -0
- package/esm/internals/plugins/expansion/selectors.d.ts +27 -0
- package/esm/internals/plugins/{useTreeViewExpansion/useTreeViewExpansion.selectors.js → expansion/selectors.js} +5 -5
- package/esm/internals/plugins/expansion/utils.d.ts +5 -0
- package/esm/internals/plugins/focus/TreeViewFocusPlugin.d.ts +33 -0
- package/esm/internals/plugins/focus/TreeViewFocusPlugin.js +107 -0
- package/esm/internals/plugins/focus/index.d.ts +2 -0
- package/esm/internals/plugins/focus/index.js +2 -0
- package/esm/internals/plugins/focus/selectors.d.ts +21 -0
- package/esm/internals/plugins/{useTreeViewFocus/useTreeViewFocus.selectors.js → focus/selectors.js} +6 -6
- package/esm/internals/plugins/id/index.d.ts +1 -0
- package/esm/internals/plugins/id/index.js +1 -0
- package/esm/internals/plugins/id/selectors.d.ts +13 -0
- package/esm/internals/plugins/id/selectors.js +18 -0
- package/esm/internals/plugins/items/TreeViewItemsPlugin.d.ts +105 -0
- package/esm/internals/plugins/items/TreeViewItemsPlugin.js +223 -0
- package/esm/internals/plugins/items/index.d.ts +3 -0
- package/esm/internals/plugins/items/index.js +3 -0
- package/esm/internals/plugins/items/selectors.d.ts +60 -0
- package/esm/internals/plugins/items/selectors.js +64 -0
- package/esm/internals/plugins/items/utils.d.ts +43 -0
- package/esm/internals/plugins/{useTreeViewItems/useTreeViewItems.utils.js → items/utils.js} +6 -49
- package/esm/internals/plugins/{useTreeViewJSXItems/useTreeViewJSXItems.types.d.ts → jsxItems/TreeViewJSXItemsPlugin.d.ts} +6 -13
- package/esm/internals/plugins/jsxItems/TreeViewJSXItemsPlugin.js +81 -0
- package/esm/internals/plugins/jsxItems/index.d.ts +1 -0
- package/esm/internals/plugins/jsxItems/index.js +1 -0
- package/esm/internals/plugins/jsxItems/itemPlugin.d.ts +4 -0
- package/esm/internals/plugins/jsxItems/itemPlugin.js +88 -0
- package/esm/internals/plugins/keyboardNavigation/TreeViewKeyboardNavigationPlugin.d.ts +28 -0
- package/esm/internals/plugins/keyboardNavigation/TreeViewKeyboardNavigationPlugin.js +306 -0
- package/esm/internals/plugins/keyboardNavigation/index.d.ts +1 -0
- package/esm/internals/plugins/keyboardNavigation/index.js +1 -0
- package/esm/internals/plugins/labelEditing/TreeViewLabelEditingPlugin.d.ts +22 -0
- package/esm/internals/plugins/labelEditing/TreeViewLabelEditingPlugin.js +50 -0
- package/esm/internals/plugins/labelEditing/index.d.ts +2 -0
- package/esm/internals/plugins/labelEditing/index.js +2 -0
- package/{internals/plugins/useTreeViewLabel → esm/internals/plugins/labelEditing}/itemPlugin.d.ts +5 -4
- package/esm/internals/plugins/{useTreeViewLabel → labelEditing}/itemPlugin.js +2 -2
- package/esm/internals/plugins/labelEditing/selectors.d.ts +15 -0
- package/esm/internals/plugins/{useTreeViewLabel/useTreeViewLabel.selectors.js → labelEditing/selectors.js} +4 -4
- package/esm/internals/plugins/lazyLoading/index.d.ts +2 -0
- package/esm/internals/plugins/lazyLoading/index.js +2 -0
- package/esm/internals/plugins/lazyLoading/selectors.d.ts +19 -0
- package/esm/internals/plugins/lazyLoading/selectors.js +25 -0
- package/esm/internals/plugins/lazyLoading/types.d.ts +5 -0
- package/esm/internals/plugins/selection/TreeViewSelectionPlugin.d.ts +73 -0
- package/esm/internals/plugins/selection/TreeViewSelectionPlugin.js +319 -0
- package/esm/internals/plugins/selection/index.d.ts +2 -0
- package/esm/internals/plugins/selection/index.js +2 -0
- package/esm/internals/plugins/{useTreeViewSelection → selection}/itemPlugin.d.ts +1 -1
- package/esm/internals/plugins/{useTreeViewSelection → selection}/itemPlugin.js +8 -8
- package/esm/internals/plugins/selection/selectors.d.ts +48 -0
- package/esm/internals/plugins/{useTreeViewSelection/useTreeViewSelection.selectors.js → selection/selectors.js} +19 -9
- package/esm/internals/utils/tree.d.ts +8 -10
- package/esm/internals/utils/tree.js +2 -2
- package/esm/models/items.d.ts +5 -2
- package/esm/useTreeItem/useTreeItem.d.ts +18 -2
- package/esm/useTreeItem/useTreeItem.js +15 -19
- package/esm/useTreeItem/useTreeItem.types.d.ts +9 -19
- package/hooks/useApplyPropagationToSelectedItemsOnMount.js +3 -3
- package/hooks/useRichTreeViewApiRef.d.ts +2 -2
- package/hooks/useSimpleTreeViewApiRef.d.ts +2 -3
- package/hooks/useTreeItemModel.d.ts +2 -2
- package/hooks/useTreeItemModel.js +2 -2
- package/hooks/useTreeItemUtils/useTreeItemUtils.d.ts +9 -19
- package/hooks/useTreeItemUtils/useTreeItemUtils.js +41 -49
- package/hooks/useTreeViewApiRef.d.ts +3 -5
- package/hooks/useTreeViewApiRef.js +3 -5
- package/index.d.ts +0 -1
- package/index.js +1 -22
- package/internals/MinimalTreeViewStore/MinimalTreeViewStore.d.ts +90 -0
- package/internals/MinimalTreeViewStore/MinimalTreeViewStore.js +134 -0
- package/internals/MinimalTreeViewStore/MinimalTreeViewStore.types.d.ts +272 -0
- package/internals/MinimalTreeViewStore/MinimalTreeViewStore.utils.d.ts +21 -0
- package/internals/MinimalTreeViewStore/MinimalTreeViewStore.utils.js +58 -0
- package/internals/MinimalTreeViewStore/TimeoutManager.d.ts +9 -0
- package/internals/MinimalTreeViewStore/TimeoutManager.js +46 -0
- package/internals/MinimalTreeViewStore/TreeViewItemPluginManager.d.ts +12 -0
- package/internals/MinimalTreeViewStore/TreeViewItemPluginManager.js +23 -0
- package/internals/MinimalTreeViewStore/index.d.ts +2 -0
- package/internals/MinimalTreeViewStore/index.js +27 -0
- package/internals/RichTreeViewStore/RichTreeViewStore.d.ts +53 -0
- package/internals/RichTreeViewStore/RichTreeViewStore.js +30 -0
- package/internals/RichTreeViewStore/RichTreeViewStore.types.d.ts +34 -0
- package/internals/RichTreeViewStore/RichTreeViewStore.utils.d.ts +3 -0
- package/internals/RichTreeViewStore/RichTreeViewStore.utils.js +22 -0
- package/internals/RichTreeViewStore/index.d.ts +3 -0
- package/internals/RichTreeViewStore/index.js +38 -0
- package/internals/SimpleTreeViewStore/SimpleTreeViewStore.d.ts +8 -0
- package/internals/SimpleTreeViewStore/SimpleTreeViewStore.js +26 -0
- package/internals/SimpleTreeViewStore/SimpleTreeViewStore.types.d.ts +9 -0
- package/internals/SimpleTreeViewStore/SimpleTreeViewStore.utils.d.ts +3 -0
- package/internals/SimpleTreeViewStore/SimpleTreeViewStore.utils.js +11 -0
- package/internals/SimpleTreeViewStore/index.d.ts +2 -0
- package/internals/SimpleTreeViewStore/index.js +27 -0
- package/internals/TreeViewItemDepthContext/TreeViewItemDepthContext.d.ts +2 -3
- package/internals/TreeViewProvider/TreeViewChildrenItemProvider.js +3 -4
- package/internals/TreeViewProvider/TreeViewContext.d.ts +3 -3
- package/internals/TreeViewProvider/TreeViewProvider.d.ts +2 -2
- package/internals/TreeViewProvider/TreeViewProvider.js +14 -9
- package/internals/TreeViewProvider/TreeViewProvider.types.d.ts +8 -10
- package/internals/TreeViewProvider/index.d.ts +1 -1
- package/internals/TreeViewProvider/useTreeViewBuildContext.d.ts +16 -0
- package/internals/{useTreeView → TreeViewProvider}/useTreeViewBuildContext.js +25 -39
- package/internals/components/RichTreeViewItems.js +9 -9
- package/internals/hooks/useTreeViewRootProps.d.ts +287 -0
- package/internals/hooks/useTreeViewRootProps.js +36 -0
- package/internals/hooks/useTreeViewStore.d.ts +10 -0
- package/internals/hooks/useTreeViewStore.js +26 -0
- package/internals/index.d.ts +15 -21
- package/internals/index.js +40 -70
- package/internals/models/events.d.ts +24 -3
- package/internals/models/index.d.ts +2 -3
- package/internals/models/index.js +11 -22
- package/internals/models/itemPlugin.d.ts +9 -0
- package/internals/models/treeView.d.ts +6 -9
- package/internals/plugins/expansion/TreeViewExpansionPlugin.d.ts +69 -0
- package/internals/plugins/expansion/TreeViewExpansionPlugin.js +132 -0
- package/internals/plugins/expansion/index.d.ts +2 -0
- package/internals/plugins/expansion/index.js +27 -0
- package/internals/plugins/expansion/selectors.d.ts +27 -0
- package/internals/plugins/{useTreeViewExpansion/useTreeViewExpansion.selectors.js → expansion/selectors.js} +8 -8
- package/internals/plugins/expansion/utils.d.ts +5 -0
- package/internals/plugins/focus/TreeViewFocusPlugin.d.ts +33 -0
- package/internals/plugins/focus/TreeViewFocusPlugin.js +114 -0
- package/internals/plugins/focus/index.d.ts +2 -0
- package/internals/plugins/focus/index.js +27 -0
- package/internals/plugins/focus/selectors.d.ts +21 -0
- package/internals/plugins/{useTreeViewFocus/useTreeViewFocus.selectors.js → focus/selectors.js} +9 -9
- package/internals/plugins/id/index.d.ts +1 -0
- package/internals/plugins/id/index.js +16 -0
- package/internals/plugins/id/selectors.d.ts +13 -0
- package/internals/plugins/id/selectors.js +24 -0
- package/internals/plugins/items/TreeViewItemsPlugin.d.ts +105 -0
- package/internals/plugins/items/TreeViewItemsPlugin.js +231 -0
- package/internals/plugins/items/index.d.ts +3 -0
- package/internals/plugins/items/index.js +46 -0
- package/internals/plugins/items/selectors.d.ts +60 -0
- package/internals/plugins/{useTreeViewItems/useTreeViewItems.selectors.js → items/selectors.js} +18 -14
- package/internals/plugins/items/utils.d.ts +43 -0
- package/internals/plugins/{useTreeViewItems/useTreeViewItems.utils.js → items/utils.js} +6 -50
- package/internals/plugins/{useTreeViewJSXItems/useTreeViewJSXItems.types.d.ts → jsxItems/TreeViewJSXItemsPlugin.d.ts} +6 -13
- package/internals/plugins/jsxItems/TreeViewJSXItemsPlugin.js +89 -0
- package/internals/plugins/jsxItems/index.d.ts +1 -0
- package/internals/plugins/jsxItems/index.js +16 -0
- package/internals/plugins/jsxItems/itemPlugin.d.ts +4 -0
- package/internals/plugins/{useTreeViewJSXItems → jsxItems}/itemPlugin.js +35 -20
- package/internals/plugins/keyboardNavigation/TreeViewKeyboardNavigationPlugin.d.ts +28 -0
- package/internals/plugins/keyboardNavigation/TreeViewKeyboardNavigationPlugin.js +313 -0
- package/internals/plugins/keyboardNavigation/index.d.ts +1 -0
- package/internals/plugins/keyboardNavigation/index.js +16 -0
- package/internals/plugins/labelEditing/TreeViewLabelEditingPlugin.d.ts +22 -0
- package/internals/plugins/labelEditing/TreeViewLabelEditingPlugin.js +58 -0
- package/internals/plugins/labelEditing/index.d.ts +2 -0
- package/internals/plugins/labelEditing/index.js +27 -0
- package/{esm/internals/plugins/useTreeViewLabel → internals/plugins/labelEditing}/itemPlugin.d.ts +5 -4
- package/internals/plugins/{useTreeViewLabel → labelEditing}/itemPlugin.js +6 -6
- package/internals/plugins/labelEditing/selectors.d.ts +15 -0
- package/internals/plugins/{useTreeViewLabel/useTreeViewLabel.selectors.js → labelEditing/selectors.js} +4 -4
- package/internals/plugins/lazyLoading/index.d.ts +2 -0
- package/internals/plugins/lazyLoading/index.js +27 -0
- package/internals/plugins/lazyLoading/selectors.d.ts +19 -0
- package/internals/plugins/{useTreeViewLazyLoading/useTreeViewLazyLoading.selectors.js → lazyLoading/selectors.js} +11 -6
- package/internals/plugins/lazyLoading/types.d.ts +5 -0
- package/internals/plugins/selection/TreeViewSelectionPlugin.d.ts +73 -0
- package/internals/plugins/selection/TreeViewSelectionPlugin.js +327 -0
- package/internals/plugins/selection/index.d.ts +2 -0
- package/internals/plugins/selection/index.js +27 -0
- package/internals/plugins/{useTreeViewSelection → selection}/itemPlugin.d.ts +1 -1
- package/internals/plugins/{useTreeViewSelection → selection}/itemPlugin.js +16 -16
- package/internals/plugins/selection/selectors.d.ts +48 -0
- package/internals/plugins/{useTreeViewSelection/useTreeViewSelection.selectors.js → selection/selectors.js} +19 -9
- package/internals/utils/tree.d.ts +8 -10
- package/internals/utils/tree.js +33 -33
- package/models/items.d.ts +5 -2
- package/package.json +3 -3
- package/useTreeItem/useTreeItem.d.ts +18 -2
- package/useTreeItem/useTreeItem.js +19 -24
- package/useTreeItem/useTreeItem.types.d.ts +9 -19
- package/RichTreeView/RichTreeView.plugins.d.ts +0 -10
- package/RichTreeView/RichTreeView.plugins.js +0 -15
- package/SimpleTreeView/SimpleTreeView.plugins.d.ts +0 -9
- package/SimpleTreeView/SimpleTreeView.plugins.js +0 -15
- package/esm/RichTreeView/RichTreeView.plugins.d.ts +0 -10
- package/esm/RichTreeView/RichTreeView.plugins.js +0 -9
- package/esm/SimpleTreeView/SimpleTreeView.plugins.d.ts +0 -9
- package/esm/SimpleTreeView/SimpleTreeView.plugins.js +0 -9
- package/esm/internals/corePlugins/corePlugins.d.ts +0 -9
- package/esm/internals/corePlugins/corePlugins.js +0 -8
- package/esm/internals/corePlugins/index.d.ts +0 -2
- package/esm/internals/corePlugins/index.js +0 -1
- package/esm/internals/corePlugins/useTreeViewId/index.d.ts +0 -3
- package/esm/internals/corePlugins/useTreeViewId/index.js +0 -2
- package/esm/internals/corePlugins/useTreeViewId/useTreeViewId.d.ts +0 -3
- package/esm/internals/corePlugins/useTreeViewId/useTreeViewId.js +0 -38
- package/esm/internals/corePlugins/useTreeViewId/useTreeViewId.selectors.d.ts +0 -10
- package/esm/internals/corePlugins/useTreeViewId/useTreeViewId.selectors.js +0 -9
- package/esm/internals/corePlugins/useTreeViewId/useTreeViewId.types.d.ts +0 -20
- package/esm/internals/corePlugins/useTreeViewId/useTreeViewId.utils.d.ts +0 -21
- package/esm/internals/corePlugins/useTreeViewId/useTreeViewId.utils.js +0 -26
- package/esm/internals/corePlugins/useTreeViewInstanceEvents/index.d.ts +0 -2
- package/esm/internals/corePlugins/useTreeViewInstanceEvents/index.js +0 -1
- package/esm/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.d.ts +0 -3
- package/esm/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.js +0 -31
- package/esm/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.types.d.ts +0 -22
- package/esm/internals/corePlugins/useTreeViewOptionalPlugins/index.d.ts +0 -2
- package/esm/internals/corePlugins/useTreeViewOptionalPlugins/index.js +0 -1
- package/esm/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.d.ts +0 -3
- package/esm/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.js +0 -12
- package/esm/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.types.d.ts +0 -8
- package/esm/internals/hooks/useInstanceEventHandler.d.ts +0 -15
- package/esm/internals/hooks/useInstanceEventHandler.js +0 -79
- package/esm/internals/models/helpers.d.ts +0 -7
- package/esm/internals/models/plugin.d.ts +0 -166
- package/esm/internals/models/plugin.js +0 -1
- package/esm/internals/plugins/useTreeViewExpansion/index.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewExpansion/index.js +0 -2
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.js +0 -149
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.d.ts +0 -28
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.d.ts +0 -112
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.js +0 -1
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.d.ts +0 -6
- package/esm/internals/plugins/useTreeViewFocus/index.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewFocus/index.js +0 -2
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.js +0 -113
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.d.ts +0 -22
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.d.ts +0 -45
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.js +0 -1
- package/esm/internals/plugins/useTreeViewItems/index.d.ts +0 -4
- package/esm/internals/plugins/useTreeViewItems/index.js +0 -3
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.js +0 -218
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.d.ts +0 -56
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.js +0 -60
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.types.d.ts +0 -197
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.types.js +0 -1
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.utils.d.ts +0 -49
- package/esm/internals/plugins/useTreeViewJSXItems/index.d.ts +0 -2
- package/esm/internals/plugins/useTreeViewJSXItems/index.js +0 -1
- package/esm/internals/plugins/useTreeViewJSXItems/itemPlugin.d.ts +0 -2
- package/esm/internals/plugins/useTreeViewJSXItems/itemPlugin.js +0 -74
- package/esm/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.js +0 -104
- package/esm/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.types.js +0 -1
- package/esm/internals/plugins/useTreeViewKeyboardNavigation/index.d.ts +0 -2
- package/esm/internals/plugins/useTreeViewKeyboardNavigation/index.js +0 -1
- package/esm/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.js +0 -305
- package/esm/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.types.d.ts +0 -32
- package/esm/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.types.js +0 -1
- package/esm/internals/plugins/useTreeViewLabel/index.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewLabel/index.js +0 -2
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.js +0 -70
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.d.ts +0 -16
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.d.ts +0 -50
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.js +0 -1
- package/esm/internals/plugins/useTreeViewLazyLoading/index.d.ts +0 -2
- package/esm/internals/plugins/useTreeViewLazyLoading/index.js +0 -1
- package/esm/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.selectors.d.ts +0 -24
- package/esm/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.selectors.js +0 -20
- package/esm/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.types.d.ts +0 -100
- package/esm/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.types.js +0 -1
- package/esm/internals/plugins/useTreeViewSelection/index.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewSelection/index.js +0 -2
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.js +0 -230
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.d.ts +0 -40
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.d.ts +0 -132
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.js +0 -1
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.d.ts +0 -31
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.js +0 -107
- package/esm/internals/useTreeView/index.d.ts +0 -1
- package/esm/internals/useTreeView/index.js +0 -1
- package/esm/internals/useTreeView/useExtractPluginParamsFromProps.d.ts +0 -19
- package/esm/internals/useTreeView/useExtractPluginParamsFromProps.js +0 -51
- package/esm/internals/useTreeView/useTreeView.d.ts +0 -18
- package/esm/internals/useTreeView/useTreeView.js +0 -102
- package/esm/internals/useTreeView/useTreeView.types.d.ts +0 -20
- package/esm/internals/useTreeView/useTreeView.types.js +0 -1
- package/esm/internals/useTreeView/useTreeViewBuildContext.d.ts +0 -13
- package/esm/internals/utils/cleanupTracking/CleanupTracking.d.ts +0 -9
- package/esm/internals/utils/cleanupTracking/CleanupTracking.js +0 -1
- package/esm/internals/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.d.ts +0 -7
- package/esm/internals/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.js +0 -14
- package/esm/internals/utils/cleanupTracking/TimerBasedCleanupTracking.d.ts +0 -9
- package/esm/internals/utils/cleanupTracking/TimerBasedCleanupTracking.js +0 -38
- package/esm/internals/utils/plugins.d.ts +0 -2
- package/esm/internals/utils/plugins.js +0 -4
- package/esm/internals/utils/publishTreeViewEvent.d.ts +0 -5
- package/esm/internals/utils/publishTreeViewEvent.js +0 -3
- package/internals/corePlugins/corePlugins.d.ts +0 -9
- package/internals/corePlugins/corePlugins.js +0 -14
- package/internals/corePlugins/index.d.ts +0 -2
- package/internals/corePlugins/index.js +0 -12
- package/internals/corePlugins/useTreeViewId/index.d.ts +0 -3
- package/internals/corePlugins/useTreeViewId/index.js +0 -19
- package/internals/corePlugins/useTreeViewId/useTreeViewId.d.ts +0 -3
- package/internals/corePlugins/useTreeViewId/useTreeViewId.js +0 -46
- package/internals/corePlugins/useTreeViewId/useTreeViewId.selectors.d.ts +0 -10
- package/internals/corePlugins/useTreeViewId/useTreeViewId.selectors.js +0 -15
- package/internals/corePlugins/useTreeViewId/useTreeViewId.types.d.ts +0 -20
- package/internals/corePlugins/useTreeViewId/useTreeViewId.utils.d.ts +0 -21
- package/internals/corePlugins/useTreeViewId/useTreeViewId.utils.js +0 -34
- package/internals/corePlugins/useTreeViewInstanceEvents/index.d.ts +0 -2
- package/internals/corePlugins/useTreeViewInstanceEvents/index.js +0 -12
- package/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.d.ts +0 -3
- package/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.js +0 -38
- package/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.types.d.ts +0 -22
- package/internals/corePlugins/useTreeViewOptionalPlugins/index.d.ts +0 -2
- package/internals/corePlugins/useTreeViewOptionalPlugins/index.js +0 -12
- package/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.d.ts +0 -3
- package/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.js +0 -19
- package/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.types.d.ts +0 -8
- package/internals/hooks/useInstanceEventHandler.d.ts +0 -15
- package/internals/hooks/useInstanceEventHandler.js +0 -87
- package/internals/models/helpers.d.ts +0 -7
- package/internals/models/plugin.d.ts +0 -166
- package/internals/models/plugin.js +0 -5
- package/internals/plugins/useTreeViewExpansion/index.d.ts +0 -3
- package/internals/plugins/useTreeViewExpansion/index.js +0 -19
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.d.ts +0 -3
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.js +0 -157
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.d.ts +0 -28
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.d.ts +0 -112
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.js +0 -5
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.d.ts +0 -6
- package/internals/plugins/useTreeViewFocus/index.d.ts +0 -3
- package/internals/plugins/useTreeViewFocus/index.js +0 -19
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.d.ts +0 -3
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.js +0 -121
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.d.ts +0 -22
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.d.ts +0 -45
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.js +0 -5
- package/internals/plugins/useTreeViewItems/index.d.ts +0 -4
- package/internals/plugins/useTreeViewItems/index.js +0 -32
- package/internals/plugins/useTreeViewItems/useTreeViewItems.d.ts +0 -3
- package/internals/plugins/useTreeViewItems/useTreeViewItems.js +0 -226
- package/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.d.ts +0 -56
- package/internals/plugins/useTreeViewItems/useTreeViewItems.types.d.ts +0 -197
- package/internals/plugins/useTreeViewItems/useTreeViewItems.types.js +0 -5
- package/internals/plugins/useTreeViewItems/useTreeViewItems.utils.d.ts +0 -49
- package/internals/plugins/useTreeViewJSXItems/index.d.ts +0 -2
- package/internals/plugins/useTreeViewJSXItems/index.js +0 -12
- package/internals/plugins/useTreeViewJSXItems/itemPlugin.d.ts +0 -2
- package/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.d.ts +0 -3
- package/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.js +0 -112
- package/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.types.js +0 -5
- package/internals/plugins/useTreeViewKeyboardNavigation/index.d.ts +0 -2
- package/internals/plugins/useTreeViewKeyboardNavigation/index.js +0 -12
- package/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.d.ts +0 -3
- package/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.js +0 -312
- package/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.types.d.ts +0 -32
- package/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.types.js +0 -5
- package/internals/plugins/useTreeViewLabel/index.d.ts +0 -3
- package/internals/plugins/useTreeViewLabel/index.js +0 -19
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.d.ts +0 -3
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.js +0 -78
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.d.ts +0 -16
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.d.ts +0 -50
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.js +0 -5
- package/internals/plugins/useTreeViewLazyLoading/index.d.ts +0 -2
- package/internals/plugins/useTreeViewLazyLoading/index.js +0 -12
- package/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.selectors.d.ts +0 -24
- package/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.types.d.ts +0 -100
- package/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.types.js +0 -5
- package/internals/plugins/useTreeViewSelection/index.d.ts +0 -3
- package/internals/plugins/useTreeViewSelection/index.js +0 -19
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.d.ts +0 -3
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.js +0 -239
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.d.ts +0 -40
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.d.ts +0 -132
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.js +0 -5
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.d.ts +0 -31
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.js +0 -116
- package/internals/useTreeView/index.d.ts +0 -1
- package/internals/useTreeView/index.js +0 -12
- package/internals/useTreeView/useExtractPluginParamsFromProps.d.ts +0 -19
- package/internals/useTreeView/useExtractPluginParamsFromProps.js +0 -60
- package/internals/useTreeView/useTreeView.d.ts +0 -18
- package/internals/useTreeView/useTreeView.js +0 -112
- package/internals/useTreeView/useTreeView.types.d.ts +0 -20
- package/internals/useTreeView/useTreeView.types.js +0 -5
- package/internals/useTreeView/useTreeViewBuildContext.d.ts +0 -13
- package/internals/utils/cleanupTracking/CleanupTracking.d.ts +0 -9
- package/internals/utils/cleanupTracking/CleanupTracking.js +0 -5
- package/internals/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.d.ts +0 -7
- package/internals/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.js +0 -21
- package/internals/utils/cleanupTracking/TimerBasedCleanupTracking.d.ts +0 -9
- package/internals/utils/cleanupTracking/TimerBasedCleanupTracking.js +0 -45
- package/internals/utils/plugins.d.ts +0 -2
- package/internals/utils/plugins.js +0 -11
- package/internals/utils/publishTreeViewEvent.d.ts +0 -5
- package/internals/utils/publishTreeViewEvent.js +0 -10
- /package/esm/internals/{corePlugins/useTreeViewId/useTreeViewId.types.js → MinimalTreeViewStore/MinimalTreeViewStore.types.js} +0 -0
- /package/esm/internals/{corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.types.js → RichTreeViewStore/RichTreeViewStore.types.js} +0 -0
- /package/esm/internals/{corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.types.js → SimpleTreeViewStore/SimpleTreeViewStore.types.js} +0 -0
- /package/esm/internals/plugins/{useTreeViewExpansion/useTreeViewExpansion.utils.js → expansion/utils.js} +0 -0
- /package/esm/internals/{models/helpers.js → plugins/lazyLoading/types.js} +0 -0
- /package/internals/{corePlugins/useTreeViewId/useTreeViewId.types.js → MinimalTreeViewStore/MinimalTreeViewStore.types.js} +0 -0
- /package/internals/{corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.types.js → RichTreeViewStore/RichTreeViewStore.types.js} +0 -0
- /package/internals/{corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.types.js → SimpleTreeViewStore/SimpleTreeViewStore.types.js} +0 -0
- /package/internals/plugins/{useTreeViewExpansion/useTreeViewExpansion.utils.js → expansion/utils.js} +0 -0
- /package/internals/{models/helpers.js → plugins/lazyLoading/types.js} +0 -0
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { DefaultizedProps } from '@mui/x-internals/types';
|
|
3
|
-
import { TreeViewPluginSignature } from "../../models/index.js";
|
|
4
|
-
import { UseTreeViewItemsSignature } from "../useTreeViewItems/index.js";
|
|
5
|
-
import { TreeViewItemId } from "../../../models/index.js";
|
|
6
|
-
import { UseTreeViewLabelSignature } from "../useTreeViewLabel/index.js";
|
|
7
|
-
export interface UseTreeViewExpansionPublicAPI {
|
|
8
|
-
/**
|
|
9
|
-
* Change the expansion status of a given item.
|
|
10
|
-
* @param {object} parameters The parameters of the method.
|
|
11
|
-
* @param {TreeViewItemId} parameters.itemId The id of the item to expand of collapse.
|
|
12
|
-
* @param {React.SyntheticEvent} parameters.event The DOM event that triggered the change.
|
|
13
|
-
* @param {boolean} parameters.shouldBeExpanded If `true` the item will be expanded. If `false` the item will be collapsed. If not defined, the item's expansion status will be the toggled.
|
|
14
|
-
*/
|
|
15
|
-
setItemExpansion: (parameters: {
|
|
16
|
-
itemId: TreeViewItemId;
|
|
17
|
-
event?: React.SyntheticEvent;
|
|
18
|
-
shouldBeExpanded?: boolean;
|
|
19
|
-
}) => void;
|
|
20
|
-
/**
|
|
21
|
-
* Check if an item is expanded.
|
|
22
|
-
* @param {TreeViewItemId} itemId The id of the item to check.
|
|
23
|
-
* @returns {boolean} `true` if the item is expanded, `false` otherwise.
|
|
24
|
-
*/
|
|
25
|
-
isItemExpanded: (itemId: TreeViewItemId) => boolean;
|
|
26
|
-
}
|
|
27
|
-
export interface UseTreeViewExpansionInstance extends Omit<UseTreeViewExpansionPublicAPI, 'isItemExpanded'> {
|
|
28
|
-
/**
|
|
29
|
-
* Expand all the siblings (i.e.: the items that have the same parent) of a given item.
|
|
30
|
-
* @param {React.SyntheticEvent} event The DOM event that triggered the change.
|
|
31
|
-
* @param {TreeViewItemId} itemId The id of the item whose siblings will be expanded.
|
|
32
|
-
*/
|
|
33
|
-
expandAllSiblings: (event: React.KeyboardEvent, itemId: TreeViewItemId) => void;
|
|
34
|
-
/**
|
|
35
|
-
* Apply the new expansion status of a given item.
|
|
36
|
-
* Is used by the `setItemExpansion` method and by the `useTreeViewLazyLoading` plugin.
|
|
37
|
-
* Unlike `setItemExpansion`, this method does not trigger the lazy loading.
|
|
38
|
-
* @param {object} parameters The parameters of the method.
|
|
39
|
-
* @param {TreeViewItemId} parameters.itemId The id of the item to expand of collapse.
|
|
40
|
-
* @param {React.SyntheticEvent | null} parameters.event The DOM event that triggered the change.
|
|
41
|
-
* @param {boolean} parameters.shouldBeExpanded If `true` the item will be expanded. If `false` the item will be collapsed.
|
|
42
|
-
*/
|
|
43
|
-
applyItemExpansion: (parameters: {
|
|
44
|
-
itemId: TreeViewItemId;
|
|
45
|
-
event: React.SyntheticEvent | null;
|
|
46
|
-
shouldBeExpanded: boolean;
|
|
47
|
-
}) => void;
|
|
48
|
-
/**
|
|
49
|
-
* Reset the expansion state of all items.
|
|
50
|
-
*/
|
|
51
|
-
resetItemExpansion: () => void;
|
|
52
|
-
}
|
|
53
|
-
export interface UseTreeViewExpansionParameters {
|
|
54
|
-
/**
|
|
55
|
-
* Expanded item ids.
|
|
56
|
-
* Used when the item's expansion is controlled.
|
|
57
|
-
*/
|
|
58
|
-
expandedItems?: readonly TreeViewItemId[];
|
|
59
|
-
/**
|
|
60
|
-
* Expanded item ids.
|
|
61
|
-
* Used when the item's expansion is not controlled.
|
|
62
|
-
* @default []
|
|
63
|
-
*/
|
|
64
|
-
defaultExpandedItems?: readonly TreeViewItemId[];
|
|
65
|
-
/**
|
|
66
|
-
* Callback fired when Tree Items are expanded/collapsed.
|
|
67
|
-
* @param {React.SyntheticEvent} event The DOM event that triggered the change. Can be null when the change is caused by the `publicAPI.setItemExpansion()` method.
|
|
68
|
-
* @param {TreeViewItemId[]} itemIds The ids of the expanded items.
|
|
69
|
-
*/
|
|
70
|
-
onExpandedItemsChange?: (event: React.SyntheticEvent | null, itemIds: TreeViewItemId[]) => void;
|
|
71
|
-
/**
|
|
72
|
-
* Callback fired when a Tree Item is expanded or collapsed.
|
|
73
|
-
* @param {React.SyntheticEvent | null} event The DOM event that triggered the change. Can be null when the change is caused by the `publicAPI.setItemExpansion()` method.
|
|
74
|
-
* @param {TreeViewItemId} itemId The itemId of the modified item.
|
|
75
|
-
* @param {boolean} isExpanded `true` if the item has just been expanded, `false` if it has just been collapsed.
|
|
76
|
-
*/
|
|
77
|
-
onItemExpansionToggle?: (event: React.SyntheticEvent | null, itemId: TreeViewItemId, isExpanded: boolean) => void;
|
|
78
|
-
/**
|
|
79
|
-
* The slot that triggers the item's expansion when clicked.
|
|
80
|
-
* @default 'content'
|
|
81
|
-
*/
|
|
82
|
-
expansionTrigger?: 'content' | 'iconContainer';
|
|
83
|
-
}
|
|
84
|
-
export type UseTreeViewExpansionParametersWithDefaults = DefaultizedProps<UseTreeViewExpansionParameters, 'defaultExpandedItems'>;
|
|
85
|
-
export interface UseTreeViewExpansionState {
|
|
86
|
-
expansion: {
|
|
87
|
-
expandedItems: readonly TreeViewItemId[];
|
|
88
|
-
expansionTrigger: 'content' | 'iconContainer';
|
|
89
|
-
};
|
|
90
|
-
}
|
|
91
|
-
interface UseTreeViewExpansionEventLookup {
|
|
92
|
-
beforeItemToggleExpansion: {
|
|
93
|
-
params: {
|
|
94
|
-
isExpansionPrevented: boolean;
|
|
95
|
-
shouldBeExpanded: boolean;
|
|
96
|
-
event: React.SyntheticEvent | null;
|
|
97
|
-
itemId: TreeViewItemId;
|
|
98
|
-
};
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
export type UseTreeViewExpansionSignature = TreeViewPluginSignature<{
|
|
102
|
-
params: UseTreeViewExpansionParameters;
|
|
103
|
-
paramsWithDefaults: UseTreeViewExpansionParametersWithDefaults;
|
|
104
|
-
instance: UseTreeViewExpansionInstance;
|
|
105
|
-
publicAPI: UseTreeViewExpansionPublicAPI;
|
|
106
|
-
modelNames: 'expandedItems';
|
|
107
|
-
state: UseTreeViewExpansionState;
|
|
108
|
-
dependencies: [UseTreeViewItemsSignature];
|
|
109
|
-
optionalDependencies: [UseTreeViewLabelSignature];
|
|
110
|
-
events: UseTreeViewExpansionEventLookup;
|
|
111
|
-
}>;
|
|
112
|
-
export {};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { TreeViewUsedParamsWithDefaults } from "../../models/index.js";
|
|
2
|
-
import { UseTreeViewExpansionSignature } from "./useTreeViewExpansion.types.js";
|
|
3
|
-
export declare const getExpansionTrigger: ({
|
|
4
|
-
isItemEditable,
|
|
5
|
-
expansionTrigger
|
|
6
|
-
}: Pick<TreeViewUsedParamsWithDefaults<UseTreeViewExpansionSignature>, "isItemEditable" | "expansionTrigger">) => "content" | "iconContainer";
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
Object.defineProperty(exports, "focusSelectors", {
|
|
7
|
-
enumerable: true,
|
|
8
|
-
get: function () {
|
|
9
|
-
return _useTreeViewFocus2.focusSelectors;
|
|
10
|
-
}
|
|
11
|
-
});
|
|
12
|
-
Object.defineProperty(exports, "useTreeViewFocus", {
|
|
13
|
-
enumerable: true,
|
|
14
|
-
get: function () {
|
|
15
|
-
return _useTreeViewFocus.useTreeViewFocus;
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
var _useTreeViewFocus = require("./useTreeViewFocus");
|
|
19
|
-
var _useTreeViewFocus2 = require("./useTreeViewFocus.selectors");
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
-
Object.defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
exports.useTreeViewFocus = void 0;
|
|
8
|
-
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
9
|
-
var _useEventCallback = require("@base-ui-components/utils/useEventCallback");
|
|
10
|
-
var _store = require("@mui/x-internals/store");
|
|
11
|
-
var _useTreeViewFocus = require("./useTreeViewFocus.selectors");
|
|
12
|
-
var _useTreeViewExpansion = require("../useTreeViewExpansion/useTreeViewExpansion.selectors");
|
|
13
|
-
var _useTreeViewItems = require("../useTreeViewItems/useTreeViewItems.selectors");
|
|
14
|
-
const useTreeViewFocus = ({
|
|
15
|
-
instance,
|
|
16
|
-
params,
|
|
17
|
-
store
|
|
18
|
-
}) => {
|
|
19
|
-
const setFocusedItemId = (0, _useEventCallback.useEventCallback)(itemId => {
|
|
20
|
-
const focusedItemId = _useTreeViewFocus.focusSelectors.focusedItemId(store.state);
|
|
21
|
-
if (focusedItemId === itemId) {
|
|
22
|
-
return;
|
|
23
|
-
}
|
|
24
|
-
store.set('focus', (0, _extends2.default)({}, store.state.focus, {
|
|
25
|
-
focusedItemId: itemId
|
|
26
|
-
}));
|
|
27
|
-
});
|
|
28
|
-
const isItemVisible = itemId => {
|
|
29
|
-
const itemMeta = _useTreeViewItems.itemsSelectors.itemMeta(store.state, itemId);
|
|
30
|
-
return itemMeta && (itemMeta.parentId == null || _useTreeViewExpansion.expansionSelectors.isItemExpanded(store.state, itemMeta.parentId));
|
|
31
|
-
};
|
|
32
|
-
const innerFocusItem = (event, itemId) => {
|
|
33
|
-
const itemElement = instance.getItemDOMElement(itemId);
|
|
34
|
-
if (itemElement) {
|
|
35
|
-
itemElement.focus();
|
|
36
|
-
}
|
|
37
|
-
setFocusedItemId(itemId);
|
|
38
|
-
if (params.onItemFocus) {
|
|
39
|
-
params.onItemFocus(event, itemId);
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
const focusItem = (0, _useEventCallback.useEventCallback)((event, itemId) => {
|
|
43
|
-
// If we receive an itemId, and it is visible, the focus will be set to it
|
|
44
|
-
if (isItemVisible(itemId)) {
|
|
45
|
-
innerFocusItem(event, itemId);
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
const removeFocusedItem = (0, _useEventCallback.useEventCallback)(() => {
|
|
49
|
-
const focusedItemId = _useTreeViewFocus.focusSelectors.focusedItemId(store.state);
|
|
50
|
-
if (focusedItemId == null) {
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
const itemMeta = _useTreeViewItems.itemsSelectors.itemMeta(store.state, focusedItemId);
|
|
54
|
-
if (itemMeta) {
|
|
55
|
-
const itemElement = instance.getItemDOMElement(focusedItemId);
|
|
56
|
-
if (itemElement) {
|
|
57
|
-
itemElement.blur();
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
setFocusedItemId(null);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
// Whenever the items change, we need to ensure the focused item is still present.
|
|
64
|
-
(0, _store.useStoreEffect)(store, _useTreeViewItems.itemsSelectors.itemMetaLookup, () => {
|
|
65
|
-
const focusedItemId = _useTreeViewFocus.focusSelectors.focusedItemId(store.state);
|
|
66
|
-
if (focusedItemId == null) {
|
|
67
|
-
return;
|
|
68
|
-
}
|
|
69
|
-
const hasItemBeenRemoved = !_useTreeViewItems.itemsSelectors.itemMeta(store.state, focusedItemId);
|
|
70
|
-
if (!hasItemBeenRemoved) {
|
|
71
|
-
return;
|
|
72
|
-
}
|
|
73
|
-
const defaultFocusableItemId = _useTreeViewFocus.focusSelectors.defaultFocusableItemId(store.state);
|
|
74
|
-
if (defaultFocusableItemId == null) {
|
|
75
|
-
setFocusedItemId(null);
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
innerFocusItem(null, defaultFocusableItemId);
|
|
79
|
-
});
|
|
80
|
-
const createRootHandleFocus = otherHandlers => event => {
|
|
81
|
-
otherHandlers.onFocus?.(event);
|
|
82
|
-
if (event.defaultMuiPrevented) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
// if the event bubbled (which is React specific) we don't want to steal focus
|
|
87
|
-
const defaultFocusableItemId = _useTreeViewFocus.focusSelectors.defaultFocusableItemId(store.state);
|
|
88
|
-
if (event.target === event.currentTarget && defaultFocusableItemId != null) {
|
|
89
|
-
innerFocusItem(event, defaultFocusableItemId);
|
|
90
|
-
}
|
|
91
|
-
};
|
|
92
|
-
const createRootHandleBlur = otherHandlers => event => {
|
|
93
|
-
otherHandlers.onBlur?.(event);
|
|
94
|
-
if (event.defaultMuiPrevented) {
|
|
95
|
-
return;
|
|
96
|
-
}
|
|
97
|
-
setFocusedItemId(null);
|
|
98
|
-
};
|
|
99
|
-
return {
|
|
100
|
-
getRootProps: otherHandlers => ({
|
|
101
|
-
onFocus: createRootHandleFocus(otherHandlers),
|
|
102
|
-
onBlur: createRootHandleBlur(otherHandlers)
|
|
103
|
-
}),
|
|
104
|
-
publicAPI: {
|
|
105
|
-
focusItem
|
|
106
|
-
},
|
|
107
|
-
instance: {
|
|
108
|
-
focusItem,
|
|
109
|
-
removeFocusedItem
|
|
110
|
-
}
|
|
111
|
-
};
|
|
112
|
-
};
|
|
113
|
-
exports.useTreeViewFocus = useTreeViewFocus;
|
|
114
|
-
useTreeViewFocus.getInitialState = () => ({
|
|
115
|
-
focus: {
|
|
116
|
-
focusedItemId: null
|
|
117
|
-
}
|
|
118
|
-
});
|
|
119
|
-
useTreeViewFocus.params = {
|
|
120
|
-
onItemFocus: true
|
|
121
|
-
};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { UseTreeViewFocusSignature } from "./useTreeViewFocus.types.js";
|
|
2
|
-
import { TreeViewState } from "../../models/index.js";
|
|
3
|
-
export declare const focusSelectors: {
|
|
4
|
-
/**
|
|
5
|
-
* Gets the item that should be sequentially focusable (usually with the Tab key).
|
|
6
|
-
* At any point in time, there is a single item that can be sequentially focused in the Tree View.
|
|
7
|
-
* This item is the first selected item (that is both visible and navigable), if any, or the first navigable item if no item is selected.
|
|
8
|
-
*/
|
|
9
|
-
defaultFocusableItemId: (args_0: import("../../corePlugins/useTreeViewId/useTreeViewId.types.js").UseTreeViewIdState & import("../useTreeViewItems/index.js").UseTreeViewItemsState<import("../../../index.js").TreeViewDefaultItemModelProperties> & Partial<{}>) => string | null;
|
|
10
|
-
/**
|
|
11
|
-
* Checks whether an item is the default focusable item.
|
|
12
|
-
*/
|
|
13
|
-
isItemTheDefaultFocusableItem: (args_0: import("../../corePlugins/useTreeViewId/useTreeViewId.types.js").UseTreeViewIdState & import("../useTreeViewItems/index.js").UseTreeViewItemsState<import("../../../index.js").TreeViewDefaultItemModelProperties> & Partial<{}>, itemId: any) => boolean;
|
|
14
|
-
/**
|
|
15
|
-
* Gets the id of the item that is currently focused.
|
|
16
|
-
*/
|
|
17
|
-
focusedItemId: (state: TreeViewState<[UseTreeViewFocusSignature]>) => string | null;
|
|
18
|
-
/**
|
|
19
|
-
* Checks whether an item is focused.
|
|
20
|
-
*/
|
|
21
|
-
isItemFocused: (state: TreeViewState<[UseTreeViewFocusSignature]>, itemId: string) => boolean;
|
|
22
|
-
};
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { TreeViewPluginSignature } from "../../models/index.js";
|
|
3
|
-
import type { UseTreeViewItemsSignature } from "../useTreeViewItems/index.js";
|
|
4
|
-
import type { UseTreeViewSelectionSignature } from "../useTreeViewSelection/index.js";
|
|
5
|
-
import { UseTreeViewExpansionSignature } from "../useTreeViewExpansion/index.js";
|
|
6
|
-
import { TreeViewItemId } from "../../../models/index.js";
|
|
7
|
-
export interface UseTreeViewFocusPublicAPI {
|
|
8
|
-
/**
|
|
9
|
-
* Focus the item with the given id.
|
|
10
|
-
*
|
|
11
|
-
* If the item is the child of a collapsed item, then this method will do nothing.
|
|
12
|
-
* Make sure to expand the ancestors of the item before calling this method if needed.
|
|
13
|
-
* @param {React.SyntheticEvent | null} event The DOM event that triggered the change.
|
|
14
|
-
* @param {TreeViewItemId} itemId The id of the item to focus.
|
|
15
|
-
*/
|
|
16
|
-
focusItem: (event: React.SyntheticEvent | null, itemId: TreeViewItemId) => void;
|
|
17
|
-
}
|
|
18
|
-
export interface UseTreeViewFocusInstance extends UseTreeViewFocusPublicAPI {
|
|
19
|
-
/**
|
|
20
|
-
* Remove the focus from the currently focused item (both from the internal state and the DOM).
|
|
21
|
-
*/
|
|
22
|
-
removeFocusedItem: () => void;
|
|
23
|
-
}
|
|
24
|
-
export interface UseTreeViewFocusParameters {
|
|
25
|
-
/**
|
|
26
|
-
* Callback fired when a given Tree Item is focused.
|
|
27
|
-
* @param {React.SyntheticEvent | null} event The DOM event that triggered the change. **Warning**: This is a generic event not a focus event.
|
|
28
|
-
* @param {TreeViewItemId} itemId The id of the focused item.
|
|
29
|
-
*/
|
|
30
|
-
onItemFocus?: (event: React.SyntheticEvent | null, itemId: TreeViewItemId) => void;
|
|
31
|
-
}
|
|
32
|
-
export type UseTreeViewFocusParametersWithDefaults = UseTreeViewFocusParameters;
|
|
33
|
-
export interface UseTreeViewFocusState {
|
|
34
|
-
focus: {
|
|
35
|
-
focusedItemId: TreeViewItemId | null;
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
export type UseTreeViewFocusSignature = TreeViewPluginSignature<{
|
|
39
|
-
params: UseTreeViewFocusParameters;
|
|
40
|
-
paramsWithDefaults: UseTreeViewFocusParametersWithDefaults;
|
|
41
|
-
instance: UseTreeViewFocusInstance;
|
|
42
|
-
publicAPI: UseTreeViewFocusPublicAPI;
|
|
43
|
-
state: UseTreeViewFocusState;
|
|
44
|
-
dependencies: [UseTreeViewItemsSignature, UseTreeViewSelectionSignature, UseTreeViewExpansionSignature];
|
|
45
|
-
}>;
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
export { useTreeViewItems } from "./useTreeViewItems.js";
|
|
2
|
-
export type { UseTreeViewItemsSignature, UseTreeViewItemsParameters, UseTreeViewItemsParametersWithDefaults, UseTreeViewItemsState } from "./useTreeViewItems.types.js";
|
|
3
|
-
export { buildSiblingIndexes, TREE_VIEW_ROOT_PARENT_ID } from "./useTreeViewItems.utils.js";
|
|
4
|
-
export { itemsSelectors } from "./useTreeViewItems.selectors.js";
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
Object.defineProperty(exports, "TREE_VIEW_ROOT_PARENT_ID", {
|
|
7
|
-
enumerable: true,
|
|
8
|
-
get: function () {
|
|
9
|
-
return _useTreeViewItems2.TREE_VIEW_ROOT_PARENT_ID;
|
|
10
|
-
}
|
|
11
|
-
});
|
|
12
|
-
Object.defineProperty(exports, "buildSiblingIndexes", {
|
|
13
|
-
enumerable: true,
|
|
14
|
-
get: function () {
|
|
15
|
-
return _useTreeViewItems2.buildSiblingIndexes;
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
Object.defineProperty(exports, "itemsSelectors", {
|
|
19
|
-
enumerable: true,
|
|
20
|
-
get: function () {
|
|
21
|
-
return _useTreeViewItems3.itemsSelectors;
|
|
22
|
-
}
|
|
23
|
-
});
|
|
24
|
-
Object.defineProperty(exports, "useTreeViewItems", {
|
|
25
|
-
enumerable: true,
|
|
26
|
-
get: function () {
|
|
27
|
-
return _useTreeViewItems.useTreeViewItems;
|
|
28
|
-
}
|
|
29
|
-
});
|
|
30
|
-
var _useTreeViewItems = require("./useTreeViewItems");
|
|
31
|
-
var _useTreeViewItems2 = require("./useTreeViewItems.utils");
|
|
32
|
-
var _useTreeViewItems3 = require("./useTreeViewItems.selectors");
|
|
@@ -1,226 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
'use client';
|
|
3
|
-
|
|
4
|
-
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
6
|
-
Object.defineProperty(exports, "__esModule", {
|
|
7
|
-
value: true
|
|
8
|
-
});
|
|
9
|
-
exports.useTreeViewItems = void 0;
|
|
10
|
-
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
11
|
-
var React = _interopRequireWildcard(require("react"));
|
|
12
|
-
var _useEventCallback = require("@base-ui-components/utils/useEventCallback");
|
|
13
|
-
var _useTreeViewItems = require("./useTreeViewItems.utils");
|
|
14
|
-
var _TreeViewItemDepthContext = require("../../TreeViewItemDepthContext");
|
|
15
|
-
var _useTreeViewItems2 = require("./useTreeViewItems.selectors");
|
|
16
|
-
var _useTreeViewId = require("../../corePlugins/useTreeViewId");
|
|
17
|
-
var _useTreeViewId2 = require("../../corePlugins/useTreeViewId/useTreeViewId.utils");
|
|
18
|
-
var _jsxRuntime = require("react/jsx-runtime");
|
|
19
|
-
const useTreeViewItems = ({
|
|
20
|
-
instance,
|
|
21
|
-
params,
|
|
22
|
-
store
|
|
23
|
-
}) => {
|
|
24
|
-
const itemsConfig = React.useMemo(() => ({
|
|
25
|
-
isItemDisabled: params.isItemDisabled,
|
|
26
|
-
getItemLabel: params.getItemLabel,
|
|
27
|
-
getItemChildren: params.getItemChildren,
|
|
28
|
-
getItemId: params.getItemId
|
|
29
|
-
}), [params.isItemDisabled, params.getItemLabel, params.getItemChildren, params.getItemId]);
|
|
30
|
-
const getItem = React.useCallback(itemId => _useTreeViewItems2.itemsSelectors.itemModel(store.state, itemId), [store]);
|
|
31
|
-
const getParentId = React.useCallback(itemId => {
|
|
32
|
-
const itemMeta = _useTreeViewItems2.itemsSelectors.itemMeta(store.state, itemId);
|
|
33
|
-
return itemMeta?.parentId || null;
|
|
34
|
-
}, [store]);
|
|
35
|
-
const setIsItemDisabled = (0, _useEventCallback.useEventCallback)(({
|
|
36
|
-
itemId,
|
|
37
|
-
shouldBeDisabled
|
|
38
|
-
}) => {
|
|
39
|
-
if (!store.state.items.itemMetaLookup[itemId]) {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
const itemMetaLookup = (0, _extends2.default)({}, store.state.items.itemMetaLookup);
|
|
43
|
-
itemMetaLookup[itemId] = (0, _extends2.default)({}, itemMetaLookup[itemId], {
|
|
44
|
-
disabled: shouldBeDisabled ?? !itemMetaLookup[itemId].disabled
|
|
45
|
-
});
|
|
46
|
-
store.set('items', (0, _extends2.default)({}, store.state.items, {
|
|
47
|
-
itemMetaLookup
|
|
48
|
-
}));
|
|
49
|
-
});
|
|
50
|
-
const getItemTree = React.useCallback(() => {
|
|
51
|
-
const getItemFromItemId = itemId => {
|
|
52
|
-
const item = _useTreeViewItems2.itemsSelectors.itemModel(store.state, itemId);
|
|
53
|
-
const itemToMutate = (0, _extends2.default)({}, item);
|
|
54
|
-
const newChildren = _useTreeViewItems2.itemsSelectors.itemOrderedChildrenIds(store.state, itemId);
|
|
55
|
-
if (newChildren.length > 0) {
|
|
56
|
-
itemToMutate.children = newChildren.map(getItemFromItemId);
|
|
57
|
-
} else {
|
|
58
|
-
delete itemToMutate.children;
|
|
59
|
-
}
|
|
60
|
-
return itemToMutate;
|
|
61
|
-
};
|
|
62
|
-
return _useTreeViewItems2.itemsSelectors.itemOrderedChildrenIds(store.state, null).map(getItemFromItemId);
|
|
63
|
-
}, [store]);
|
|
64
|
-
const getItemOrderedChildrenIds = React.useCallback(itemId => _useTreeViewItems2.itemsSelectors.itemOrderedChildrenIds(store.state, itemId), [store]);
|
|
65
|
-
const getItemDOMElement = itemId => {
|
|
66
|
-
const itemMeta = _useTreeViewItems2.itemsSelectors.itemMeta(store.state, itemId);
|
|
67
|
-
if (itemMeta == null) {
|
|
68
|
-
return null;
|
|
69
|
-
}
|
|
70
|
-
const idAttribute = (0, _useTreeViewId2.generateTreeItemIdAttribute)({
|
|
71
|
-
treeId: _useTreeViewId.idSelectors.treeId(store.state),
|
|
72
|
-
itemId,
|
|
73
|
-
id: itemMeta.idAttribute
|
|
74
|
-
});
|
|
75
|
-
return document.getElementById(idAttribute);
|
|
76
|
-
};
|
|
77
|
-
const areItemUpdatesPreventedRef = React.useRef(false);
|
|
78
|
-
const preventItemUpdates = React.useCallback(() => {
|
|
79
|
-
areItemUpdatesPreventedRef.current = true;
|
|
80
|
-
}, []);
|
|
81
|
-
const areItemUpdatesPrevented = React.useCallback(() => areItemUpdatesPreventedRef.current, []);
|
|
82
|
-
const setItemChildren = ({
|
|
83
|
-
items,
|
|
84
|
-
parentId,
|
|
85
|
-
getChildrenCount
|
|
86
|
-
}) => {
|
|
87
|
-
const parentIdWithDefault = parentId ?? _useTreeViewItems.TREE_VIEW_ROOT_PARENT_ID;
|
|
88
|
-
const parentDepth = parentId == null ? -1 : _useTreeViewItems2.itemsSelectors.itemDepth(store.state, parentId);
|
|
89
|
-
const {
|
|
90
|
-
metaLookup,
|
|
91
|
-
modelLookup,
|
|
92
|
-
orderedChildrenIds,
|
|
93
|
-
childrenIndexes
|
|
94
|
-
} = (0, _useTreeViewItems.buildItemsLookups)({
|
|
95
|
-
config: itemsConfig,
|
|
96
|
-
items,
|
|
97
|
-
parentId,
|
|
98
|
-
depth: parentDepth + 1,
|
|
99
|
-
isItemExpandable: getChildrenCount ? item => getChildrenCount(item) > 0 : () => false,
|
|
100
|
-
otherItemsMetaLookup: _useTreeViewItems2.itemsSelectors.itemMetaLookup(store.state)
|
|
101
|
-
});
|
|
102
|
-
const lookups = {
|
|
103
|
-
itemModelLookup: (0, _extends2.default)({}, store.state.items.itemModelLookup, modelLookup),
|
|
104
|
-
itemMetaLookup: (0, _extends2.default)({}, store.state.items.itemMetaLookup, metaLookup),
|
|
105
|
-
itemOrderedChildrenIdsLookup: (0, _extends2.default)({}, store.state.items.itemOrderedChildrenIdsLookup, {
|
|
106
|
-
[parentIdWithDefault]: orderedChildrenIds
|
|
107
|
-
}),
|
|
108
|
-
itemChildrenIndexesLookup: (0, _extends2.default)({}, store.state.items.itemChildrenIndexesLookup, {
|
|
109
|
-
[parentIdWithDefault]: childrenIndexes
|
|
110
|
-
})
|
|
111
|
-
};
|
|
112
|
-
store.set('items', (0, _extends2.default)({}, store.state.items, lookups));
|
|
113
|
-
};
|
|
114
|
-
const removeChildren = (0, _useEventCallback.useEventCallback)(parentId => {
|
|
115
|
-
const newMetaMap = Object.keys(store.state.items.itemMetaLookup).reduce((acc, key) => {
|
|
116
|
-
const item = store.state.items.itemMetaLookup[key];
|
|
117
|
-
if (item.parentId === parentId) {
|
|
118
|
-
return acc;
|
|
119
|
-
}
|
|
120
|
-
return (0, _extends2.default)({}, acc, {
|
|
121
|
-
[item.id]: item
|
|
122
|
-
});
|
|
123
|
-
}, {});
|
|
124
|
-
const newItemOrderedChildrenIdsLookup = (0, _extends2.default)({}, store.state.items.itemOrderedChildrenIdsLookup);
|
|
125
|
-
const newItemChildrenIndexesLookup = (0, _extends2.default)({}, store.state.items.itemChildrenIndexesLookup);
|
|
126
|
-
const cleanId = parentId ?? _useTreeViewItems.TREE_VIEW_ROOT_PARENT_ID;
|
|
127
|
-
delete newItemChildrenIndexesLookup[cleanId];
|
|
128
|
-
delete newItemOrderedChildrenIdsLookup[cleanId];
|
|
129
|
-
store.set('items', (0, _extends2.default)({}, store.state.items, {
|
|
130
|
-
itemMetaLookup: newMetaMap,
|
|
131
|
-
itemOrderedChildrenIdsLookup: newItemOrderedChildrenIdsLookup,
|
|
132
|
-
itemChildrenIndexesLookup: newItemChildrenIndexesLookup
|
|
133
|
-
}));
|
|
134
|
-
});
|
|
135
|
-
const addExpandableItems = (0, _useEventCallback.useEventCallback)(items => {
|
|
136
|
-
const newItemMetaLookup = (0, _extends2.default)({}, store.state.items.itemMetaLookup);
|
|
137
|
-
for (const itemId of items) {
|
|
138
|
-
newItemMetaLookup[itemId] = (0, _extends2.default)({}, newItemMetaLookup[itemId], {
|
|
139
|
-
expandable: true
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
store.set('items', (0, _extends2.default)({}, store.state.items, {
|
|
143
|
-
itemMetaLookup: newItemMetaLookup
|
|
144
|
-
}));
|
|
145
|
-
});
|
|
146
|
-
React.useEffect(() => {
|
|
147
|
-
if (instance.areItemUpdatesPrevented()) {
|
|
148
|
-
return;
|
|
149
|
-
}
|
|
150
|
-
const newState = (0, _useTreeViewItems.buildItemsState)({
|
|
151
|
-
disabledItemsFocusable: params.disabledItemsFocusable,
|
|
152
|
-
items: params.items,
|
|
153
|
-
config: itemsConfig
|
|
154
|
-
});
|
|
155
|
-
store.set('items', (0, _extends2.default)({}, store.state.items, newState));
|
|
156
|
-
}, [instance, store, params.items, params.disabledItemsFocusable, itemsConfig]);
|
|
157
|
-
|
|
158
|
-
// Wrap `props.onItemClick` with `useEventCallback` to prevent unneeded context updates.
|
|
159
|
-
const handleItemClick = (0, _useEventCallback.useEventCallback)((event, itemId) => {
|
|
160
|
-
if (params.onItemClick) {
|
|
161
|
-
params.onItemClick(event, itemId);
|
|
162
|
-
}
|
|
163
|
-
});
|
|
164
|
-
return {
|
|
165
|
-
getRootProps: () => ({
|
|
166
|
-
style: {
|
|
167
|
-
'--TreeView-itemChildrenIndentation': typeof params.itemChildrenIndentation === 'number' ? `${params.itemChildrenIndentation}px` : params.itemChildrenIndentation
|
|
168
|
-
}
|
|
169
|
-
}),
|
|
170
|
-
publicAPI: {
|
|
171
|
-
getItem,
|
|
172
|
-
getItemDOMElement,
|
|
173
|
-
getItemTree,
|
|
174
|
-
getItemOrderedChildrenIds,
|
|
175
|
-
setIsItemDisabled,
|
|
176
|
-
getParentId
|
|
177
|
-
},
|
|
178
|
-
instance: {
|
|
179
|
-
getItemDOMElement,
|
|
180
|
-
preventItemUpdates,
|
|
181
|
-
areItemUpdatesPrevented,
|
|
182
|
-
setItemChildren,
|
|
183
|
-
removeChildren,
|
|
184
|
-
addExpandableItems,
|
|
185
|
-
handleItemClick
|
|
186
|
-
}
|
|
187
|
-
};
|
|
188
|
-
};
|
|
189
|
-
exports.useTreeViewItems = useTreeViewItems;
|
|
190
|
-
useTreeViewItems.getInitialState = params => ({
|
|
191
|
-
items: (0, _useTreeViewItems.buildItemsState)({
|
|
192
|
-
items: params.items,
|
|
193
|
-
disabledItemsFocusable: params.disabledItemsFocusable,
|
|
194
|
-
config: {
|
|
195
|
-
isItemDisabled: params.isItemDisabled,
|
|
196
|
-
getItemId: params.getItemId,
|
|
197
|
-
getItemLabel: params.getItemLabel,
|
|
198
|
-
getItemChildren: params.getItemChildren
|
|
199
|
-
}
|
|
200
|
-
})
|
|
201
|
-
});
|
|
202
|
-
useTreeViewItems.applyDefaultValuesToParams = ({
|
|
203
|
-
params
|
|
204
|
-
}) => (0, _extends2.default)({}, params, {
|
|
205
|
-
disabledItemsFocusable: params.disabledItemsFocusable ?? false,
|
|
206
|
-
itemChildrenIndentation: params.itemChildrenIndentation ?? '12px'
|
|
207
|
-
});
|
|
208
|
-
useTreeViewItems.wrapRoot = ({
|
|
209
|
-
children
|
|
210
|
-
}) => {
|
|
211
|
-
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_TreeViewItemDepthContext.TreeViewItemDepthContext.Provider, {
|
|
212
|
-
value: _useTreeViewItems2.itemsSelectors.itemDepth,
|
|
213
|
-
children: children
|
|
214
|
-
});
|
|
215
|
-
};
|
|
216
|
-
if (process.env.NODE_ENV !== "production") useTreeViewItems.wrapRoot.displayName = "useTreeViewItems.wrapRoot";
|
|
217
|
-
useTreeViewItems.params = {
|
|
218
|
-
disabledItemsFocusable: true,
|
|
219
|
-
items: true,
|
|
220
|
-
isItemDisabled: true,
|
|
221
|
-
getItemLabel: true,
|
|
222
|
-
getItemChildren: true,
|
|
223
|
-
getItemId: true,
|
|
224
|
-
onItemClick: true,
|
|
225
|
-
itemChildrenIndentation: true
|
|
226
|
-
};
|