@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
package/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @mui/x-tree-view v8.
|
|
2
|
+
* @mui/x-tree-view v8.24.0
|
|
3
3
|
*
|
|
4
4
|
* @license MIT
|
|
5
5
|
* This source code is licensed under the MIT license found in the
|
|
@@ -10,19 +10,9 @@
|
|
|
10
10
|
Object.defineProperty(exports, "__esModule", {
|
|
11
11
|
value: true
|
|
12
12
|
});
|
|
13
|
-
var _exportNames = {
|
|
14
|
-
unstable_resetCleanupTracking: true
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "unstable_resetCleanupTracking", {
|
|
17
|
-
enumerable: true,
|
|
18
|
-
get: function () {
|
|
19
|
-
return _useInstanceEventHandler.unstable_resetCleanupTracking;
|
|
20
|
-
}
|
|
21
|
-
});
|
|
22
13
|
var _SimpleTreeView = require("./SimpleTreeView");
|
|
23
14
|
Object.keys(_SimpleTreeView).forEach(function (key) {
|
|
24
15
|
if (key === "default" || key === "__esModule") return;
|
|
25
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
26
16
|
if (key in exports && exports[key] === _SimpleTreeView[key]) return;
|
|
27
17
|
Object.defineProperty(exports, key, {
|
|
28
18
|
enumerable: true,
|
|
@@ -34,7 +24,6 @@ Object.keys(_SimpleTreeView).forEach(function (key) {
|
|
|
34
24
|
var _RichTreeView = require("./RichTreeView");
|
|
35
25
|
Object.keys(_RichTreeView).forEach(function (key) {
|
|
36
26
|
if (key === "default" || key === "__esModule") return;
|
|
37
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
38
27
|
if (key in exports && exports[key] === _RichTreeView[key]) return;
|
|
39
28
|
Object.defineProperty(exports, key, {
|
|
40
29
|
enumerable: true,
|
|
@@ -46,7 +35,6 @@ Object.keys(_RichTreeView).forEach(function (key) {
|
|
|
46
35
|
var _TreeItem = require("./TreeItem");
|
|
47
36
|
Object.keys(_TreeItem).forEach(function (key) {
|
|
48
37
|
if (key === "default" || key === "__esModule") return;
|
|
49
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
50
38
|
if (key in exports && exports[key] === _TreeItem[key]) return;
|
|
51
39
|
Object.defineProperty(exports, key, {
|
|
52
40
|
enumerable: true,
|
|
@@ -58,7 +46,6 @@ Object.keys(_TreeItem).forEach(function (key) {
|
|
|
58
46
|
var _useTreeItem = require("./useTreeItem");
|
|
59
47
|
Object.keys(_useTreeItem).forEach(function (key) {
|
|
60
48
|
if (key === "default" || key === "__esModule") return;
|
|
61
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
62
49
|
if (key in exports && exports[key] === _useTreeItem[key]) return;
|
|
63
50
|
Object.defineProperty(exports, key, {
|
|
64
51
|
enumerable: true,
|
|
@@ -70,7 +57,6 @@ Object.keys(_useTreeItem).forEach(function (key) {
|
|
|
70
57
|
var _TreeItemIcon = require("./TreeItemIcon");
|
|
71
58
|
Object.keys(_TreeItemIcon).forEach(function (key) {
|
|
72
59
|
if (key === "default" || key === "__esModule") return;
|
|
73
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
74
60
|
if (key in exports && exports[key] === _TreeItemIcon[key]) return;
|
|
75
61
|
Object.defineProperty(exports, key, {
|
|
76
62
|
enumerable: true,
|
|
@@ -82,7 +68,6 @@ Object.keys(_TreeItemIcon).forEach(function (key) {
|
|
|
82
68
|
var _TreeItemProvider = require("./TreeItemProvider");
|
|
83
69
|
Object.keys(_TreeItemProvider).forEach(function (key) {
|
|
84
70
|
if (key === "default" || key === "__esModule") return;
|
|
85
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
86
71
|
if (key in exports && exports[key] === _TreeItemProvider[key]) return;
|
|
87
72
|
Object.defineProperty(exports, key, {
|
|
88
73
|
enumerable: true,
|
|
@@ -94,7 +79,6 @@ Object.keys(_TreeItemProvider).forEach(function (key) {
|
|
|
94
79
|
var _TreeItemDragAndDropOverlay = require("./TreeItemDragAndDropOverlay");
|
|
95
80
|
Object.keys(_TreeItemDragAndDropOverlay).forEach(function (key) {
|
|
96
81
|
if (key === "default" || key === "__esModule") return;
|
|
97
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
98
82
|
if (key in exports && exports[key] === _TreeItemDragAndDropOverlay[key]) return;
|
|
99
83
|
Object.defineProperty(exports, key, {
|
|
100
84
|
enumerable: true,
|
|
@@ -106,7 +90,6 @@ Object.keys(_TreeItemDragAndDropOverlay).forEach(function (key) {
|
|
|
106
90
|
var _TreeItemLabelInput = require("./TreeItemLabelInput");
|
|
107
91
|
Object.keys(_TreeItemLabelInput).forEach(function (key) {
|
|
108
92
|
if (key === "default" || key === "__esModule") return;
|
|
109
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
110
93
|
if (key in exports && exports[key] === _TreeItemLabelInput[key]) return;
|
|
111
94
|
Object.defineProperty(exports, key, {
|
|
112
95
|
enumerable: true,
|
|
@@ -115,11 +98,9 @@ Object.keys(_TreeItemLabelInput).forEach(function (key) {
|
|
|
115
98
|
}
|
|
116
99
|
});
|
|
117
100
|
});
|
|
118
|
-
var _useInstanceEventHandler = require("./internals/hooks/useInstanceEventHandler");
|
|
119
101
|
var _models = require("./models");
|
|
120
102
|
Object.keys(_models).forEach(function (key) {
|
|
121
103
|
if (key === "default" || key === "__esModule") return;
|
|
122
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
123
104
|
if (key in exports && exports[key] === _models[key]) return;
|
|
124
105
|
Object.defineProperty(exports, key, {
|
|
125
106
|
enumerable: true,
|
|
@@ -131,7 +112,6 @@ Object.keys(_models).forEach(function (key) {
|
|
|
131
112
|
var _icons = require("./icons");
|
|
132
113
|
Object.keys(_icons).forEach(function (key) {
|
|
133
114
|
if (key === "default" || key === "__esModule") return;
|
|
134
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
135
115
|
if (key in exports && exports[key] === _icons[key]) return;
|
|
136
116
|
Object.defineProperty(exports, key, {
|
|
137
117
|
enumerable: true,
|
|
@@ -143,7 +123,6 @@ Object.keys(_icons).forEach(function (key) {
|
|
|
143
123
|
var _hooks = require("./hooks");
|
|
144
124
|
Object.keys(_hooks).forEach(function (key) {
|
|
145
125
|
if (key === "default" || key === "__esModule") return;
|
|
146
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
147
126
|
if (key in exports && exports[key] === _hooks[key]) return;
|
|
148
127
|
Object.defineProperty(exports, key, {
|
|
149
128
|
enumerable: true,
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { Store } from '@mui/x-internals/store';
|
|
2
|
+
import { MinimalTreeViewParameters, TreeViewParametersToStateMapper, MinimalTreeViewState } from "./MinimalTreeViewStore.types.js";
|
|
3
|
+
import { TreeViewValidItem } from "../../models/index.js";
|
|
4
|
+
import { TimeoutManager } from "./TimeoutManager.js";
|
|
5
|
+
import { TreeViewKeyboardNavigationPlugin } from "../plugins/keyboardNavigation/index.js";
|
|
6
|
+
import { TreeViewFocusPlugin } from "../plugins/focus/TreeViewFocusPlugin.js";
|
|
7
|
+
import { TreeViewItemsPlugin } from "../plugins/items/TreeViewItemsPlugin.js";
|
|
8
|
+
import { TreeViewSelectionPlugin } from "../plugins/selection/TreeViewSelectionPlugin.js";
|
|
9
|
+
import { TreeViewExpansionPlugin } from "../plugins/expansion/index.js";
|
|
10
|
+
import { TreeViewItemPluginManager } from "./TreeViewItemPluginManager.js";
|
|
11
|
+
import { TreeViewEventEvent, TreeViewEventListener, TreeViewEventParameters, TreeViewEvents } from "../models/index.js";
|
|
12
|
+
export declare class MinimalTreeViewStore<R extends TreeViewValidItem<R>, Multiple extends boolean | undefined, State extends MinimalTreeViewState<R, Multiple> = MinimalTreeViewState<R, Multiple>, Parameters extends MinimalTreeViewParameters<R, Multiple> = MinimalTreeViewParameters<R, Multiple>> extends Store<State> {
|
|
13
|
+
private initialParameters;
|
|
14
|
+
private mapper;
|
|
15
|
+
private eventManager;
|
|
16
|
+
instanceName: string;
|
|
17
|
+
parameters: Parameters;
|
|
18
|
+
timeoutManager: TimeoutManager;
|
|
19
|
+
itemPluginManager: TreeViewItemPluginManager<this>;
|
|
20
|
+
items: TreeViewItemsPlugin<R>;
|
|
21
|
+
focus: TreeViewFocusPlugin;
|
|
22
|
+
expansion: TreeViewExpansionPlugin;
|
|
23
|
+
selection: TreeViewSelectionPlugin<Multiple>;
|
|
24
|
+
keyboardNavigation: TreeViewKeyboardNavigationPlugin;
|
|
25
|
+
constructor(parameters: Parameters, instanceName: string, mapper: TreeViewParametersToStateMapper<R, Multiple, State, Parameters>);
|
|
26
|
+
/**
|
|
27
|
+
* Builds an object containing the method that should be exposed publicly by the Tree View components.
|
|
28
|
+
*/
|
|
29
|
+
buildPublicAPI(): {
|
|
30
|
+
setItemSelection: ({
|
|
31
|
+
itemId,
|
|
32
|
+
event,
|
|
33
|
+
keepExistingSelection,
|
|
34
|
+
shouldBeSelected
|
|
35
|
+
}: {
|
|
36
|
+
itemId: string;
|
|
37
|
+
event?: React.SyntheticEvent | null;
|
|
38
|
+
shouldBeSelected?: boolean;
|
|
39
|
+
keepExistingSelection?: boolean;
|
|
40
|
+
}) => void;
|
|
41
|
+
isItemExpanded: (itemId: import("../../index.js").TreeViewItemId) => boolean;
|
|
42
|
+
setItemExpansion: ({
|
|
43
|
+
itemId,
|
|
44
|
+
event,
|
|
45
|
+
shouldBeExpanded
|
|
46
|
+
}: {
|
|
47
|
+
itemId: import("../../index.js").TreeViewItemId;
|
|
48
|
+
event?: React.SyntheticEvent | null;
|
|
49
|
+
shouldBeExpanded?: boolean;
|
|
50
|
+
}) => void;
|
|
51
|
+
focusItem: (event: React.SyntheticEvent | null, itemId: import("../../index.js").TreeViewItemId) => void;
|
|
52
|
+
getItem: (itemId: import("../../index.js").TreeViewItemId) => R;
|
|
53
|
+
getItemDOMElement: (itemId: import("../../index.js").TreeViewItemId) => HTMLElement | null;
|
|
54
|
+
getItemOrderedChildrenIds: (itemId: import("../../index.js").TreeViewItemId | null) => import("../../index.js").TreeViewItemId[];
|
|
55
|
+
getItemTree: () => R[];
|
|
56
|
+
getParentId: (itemId: import("../../index.js").TreeViewItemId) => import("../../index.js").TreeViewItemId | null;
|
|
57
|
+
setIsItemDisabled: ({
|
|
58
|
+
itemId,
|
|
59
|
+
shouldBeDisabled
|
|
60
|
+
}: {
|
|
61
|
+
itemId: import("../../index.js").TreeViewItemId;
|
|
62
|
+
shouldBeDisabled?: boolean;
|
|
63
|
+
}) => void;
|
|
64
|
+
};
|
|
65
|
+
/**
|
|
66
|
+
* Updates the state of the Tree View based on the new parameters provided to the root component.
|
|
67
|
+
*/
|
|
68
|
+
updateStateFromParameters(parameters: Parameters): void;
|
|
69
|
+
/**
|
|
70
|
+
* Returns a cleanup function that need to be called when the store is destroyed.
|
|
71
|
+
*/
|
|
72
|
+
disposeEffect: () => () => void;
|
|
73
|
+
/**
|
|
74
|
+
* Whether updates based on `props.items` change should be ignored.
|
|
75
|
+
*/
|
|
76
|
+
shouldIgnoreItemsStateUpdate: () => boolean;
|
|
77
|
+
/**
|
|
78
|
+
* Registers an effect to be run when the value returned by the selector changes.
|
|
79
|
+
*/
|
|
80
|
+
registerStoreEffect: <Value>(selector: (state: State) => Value, effect: (previous: Value, next: Value) => void) => void;
|
|
81
|
+
/**
|
|
82
|
+
* Publishes an event to all its subscribers.
|
|
83
|
+
*/
|
|
84
|
+
publishEvent: <E extends TreeViewEvents>(name: E, params: TreeViewEventParameters<E>, event: TreeViewEventEvent<E>) => void;
|
|
85
|
+
/**
|
|
86
|
+
* Subscribe to an event emitted by the store.
|
|
87
|
+
* For now, the subscription is only removed when the store is destroyed.
|
|
88
|
+
*/
|
|
89
|
+
subscribeEvent: <E extends TreeViewEvents>(eventName: E, handler: TreeViewEventListener<E>) => void;
|
|
90
|
+
}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.MinimalTreeViewStore = void 0;
|
|
8
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
9
|
+
var _store = require("@mui/x-internals/store");
|
|
10
|
+
var _warning = require("@mui/x-internals/warning");
|
|
11
|
+
var _EventManager = require("@mui/x-internals/EventManager");
|
|
12
|
+
var _MinimalTreeViewStore = require("./MinimalTreeViewStore.utils");
|
|
13
|
+
var _TimeoutManager = require("./TimeoutManager");
|
|
14
|
+
var _keyboardNavigation = require("../plugins/keyboardNavigation");
|
|
15
|
+
var _TreeViewFocusPlugin = require("../plugins/focus/TreeViewFocusPlugin");
|
|
16
|
+
var _TreeViewItemsPlugin = require("../plugins/items/TreeViewItemsPlugin");
|
|
17
|
+
var _TreeViewSelectionPlugin = require("../plugins/selection/TreeViewSelectionPlugin");
|
|
18
|
+
var _expansion = require("../plugins/expansion");
|
|
19
|
+
var _TreeViewItemPluginManager = require("./TreeViewItemPluginManager");
|
|
20
|
+
class MinimalTreeViewStore extends _store.Store {
|
|
21
|
+
initialParameters = null;
|
|
22
|
+
eventManager = new _EventManager.EventManager();
|
|
23
|
+
timeoutManager = new _TimeoutManager.TimeoutManager();
|
|
24
|
+
itemPluginManager = new _TreeViewItemPluginManager.TreeViewItemPluginManager();
|
|
25
|
+
constructor(parameters, instanceName, mapper) {
|
|
26
|
+
const minimalInitialState = (0, _MinimalTreeViewStore.createMinimalInitialState)(parameters);
|
|
27
|
+
const initialState = mapper.getInitialState(minimalInitialState, parameters);
|
|
28
|
+
super(initialState);
|
|
29
|
+
this.parameters = parameters;
|
|
30
|
+
this.instanceName = instanceName;
|
|
31
|
+
this.mapper = mapper;
|
|
32
|
+
|
|
33
|
+
// We mount the plugins in the constructor to make sure all the methods of the store are available to the plugins during their construction.
|
|
34
|
+
this.items = new _TreeViewItemsPlugin.TreeViewItemsPlugin(this);
|
|
35
|
+
this.focus = new _TreeViewFocusPlugin.TreeViewFocusPlugin(this);
|
|
36
|
+
this.expansion = new _expansion.TreeViewExpansionPlugin(this);
|
|
37
|
+
this.selection = new _TreeViewSelectionPlugin.TreeViewSelectionPlugin(this);
|
|
38
|
+
this.keyboardNavigation = new _keyboardNavigation.TreeViewKeyboardNavigationPlugin(this);
|
|
39
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
40
|
+
this.initialParameters = parameters;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Builds an object containing the method that should be exposed publicly by the Tree View components.
|
|
46
|
+
*/
|
|
47
|
+
buildPublicAPI() {
|
|
48
|
+
return (0, _extends2.default)({}, this.items.buildPublicAPI(), this.focus.buildPublicAPI(), this.expansion.buildPublicAPI(), this.selection.buildPublicAPI());
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* Updates the state of the Tree View based on the new parameters provided to the root component.
|
|
53
|
+
*/
|
|
54
|
+
updateStateFromParameters(parameters) {
|
|
55
|
+
const updateModel = (mutableNewState, controlledProp, defaultProp) => {
|
|
56
|
+
if (parameters[controlledProp] !== undefined) {
|
|
57
|
+
mutableNewState[controlledProp] = parameters[controlledProp];
|
|
58
|
+
}
|
|
59
|
+
if (process.env.NODE_ENV !== 'production') {
|
|
60
|
+
const defaultValue = parameters[defaultProp];
|
|
61
|
+
const isControlled = parameters[controlledProp] !== undefined;
|
|
62
|
+
const initialDefaultValue = this.initialParameters?.[defaultProp];
|
|
63
|
+
const initialIsControlled = this.initialParameters?.[controlledProp] !== undefined;
|
|
64
|
+
if (initialIsControlled !== isControlled) {
|
|
65
|
+
(0, _warning.warnOnce)([`MUI X Tree View: A component is changing the ${initialIsControlled ? '' : 'un'}controlled ${controlledProp} state of ${this.instanceName} to be ${initialIsControlled ? 'un' : ''}controlled.`, 'Elements should not switch from uncontrolled to controlled (or vice versa).', `Decide between using a controlled or uncontrolled ${controlledProp} element for the lifetime of the component.`, "The nature of the state is determined during the first render. It's considered controlled if the value is not `undefined`.", 'More info: https://fb.me/react-controlled-components'], 'error');
|
|
66
|
+
} else if (JSON.stringify(initialDefaultValue) !== JSON.stringify(defaultValue)) {
|
|
67
|
+
(0, _warning.warnOnce)([`MUI X Tree View: A component is changing the default ${controlledProp} state of an uncontrolled ${this.instanceName} after being initialized. `, `To suppress this warning opt to use a controlled ${this.instanceName}.`], 'error');
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
const newMinimalState = (0, _MinimalTreeViewStore.deriveStateFromParameters)(parameters);
|
|
72
|
+
updateModel(newMinimalState, 'expandedItems', 'defaultExpandedItems');
|
|
73
|
+
updateModel(newMinimalState, 'selectedItems', 'defaultSelectedItems');
|
|
74
|
+
if (this.state.providedTreeId !== parameters.id || this.state.treeId === undefined) {
|
|
75
|
+
newMinimalState.treeId = (0, _MinimalTreeViewStore.createTreeViewDefaultId)();
|
|
76
|
+
}
|
|
77
|
+
if (!this.mapper.shouldIgnoreItemsStateUpdate(parameters) && _TreeViewItemsPlugin.TreeViewItemsPlugin.shouldRebuildItemsState(parameters, this.parameters)) {
|
|
78
|
+
Object.assign(newMinimalState, _TreeViewItemsPlugin.TreeViewItemsPlugin.buildItemsStateIfNeeded(parameters));
|
|
79
|
+
}
|
|
80
|
+
const newState = this.mapper.updateStateFromParameters(newMinimalState, parameters, updateModel);
|
|
81
|
+
this.update(newState);
|
|
82
|
+
this.parameters = parameters;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Returns a cleanup function that need to be called when the store is destroyed.
|
|
87
|
+
*/
|
|
88
|
+
disposeEffect = () => {
|
|
89
|
+
return this.timeoutManager.clearAll;
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
/**
|
|
93
|
+
* Whether updates based on `props.items` change should be ignored.
|
|
94
|
+
*/
|
|
95
|
+
shouldIgnoreItemsStateUpdate = () => {
|
|
96
|
+
return this.mapper.shouldIgnoreItemsStateUpdate(this.parameters);
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* Registers an effect to be run when the value returned by the selector changes.
|
|
101
|
+
*/
|
|
102
|
+
registerStoreEffect = (selector, effect) => {
|
|
103
|
+
let previousValue = selector(this.state);
|
|
104
|
+
this.subscribe(state => {
|
|
105
|
+
const nextValue = selector(state);
|
|
106
|
+
if (nextValue !== previousValue) {
|
|
107
|
+
effect(previousValue, nextValue);
|
|
108
|
+
previousValue = nextValue;
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Publishes an event to all its subscribers.
|
|
115
|
+
*/
|
|
116
|
+
publishEvent = (name, params, event) => {
|
|
117
|
+
if (isSyntheticEvent(event) && event.isPropagationStopped()) {
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
this.eventManager.emit(name, params, event);
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* Subscribe to an event emitted by the store.
|
|
125
|
+
* For now, the subscription is only removed when the store is destroyed.
|
|
126
|
+
*/
|
|
127
|
+
subscribeEvent = (eventName, handler) => {
|
|
128
|
+
this.eventManager.on(eventName, handler);
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
exports.MinimalTreeViewStore = MinimalTreeViewStore;
|
|
132
|
+
function isSyntheticEvent(event) {
|
|
133
|
+
return event.isPropagationStopped !== undefined;
|
|
134
|
+
}
|
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
import { TreeViewItemId, TreeViewSelectionPropagation, TreeViewValidItem } from "../../models/index.js";
|
|
2
|
+
import { TreeViewItemMeta } from "../models/index.js";
|
|
3
|
+
export interface MinimalTreeViewState<R extends TreeViewValidItem<R>, Multiple extends boolean | undefined> {
|
|
4
|
+
/**
|
|
5
|
+
* Whether the button should be focusable when disabled.
|
|
6
|
+
* Always equal to `props.disabledItemsFocusable` (or `false` if not provided).
|
|
7
|
+
*/
|
|
8
|
+
disabledItemsFocusable: boolean;
|
|
9
|
+
/**
|
|
10
|
+
* Model of each item as provided by `props.items` or by imperative items updates.
|
|
11
|
+
* It is not updated when properties derived from the model are updated:
|
|
12
|
+
* - when the label of an item is updated, `itemMetaLookup` is updated, not `itemModelLookup`.
|
|
13
|
+
* - when the children of an item are updated, `itemOrderedChildrenIdsLookup` and `itemChildrenIndexesLookup` are updated, not `itemModelLookup`.
|
|
14
|
+
* This means that the `children`, `label` or `id` properties of an item model should never be used directly, always use the structured sub-states instead.
|
|
15
|
+
*/
|
|
16
|
+
itemModelLookup: {
|
|
17
|
+
[itemId: string]: R;
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Meta data of each item.
|
|
21
|
+
*/
|
|
22
|
+
itemMetaLookup: {
|
|
23
|
+
[itemId: string]: TreeViewItemMeta;
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* Ordered children ids of each item.
|
|
27
|
+
*/
|
|
28
|
+
itemOrderedChildrenIdsLookup: {
|
|
29
|
+
[parentItemId: string]: TreeViewItemId[];
|
|
30
|
+
};
|
|
31
|
+
/**
|
|
32
|
+
* Index of each child in the ordered children ids of its parent.
|
|
33
|
+
*/
|
|
34
|
+
itemChildrenIndexesLookup: {
|
|
35
|
+
[parentItemId: string]: {
|
|
36
|
+
[itemId: string]: number;
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
/**
|
|
40
|
+
* When equal to 'flat', the tree is rendered as a flat list (children are rendered as siblings of their parents).
|
|
41
|
+
* When equal to 'nested', the tree is rendered with nested children (children are rendered inside the groupTransition slot of their children).
|
|
42
|
+
* Nested DOM structure is not compatible with collapse / expansion animations.
|
|
43
|
+
*/
|
|
44
|
+
domStructure: 'flat' | 'nested';
|
|
45
|
+
/**
|
|
46
|
+
* Horizontal indentation between an item and its children.
|
|
47
|
+
* Examples: 24, "24px", "2rem", "2em".
|
|
48
|
+
*/
|
|
49
|
+
itemChildrenIndentation: string | number;
|
|
50
|
+
/**
|
|
51
|
+
* The id of the Tree View as provided by the `id` parameter.
|
|
52
|
+
*/
|
|
53
|
+
providedTreeId: string | undefined;
|
|
54
|
+
/**
|
|
55
|
+
* The id of the Tree View used for accessibility attributes.
|
|
56
|
+
*/
|
|
57
|
+
treeId: string | undefined;
|
|
58
|
+
/**
|
|
59
|
+
* The ids of the items currently expanded.
|
|
60
|
+
*/
|
|
61
|
+
expandedItems: readonly TreeViewItemId[];
|
|
62
|
+
/**
|
|
63
|
+
* The slot that triggers the item's expansion when clicked.
|
|
64
|
+
*/
|
|
65
|
+
expansionTrigger: 'content' | 'iconContainer';
|
|
66
|
+
/**
|
|
67
|
+
* The ids of the items currently selected.
|
|
68
|
+
*/
|
|
69
|
+
selectedItems: TreeViewSelectionReadonlyValue<Multiple>;
|
|
70
|
+
/**
|
|
71
|
+
* Whether selection is disabled.
|
|
72
|
+
*/
|
|
73
|
+
disableSelection: boolean;
|
|
74
|
+
/**
|
|
75
|
+
* Whether multi-selection is enabled.
|
|
76
|
+
*/
|
|
77
|
+
multiSelect: boolean;
|
|
78
|
+
/**
|
|
79
|
+
* Whether the Tree View renders a checkbox at the left of its label that allows selecting it.
|
|
80
|
+
*/
|
|
81
|
+
checkboxSelection: boolean;
|
|
82
|
+
/**
|
|
83
|
+
* The selection propagation behavior.
|
|
84
|
+
*/
|
|
85
|
+
selectionPropagation: TreeViewSelectionPropagation;
|
|
86
|
+
/**
|
|
87
|
+
* The id of the currently focused item.
|
|
88
|
+
*/
|
|
89
|
+
focusedItemId: TreeViewItemId | null;
|
|
90
|
+
}
|
|
91
|
+
export interface MinimalTreeViewParameters<R extends TreeViewValidItem<R>, Multiple extends boolean | undefined> {
|
|
92
|
+
/**
|
|
93
|
+
* Whether the layout is right-to-left.
|
|
94
|
+
*/
|
|
95
|
+
isRtl: boolean;
|
|
96
|
+
/**
|
|
97
|
+
* Whether the items should be focusable when disabled.
|
|
98
|
+
* @default false
|
|
99
|
+
*/
|
|
100
|
+
disabledItemsFocusable?: boolean;
|
|
101
|
+
items: readonly R[];
|
|
102
|
+
/**
|
|
103
|
+
* Used to determine if a given item should be disabled.
|
|
104
|
+
* @template R
|
|
105
|
+
* @param {R} item The item to check.
|
|
106
|
+
* @returns {boolean} `true` if the item should be disabled.
|
|
107
|
+
*/
|
|
108
|
+
isItemDisabled?: (item: R) => boolean;
|
|
109
|
+
/**
|
|
110
|
+
* Used to determine if a given item should have selection disabled.
|
|
111
|
+
* @template R
|
|
112
|
+
* @param {R} item The item to check.
|
|
113
|
+
* @returns {boolean} `true` if the item should have selection disabled.
|
|
114
|
+
*/
|
|
115
|
+
isItemSelectionDisabled?: (item: R) => boolean;
|
|
116
|
+
/**
|
|
117
|
+
* Used to determine the string label for a given item.
|
|
118
|
+
*
|
|
119
|
+
* @template R
|
|
120
|
+
* @param {R} item The item to check.
|
|
121
|
+
* @returns {string} The label of the item.
|
|
122
|
+
* @default (item) => item.label
|
|
123
|
+
*/
|
|
124
|
+
getItemLabel?: (item: R) => string;
|
|
125
|
+
/**
|
|
126
|
+
* Used to determine the children of a given item.
|
|
127
|
+
*
|
|
128
|
+
* @template R
|
|
129
|
+
* @param {R} item The item to check.
|
|
130
|
+
* @returns {R[]} The children of the item.
|
|
131
|
+
* @default (item) => item.children
|
|
132
|
+
*/
|
|
133
|
+
getItemChildren?: (item: R) => R[] | undefined;
|
|
134
|
+
/**
|
|
135
|
+
* Used to determine the id of a given item.
|
|
136
|
+
*
|
|
137
|
+
* @template R
|
|
138
|
+
* @param {R} item The item to check.
|
|
139
|
+
* @returns {TreeViewItemId} The id of the item.
|
|
140
|
+
* @default (item) => item.id
|
|
141
|
+
*/
|
|
142
|
+
getItemId?: (item: R) => TreeViewItemId;
|
|
143
|
+
/**
|
|
144
|
+
* Callback fired when the `content` slot of a given Tree Item is clicked.
|
|
145
|
+
* @param {React.MouseEvent} event The DOM event that triggered the change.
|
|
146
|
+
* @param {TreeViewItemId} itemId The id of the focused item.
|
|
147
|
+
*/
|
|
148
|
+
onItemClick?: (event: React.MouseEvent, itemId: TreeViewItemId) => void;
|
|
149
|
+
/**
|
|
150
|
+
* Horizontal indentation between an item and its children.
|
|
151
|
+
* Examples: 24, "24px", "2rem", "2em".
|
|
152
|
+
* @default 12px
|
|
153
|
+
*/
|
|
154
|
+
itemChildrenIndentation?: string | number;
|
|
155
|
+
/**
|
|
156
|
+
* This prop is used to help implement the accessibility logic.
|
|
157
|
+
* If you don't provide this prop. It falls back to a randomly generated id.
|
|
158
|
+
*/
|
|
159
|
+
id?: string;
|
|
160
|
+
/**
|
|
161
|
+
* Expanded item ids.
|
|
162
|
+
* Used when the item's expansion is controlled.
|
|
163
|
+
*/
|
|
164
|
+
expandedItems?: readonly TreeViewItemId[];
|
|
165
|
+
/**
|
|
166
|
+
* Expanded item ids.
|
|
167
|
+
* Used when the item's expansion is not controlled.
|
|
168
|
+
* @default []
|
|
169
|
+
*/
|
|
170
|
+
defaultExpandedItems?: readonly TreeViewItemId[];
|
|
171
|
+
/**
|
|
172
|
+
* Callback fired when Tree Items are expanded/collapsed.
|
|
173
|
+
* @param {React.SyntheticEvent} event The DOM event that triggered the change. Can be null when the change is caused by the `publicAPI.setItemExpansion()` method.
|
|
174
|
+
* @param {TreeViewItemId[]} itemIds The ids of the expanded items.
|
|
175
|
+
*/
|
|
176
|
+
onExpandedItemsChange?: (event: React.SyntheticEvent | null, itemIds: TreeViewItemId[]) => void;
|
|
177
|
+
/**
|
|
178
|
+
* Callback fired when a Tree Item is expanded or collapsed.
|
|
179
|
+
* @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.
|
|
180
|
+
* @param {TreeViewItemId} itemId The itemId of the modified item.
|
|
181
|
+
* @param {boolean} isExpanded `true` if the item has just been expanded, `false` if it has just been collapsed.
|
|
182
|
+
*/
|
|
183
|
+
onItemExpansionToggle?: (event: React.SyntheticEvent | null, itemId: TreeViewItemId, isExpanded: boolean) => void;
|
|
184
|
+
/**
|
|
185
|
+
* The slot that triggers the item's expansion when clicked.
|
|
186
|
+
* @default 'content'
|
|
187
|
+
*/
|
|
188
|
+
expansionTrigger?: 'content' | 'iconContainer';
|
|
189
|
+
/**
|
|
190
|
+
* Whether selection is disabled.
|
|
191
|
+
* @default false
|
|
192
|
+
*/
|
|
193
|
+
disableSelection?: boolean;
|
|
194
|
+
/**
|
|
195
|
+
* Selected item ids. (Controlled)
|
|
196
|
+
* When `multiSelect` is true this takes an array of strings; when false (default) a string.
|
|
197
|
+
*/
|
|
198
|
+
selectedItems?: TreeViewSelectionReadonlyValue<Multiple>;
|
|
199
|
+
/**
|
|
200
|
+
* Selected item ids. (Uncontrolled)
|
|
201
|
+
* When `multiSelect` is true this takes an array of strings; when false (default) a string.
|
|
202
|
+
* @default []
|
|
203
|
+
*/
|
|
204
|
+
defaultSelectedItems?: TreeViewSelectionReadonlyValue<Multiple>;
|
|
205
|
+
/**
|
|
206
|
+
* Whether multiple items can be selected.
|
|
207
|
+
* @default false
|
|
208
|
+
*/
|
|
209
|
+
multiSelect?: Multiple;
|
|
210
|
+
/**
|
|
211
|
+
* Whether the Tree View renders a checkbox at the left of its label that allows selecting it.
|
|
212
|
+
* @default false
|
|
213
|
+
*/
|
|
214
|
+
checkboxSelection?: boolean;
|
|
215
|
+
/**
|
|
216
|
+
* When `selectionPropagation.descendants` is set to `true`.
|
|
217
|
+
*
|
|
218
|
+
* - Selecting a parent selects all its descendants automatically.
|
|
219
|
+
* - Deselecting a parent deselects all its descendants automatically.
|
|
220
|
+
*
|
|
221
|
+
* When `selectionPropagation.parents` is set to `true`.
|
|
222
|
+
*
|
|
223
|
+
* - Selecting all the descendants of a parent selects the parent automatically.
|
|
224
|
+
* - Deselecting a descendant of a selected parent deselects the parent automatically.
|
|
225
|
+
*
|
|
226
|
+
* Only works when `multiSelect` is `true`.
|
|
227
|
+
* On the <SimpleTreeView />, only the expanded items are considered (since the collapsed item are not passed to the Tree View component at all)
|
|
228
|
+
*
|
|
229
|
+
* @default { parents: false, descendants: false }
|
|
230
|
+
*/
|
|
231
|
+
selectionPropagation?: TreeViewSelectionPropagation;
|
|
232
|
+
/**
|
|
233
|
+
* Callback fired when Tree Items are selected/deselected.
|
|
234
|
+
* @param {React.SyntheticEvent} event The DOM event that triggered the change. Can be null when the change is caused by the `publicAPI.setItemSelection()` method.
|
|
235
|
+
* @param {TreeViewItemId[] | TreeViewItemId} itemIds The ids of the selected items.
|
|
236
|
+
* When `multiSelect` is `true`, this is an array of strings; when false (default) a string.
|
|
237
|
+
*/
|
|
238
|
+
onSelectedItemsChange?: (event: React.SyntheticEvent | null, itemIds: TreeViewSelectionValue<Multiple>) => void;
|
|
239
|
+
/**
|
|
240
|
+
* Callback fired when a Tree Item is selected or deselected.
|
|
241
|
+
* @param {React.SyntheticEvent} event The DOM event that triggered the change. Can be null when the change is caused by the `publicAPI.setItemSelection()` method.
|
|
242
|
+
* @param {TreeViewItemId} itemId The itemId of the modified item.
|
|
243
|
+
* @param {boolean} isSelected `true` if the item has just been selected, `false` if it has just been deselected.
|
|
244
|
+
*/
|
|
245
|
+
onItemSelectionToggle?: (event: React.SyntheticEvent | null, itemId: TreeViewItemId, isSelected: boolean) => void;
|
|
246
|
+
/**
|
|
247
|
+
* Callback fired when a given Tree Item is focused.
|
|
248
|
+
* @param {React.SyntheticEvent | null} event The DOM event that triggered the change. **Warning**: This is a generic event not a focus event.
|
|
249
|
+
* @param {TreeViewItemId} itemId The id of the focused item.
|
|
250
|
+
*/
|
|
251
|
+
onItemFocus?: (event: React.SyntheticEvent | null, itemId: TreeViewItemId) => void;
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Mapper between a Tree View instance's state and parameters.
|
|
255
|
+
* Used by classes extending `TreeViewStore` to manage the state based on the parameters.
|
|
256
|
+
*/
|
|
257
|
+
export interface TreeViewParametersToStateMapper<R extends TreeViewValidItem<R>, Multiple extends boolean | undefined, State extends MinimalTreeViewState<R, Multiple>, Parameters extends MinimalTreeViewParameters<R, Multiple>> {
|
|
258
|
+
getInitialState: (treeViewInitialState: MinimalTreeViewState<R, Multiple>, parameters: Parameters) => State;
|
|
259
|
+
updateStateFromParameters: (newState: Partial<MinimalTreeViewState<R, Multiple>>, parameters: Parameters, updateModel: TreeViewModelUpdater<State, Parameters>) => Partial<State>;
|
|
260
|
+
shouldIgnoreItemsStateUpdate: (parameters: Parameters) => boolean;
|
|
261
|
+
}
|
|
262
|
+
export type TreeViewModelUpdater<State extends MinimalTreeViewState<any, any>, Parameters extends MinimalTreeViewParameters<any, any>> = (newState: Partial<State>, controlledProp: keyof Parameters & keyof State & string, defaultProp: keyof Parameters) => void;
|
|
263
|
+
export type TreeViewSelectionReadonlyValue<Multiple extends boolean | undefined> = Multiple extends true ? Multiple extends false ?
|
|
264
|
+
// Multiple === boolean, the type cannot be simplified further
|
|
265
|
+
TreeViewItemId | null | readonly TreeViewItemId[] : readonly TreeViewItemId[] :
|
|
266
|
+
// Multiple === false | undefined, the selection is single
|
|
267
|
+
TreeViewItemId | null;
|
|
268
|
+
export type TreeViewSelectionValue<Multiple extends boolean | undefined> = Multiple extends true ? Multiple extends false ?
|
|
269
|
+
// Multiple === boolean, the type cannot be simplified further
|
|
270
|
+
TreeViewItemId | null | TreeViewItemId[] : TreeViewItemId[] :
|
|
271
|
+
// Multiple === false | undefined, the selection is single
|
|
272
|
+
TreeViewItemId | null;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { TreeViewValidItem } from "../../models/index.js";
|
|
2
|
+
import { MinimalTreeViewParameters, MinimalTreeViewState } from "./MinimalTreeViewStore.types.js";
|
|
3
|
+
/**
|
|
4
|
+
* Returns the properties of the state that are derived from the parameters.
|
|
5
|
+
* This do not contain state properties that don't update whenever the parameters update.
|
|
6
|
+
*/
|
|
7
|
+
export declare function deriveStateFromParameters<R extends TreeViewValidItem<R>, Multiple extends boolean | undefined>(parameters: MinimalTreeViewParameters<R, Multiple> & {
|
|
8
|
+
isItemEditable?: any;
|
|
9
|
+
}): {
|
|
10
|
+
disabledItemsFocusable: boolean;
|
|
11
|
+
domStructure: "nested";
|
|
12
|
+
itemChildrenIndentation: string | number;
|
|
13
|
+
providedTreeId: string | undefined;
|
|
14
|
+
expansionTrigger: "content" | "iconContainer";
|
|
15
|
+
disableSelection: boolean;
|
|
16
|
+
multiSelect: boolean | NonNullable<Multiple>;
|
|
17
|
+
checkboxSelection: boolean;
|
|
18
|
+
selectionPropagation: Readonly<{}>;
|
|
19
|
+
};
|
|
20
|
+
export declare function createMinimalInitialState<R extends TreeViewValidItem<R>, Multiple extends boolean | undefined>(parameters: MinimalTreeViewParameters<R, Multiple>): MinimalTreeViewState<R, Multiple>;
|
|
21
|
+
export declare const createTreeViewDefaultId: () => string;
|