@mui/x-tree-view 8.0.0-beta.2 → 8.0.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 +423 -96
- package/RichTreeView/RichTreeView.js +11 -6
- package/RichTreeView/RichTreeView.plugins.d.ts +3 -6
- package/RichTreeView/RichTreeView.plugins.js +1 -2
- package/RichTreeView/RichTreeView.types.d.ts +4 -3
- package/RichTreeView/index.d.ts +1 -1
- package/SimpleTreeView/SimpleTreeView.js +12 -8
- package/SimpleTreeView/SimpleTreeView.plugins.d.ts +3 -6
- package/SimpleTreeView/SimpleTreeView.plugins.js +1 -2
- package/SimpleTreeView/SimpleTreeView.types.d.ts +4 -3
- package/TreeItemIcon/TreeItemIcon.js +15 -11
- package/esm/RichTreeView/RichTreeView.js +10 -5
- package/esm/RichTreeView/RichTreeView.plugins.d.ts +3 -6
- package/esm/RichTreeView/RichTreeView.plugins.js +1 -2
- package/esm/RichTreeView/RichTreeView.types.d.ts +4 -3
- package/esm/RichTreeView/index.d.ts +1 -1
- package/esm/SimpleTreeView/SimpleTreeView.js +11 -7
- package/esm/SimpleTreeView/SimpleTreeView.plugins.d.ts +3 -6
- package/esm/SimpleTreeView/SimpleTreeView.plugins.js +1 -2
- package/esm/SimpleTreeView/SimpleTreeView.types.d.ts +4 -3
- package/esm/TreeItemIcon/TreeItemIcon.js +15 -11
- package/esm/hooks/useTreeItemUtils/useTreeItemUtils.js +1 -1
- package/esm/index.js +1 -1
- package/esm/internals/TreeViewProvider/TreeViewContext.d.ts +1 -1
- package/esm/internals/TreeViewProvider/TreeViewProvider.js +14 -4
- package/esm/internals/TreeViewProvider/TreeViewProvider.types.d.ts +6 -5
- package/esm/internals/TreeViewProvider/TreeViewStyleContext.d.ts +23 -0
- package/esm/internals/TreeViewProvider/TreeViewStyleContext.js +3 -1
- package/esm/internals/hooks/useSelector.js +1 -4
- package/esm/internals/index.d.ts +2 -3
- package/esm/internals/index.js +1 -1
- package/esm/internals/models/events.d.ts +2 -6
- package/esm/internals/models/plugin.d.ts +63 -38
- package/esm/internals/models/treeView.d.ts +0 -5
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.js +35 -21
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.d.ts +144 -10
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.js +21 -1
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.d.ts +1 -1
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.d.ts +0 -1
- package/esm/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.js +0 -7
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.js +3 -30
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.d.ts +476 -28
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.js +21 -1
- package/esm/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.d.ts +0 -1
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.d.ts +90 -4
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.js +12 -25
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.utils.d.ts +12 -1
- package/esm/internals/plugins/useTreeViewItems/useTreeViewItems.utils.js +31 -0
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.js +3 -6
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.d.ts +43 -9
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.js +12 -2
- package/esm/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.d.ts +1 -1
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.itemPlugin.js +2 -2
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.js +39 -40
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.d.ts +186 -30
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.js +36 -1
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.d.ts +3 -6
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.d.ts +0 -7
- package/esm/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.js +5 -24
- package/esm/internals/useTreeView/extractPluginParamsFromProps.d.ts +0 -2
- package/esm/internals/useTreeView/extractPluginParamsFromProps.js +1 -5
- package/esm/internals/useTreeView/useTreeView.d.ts +10 -1
- package/esm/internals/useTreeView/useTreeView.js +22 -25
- package/esm/internals/useTreeView/useTreeView.types.d.ts +1 -3
- package/esm/internals/useTreeView/useTreeViewBuildContext.js +9 -11
- package/esm/internals/utils/models.d.ts +7 -0
- package/esm/internals/utils/models.js +23 -0
- package/esm/internals/utils/selectors.d.ts +1 -1
- package/esm/utils/cache.d.ts +1 -1
- package/esm/utils/cache.js +1 -1
- package/hooks/useTreeItemUtils/useTreeItemUtils.js +1 -1
- package/index.js +1 -1
- package/internals/TreeViewProvider/TreeViewContext.d.ts +1 -1
- package/internals/TreeViewProvider/TreeViewProvider.js +14 -4
- package/internals/TreeViewProvider/TreeViewProvider.types.d.ts +6 -5
- package/internals/TreeViewProvider/TreeViewStyleContext.d.ts +23 -0
- package/internals/TreeViewProvider/TreeViewStyleContext.js +3 -1
- package/internals/hooks/useSelector.js +1 -5
- package/internals/index.d.ts +2 -3
- package/internals/index.js +13 -7
- package/internals/models/events.d.ts +2 -6
- package/internals/models/plugin.d.ts +63 -38
- package/internals/models/treeView.d.ts +0 -5
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.js +33 -19
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.d.ts +144 -10
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.js +22 -2
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.d.ts +1 -1
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.d.ts +0 -1
- package/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.js +1 -9
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.js +2 -30
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.d.ts +476 -28
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.js +21 -1
- package/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.d.ts +0 -1
- package/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.d.ts +90 -4
- package/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.js +12 -25
- package/internals/plugins/useTreeViewItems/useTreeViewItems.utils.d.ts +12 -1
- package/internals/plugins/useTreeViewItems/useTreeViewItems.utils.js +34 -2
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.js +3 -6
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.d.ts +43 -9
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.js +13 -3
- package/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.d.ts +1 -1
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.itemPlugin.js +2 -2
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.js +37 -38
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.d.ts +186 -30
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.js +37 -2
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.d.ts +3 -6
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.d.ts +0 -7
- package/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.js +6 -26
- package/internals/useTreeView/extractPluginParamsFromProps.d.ts +0 -2
- package/internals/useTreeView/extractPluginParamsFromProps.js +1 -5
- package/internals/useTreeView/useTreeView.d.ts +10 -1
- package/internals/useTreeView/useTreeView.js +22 -25
- package/internals/useTreeView/useTreeView.types.d.ts +1 -3
- package/internals/useTreeView/useTreeViewBuildContext.js +9 -11
- package/internals/utils/models.d.ts +7 -0
- package/internals/utils/models.js +30 -0
- package/internals/utils/selectors.d.ts +1 -1
- package/package.json +7 -15
- package/utils/cache.d.ts +1 -1
- package/utils/cache.js +1 -1
- package/esm/internals/plugins/useTreeViewIcons/index.d.ts +0 -2
- package/esm/internals/plugins/useTreeViewIcons/index.js +0 -1
- package/esm/internals/plugins/useTreeViewIcons/useTreeViewIcons.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewIcons/useTreeViewIcons.js +0 -24
- package/esm/internals/plugins/useTreeViewIcons/useTreeViewIcons.types.d.ts +0 -42
- package/esm/internals/plugins/useTreeViewIcons/useTreeViewIcons.types.js +0 -1
- package/esm/internals/plugins/useTreeViewItemCustomization/index.d.ts +0 -2
- package/esm/internals/plugins/useTreeViewItemCustomization/index.js +0 -1
- package/esm/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.d.ts +0 -3
- package/esm/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.js +0 -24
- package/esm/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.types.d.ts +0 -42
- package/esm/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.types.js +0 -1
- package/esm/internals/useTreeView/useTreeViewModels.d.ts +0 -7
- package/esm/internals/useTreeView/useTreeViewModels.js +0 -62
- package/internals/plugins/useTreeViewIcons/index.d.ts +0 -2
- package/internals/plugins/useTreeViewIcons/index.js +0 -12
- package/internals/plugins/useTreeViewIcons/useTreeViewIcons.d.ts +0 -3
- package/internals/plugins/useTreeViewIcons/useTreeViewIcons.js +0 -32
- package/internals/plugins/useTreeViewIcons/useTreeViewIcons.types.d.ts +0 -42
- package/internals/plugins/useTreeViewIcons/useTreeViewIcons.types.js +0 -5
- package/internals/plugins/useTreeViewItemCustomization/index.d.ts +0 -2
- package/internals/plugins/useTreeViewItemCustomization/index.js +0 -12
- package/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.d.ts +0 -3
- package/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.js +0 -32
- package/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.types.d.ts +0 -42
- package/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.types.js +0 -5
- package/internals/useTreeView/useTreeViewModels.d.ts +0 -7
- package/internals/useTreeView/useTreeViewModels.js +0 -71
- package/modern/RichTreeView/RichTreeView.d.ts +0 -18
- package/modern/RichTreeView/RichTreeView.js +0 -322
- package/modern/RichTreeView/RichTreeView.plugins.d.ts +0 -13
- package/modern/RichTreeView/RichTreeView.plugins.js +0 -10
- package/modern/RichTreeView/RichTreeView.types.d.ts +0 -52
- package/modern/RichTreeView/RichTreeView.types.js +0 -1
- package/modern/RichTreeView/index.d.ts +0 -5
- package/modern/RichTreeView/index.js +0 -3
- package/modern/RichTreeView/richTreeViewClasses.d.ts +0 -5
- package/modern/RichTreeView/richTreeViewClasses.js +0 -6
- package/modern/SimpleTreeView/SimpleTreeView.d.ts +0 -20
- package/modern/SimpleTreeView/SimpleTreeView.js +0 -265
- package/modern/SimpleTreeView/SimpleTreeView.plugins.d.ts +0 -12
- package/modern/SimpleTreeView/SimpleTreeView.plugins.js +0 -10
- package/modern/SimpleTreeView/SimpleTreeView.types.d.ts +0 -51
- package/modern/SimpleTreeView/SimpleTreeView.types.js +0 -1
- package/modern/SimpleTreeView/index.d.ts +0 -3
- package/modern/SimpleTreeView/index.js +0 -3
- package/modern/SimpleTreeView/simpleTreeViewClasses.d.ts +0 -5
- package/modern/SimpleTreeView/simpleTreeViewClasses.js +0 -6
- package/modern/TreeItem/TreeItem.d.ts +0 -33
- package/modern/TreeItem/TreeItem.js +0 -408
- package/modern/TreeItem/TreeItem.types.d.ts +0 -107
- package/modern/TreeItem/TreeItem.types.js +0 -1
- package/modern/TreeItem/index.d.ts +0 -4
- package/modern/TreeItem/index.js +0 -2
- package/modern/TreeItem/treeItemClasses.d.ts +0 -55
- package/modern/TreeItem/treeItemClasses.js +0 -8
- package/modern/TreeItemDragAndDropOverlay/TreeItemDragAndDropOverlay.d.ts +0 -7
- package/modern/TreeItemDragAndDropOverlay/TreeItemDragAndDropOverlay.js +0 -74
- package/modern/TreeItemDragAndDropOverlay/TreeItemDragAndDropOverlay.types.d.ts +0 -6
- package/modern/TreeItemDragAndDropOverlay/TreeItemDragAndDropOverlay.types.js +0 -1
- package/modern/TreeItemDragAndDropOverlay/index.d.ts +0 -2
- package/modern/TreeItemDragAndDropOverlay/index.js +0 -1
- package/modern/TreeItemIcon/TreeItemIcon.d.ts +0 -7
- package/modern/TreeItemIcon/TreeItemIcon.js +0 -74
- package/modern/TreeItemIcon/TreeItemIcon.types.d.ts +0 -40
- package/modern/TreeItemIcon/TreeItemIcon.types.js +0 -1
- package/modern/TreeItemIcon/index.d.ts +0 -2
- package/modern/TreeItemIcon/index.js +0 -1
- package/modern/TreeItemLabelInput/TreeItemLabelInput.d.ts +0 -5
- package/modern/TreeItemLabelInput/TreeItemLabelInput.js +0 -24
- package/modern/TreeItemLabelInput/TreeItemLabelInput.types.d.ts +0 -14
- package/modern/TreeItemLabelInput/TreeItemLabelInput.types.js +0 -1
- package/modern/TreeItemLabelInput/index.d.ts +0 -2
- package/modern/TreeItemLabelInput/index.js +0 -1
- package/modern/TreeItemProvider/TreeItemProvider.d.ts +0 -7
- package/modern/TreeItemProvider/TreeItemProvider.js +0 -45
- package/modern/TreeItemProvider/TreeItemProvider.types.d.ts +0 -7
- package/modern/TreeItemProvider/TreeItemProvider.types.js +0 -1
- package/modern/TreeItemProvider/index.d.ts +0 -2
- package/modern/TreeItemProvider/index.js +0 -1
- package/modern/hooks/index.d.ts +0 -3
- package/modern/hooks/index.js +0 -3
- package/modern/hooks/useTreeItemModel.d.ts +0 -2
- package/modern/hooks/useTreeItemModel.js +0 -11
- package/modern/hooks/useTreeItemUtils/index.d.ts +0 -1
- package/modern/hooks/useTreeItemUtils/index.js +0 -1
- package/modern/hooks/useTreeItemUtils/useTreeItemUtils.d.ts +0 -42
- package/modern/hooks/useTreeItemUtils/useTreeItemUtils.js +0 -165
- package/modern/hooks/useTreeViewApiRef.d.ts +0 -7
- package/modern/hooks/useTreeViewApiRef.js +0 -7
- package/modern/icons/icons.d.ts +0 -6
- package/modern/icons/icons.js +0 -9
- package/modern/icons/index.d.ts +0 -1
- package/modern/icons/index.js +0 -1
- package/modern/index.d.ts +0 -12
- package/modern/index.js +0 -22
- package/modern/internals/TreeViewItemDepthContext/TreeViewItemDepthContext.d.ts +0 -5
- package/modern/internals/TreeViewItemDepthContext/TreeViewItemDepthContext.js +0 -5
- package/modern/internals/TreeViewItemDepthContext/index.d.ts +0 -1
- package/modern/internals/TreeViewItemDepthContext/index.js +0 -1
- package/modern/internals/TreeViewProvider/TreeViewChildrenItemProvider.d.ts +0 -17
- package/modern/internals/TreeViewProvider/TreeViewChildrenItemProvider.js +0 -49
- package/modern/internals/TreeViewProvider/TreeViewContext.d.ts +0 -8
- package/modern/internals/TreeViewProvider/TreeViewContext.js +0 -15
- package/modern/internals/TreeViewProvider/TreeViewProvider.d.ts +0 -9
- package/modern/internals/TreeViewProvider/TreeViewProvider.js +0 -32
- package/modern/internals/TreeViewProvider/TreeViewProvider.types.d.ts +0 -21
- package/modern/internals/TreeViewProvider/TreeViewProvider.types.js +0 -1
- package/modern/internals/TreeViewProvider/TreeViewStyleContext.d.ts +0 -33
- package/modern/internals/TreeViewProvider/TreeViewStyleContext.js +0 -13
- package/modern/internals/TreeViewProvider/index.d.ts +0 -3
- package/modern/internals/TreeViewProvider/index.js +0 -2
- package/modern/internals/components/RichTreeViewItems.d.ts +0 -32
- package/modern/internals/components/RichTreeViewItems.js +0 -68
- package/modern/internals/corePlugins/corePlugins.d.ts +0 -9
- package/modern/internals/corePlugins/corePlugins.js +0 -8
- package/modern/internals/corePlugins/index.d.ts +0 -2
- package/modern/internals/corePlugins/index.js +0 -1
- package/modern/internals/corePlugins/useTreeViewId/index.d.ts +0 -2
- package/modern/internals/corePlugins/useTreeViewId/index.js +0 -1
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.d.ts +0 -3
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.js +0 -39
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.selectors.d.ts +0 -36
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.selectors.js +0 -9
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.types.d.ts +0 -20
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.types.js +0 -1
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.utils.d.ts +0 -21
- package/modern/internals/corePlugins/useTreeViewId/useTreeViewId.utils.js +0 -26
- package/modern/internals/corePlugins/useTreeViewInstanceEvents/index.d.ts +0 -2
- package/modern/internals/corePlugins/useTreeViewInstanceEvents/index.js +0 -1
- package/modern/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.d.ts +0 -3
- package/modern/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.js +0 -29
- package/modern/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.types.d.ts +0 -22
- package/modern/internals/corePlugins/useTreeViewInstanceEvents/useTreeViewInstanceEvents.types.js +0 -1
- package/modern/internals/corePlugins/useTreeViewOptionalPlugins/index.d.ts +0 -2
- package/modern/internals/corePlugins/useTreeViewOptionalPlugins/index.js +0 -1
- package/modern/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.d.ts +0 -3
- package/modern/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.js +0 -12
- package/modern/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.types.d.ts +0 -8
- package/modern/internals/corePlugins/useTreeViewOptionalPlugins/useTreeViewOptionalPlugins.types.js +0 -1
- package/modern/internals/hooks/useInstanceEventHandler.d.ts +0 -15
- package/modern/internals/hooks/useInstanceEventHandler.js +0 -77
- package/modern/internals/hooks/useLazyRef.d.ts +0 -1
- package/modern/internals/hooks/useLazyRef.js +0 -1
- package/modern/internals/hooks/useOnMount.d.ts +0 -1
- package/modern/internals/hooks/useOnMount.js +0 -1
- package/modern/internals/hooks/useSelector.d.ts +0 -4
- package/modern/internals/hooks/useSelector.js +0 -9
- package/modern/internals/hooks/useTimeout.d.ts +0 -1
- package/modern/internals/hooks/useTimeout.js +0 -1
- package/modern/internals/index.d.ts +0 -34
- package/modern/internals/index.js +0 -24
- package/modern/internals/models/events.d.ts +0 -9
- package/modern/internals/models/events.js +0 -1
- package/modern/internals/models/helpers.d.ts +0 -7
- package/modern/internals/models/helpers.js +0 -1
- package/modern/internals/models/index.d.ts +0 -4
- package/modern/internals/models/index.js +0 -4
- package/modern/internals/models/itemPlugin.d.ts +0 -43
- package/modern/internals/models/itemPlugin.js +0 -1
- package/modern/internals/models/plugin.d.ts +0 -151
- package/modern/internals/models/plugin.js +0 -1
- package/modern/internals/models/treeView.d.ts +0 -32
- package/modern/internals/models/treeView.js +0 -1
- package/modern/internals/plugins/useTreeViewExpansion/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewExpansion/index.js +0 -1
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.js +0 -134
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.d.ts +0 -184
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.selectors.js +0 -24
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.d.ts +0 -102
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.types.js +0 -1
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.d.ts +0 -7
- package/modern/internals/plugins/useTreeViewExpansion/useTreeViewExpansion.utils.js +0 -19
- package/modern/internals/plugins/useTreeViewFocus/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewFocus/index.js +0 -1
- package/modern/internals/plugins/useTreeViewFocus/useTreeViewFocus.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewFocus/useTreeViewFocus.js +0 -135
- package/modern/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.d.ts +0 -182
- package/modern/internals/plugins/useTreeViewFocus/useTreeViewFocus.selectors.js +0 -34
- package/modern/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.d.ts +0 -45
- package/modern/internals/plugins/useTreeViewFocus/useTreeViewFocus.types.js +0 -1
- package/modern/internals/plugins/useTreeViewIcons/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewIcons/index.js +0 -1
- package/modern/internals/plugins/useTreeViewIcons/useTreeViewIcons.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewIcons/useTreeViewIcons.js +0 -24
- package/modern/internals/plugins/useTreeViewIcons/useTreeViewIcons.types.d.ts +0 -42
- package/modern/internals/plugins/useTreeViewIcons/useTreeViewIcons.types.js +0 -1
- package/modern/internals/plugins/useTreeViewItemCustomization/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewItemCustomization/index.js +0 -1
- package/modern/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.js +0 -24
- package/modern/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.types.d.ts +0 -42
- package/modern/internals/plugins/useTreeViewItemCustomization/useTreeViewItemCustomization.types.js +0 -1
- package/modern/internals/plugins/useTreeViewItems/index.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewItems/index.js +0 -2
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.js +0 -325
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.d.ts +0 -1058
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.selectors.js +0 -113
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.types.d.ts +0 -205
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.types.js +0 -1
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.utils.d.ts +0 -4
- package/modern/internals/plugins/useTreeViewItems/useTreeViewItems.utils.js +0 -8
- package/modern/internals/plugins/useTreeViewJSXItems/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewJSXItems/index.js +0 -1
- package/modern/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.js +0 -183
- package/modern/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.types.d.ts +0 -35
- package/modern/internals/plugins/useTreeViewJSXItems/useTreeViewJSXItems.types.js +0 -1
- package/modern/internals/plugins/useTreeViewKeyboardNavigation/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewKeyboardNavigation/index.js +0 -1
- package/modern/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.js +0 -273
- package/modern/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.types.d.ts +0 -30
- package/modern/internals/plugins/useTreeViewKeyboardNavigation/useTreeViewKeyboardNavigation.types.js +0 -1
- package/modern/internals/plugins/useTreeViewLabel/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewLabel/index.js +0 -1
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.itemPlugin.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.itemPlugin.js +0 -72
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.js +0 -73
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.d.ts +0 -68
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.selectors.js +0 -24
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.d.ts +0 -60
- package/modern/internals/plugins/useTreeViewLabel/useTreeViewLabel.types.js +0 -1
- package/modern/internals/plugins/useTreeViewLazyLoading/index.d.ts +0 -1
- package/modern/internals/plugins/useTreeViewLazyLoading/index.js +0 -1
- package/modern/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.selectors.d.ts +0 -247
- package/modern/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.selectors.js +0 -27
- package/modern/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.types.d.ts +0 -82
- package/modern/internals/plugins/useTreeViewLazyLoading/useTreeViewLazyLoading.types.js +0 -1
- package/modern/internals/plugins/useTreeViewSelection/index.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewSelection/index.js +0 -1
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.d.ts +0 -3
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.itemPlugin.d.ts +0 -2
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.itemPlugin.js +0 -80
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.js +0 -234
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.d.ts +0 -363
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.selectors.js +0 -46
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.d.ts +0 -145
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.types.js +0 -1
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.d.ts +0 -38
- package/modern/internals/plugins/useTreeViewSelection/useTreeViewSelection.utils.js +0 -126
- package/modern/internals/useTreeView/extractPluginParamsFromProps.d.ts +0 -22
- package/modern/internals/useTreeView/extractPluginParamsFromProps.js +0 -46
- package/modern/internals/useTreeView/index.d.ts +0 -1
- package/modern/internals/useTreeView/index.js +0 -1
- package/modern/internals/useTreeView/useTreeView.d.ts +0 -9
- package/modern/internals/useTreeView/useTreeView.js +0 -114
- package/modern/internals/useTreeView/useTreeView.types.d.ts +0 -23
- package/modern/internals/useTreeView/useTreeView.types.js +0 -1
- package/modern/internals/useTreeView/useTreeViewBuildContext.d.ts +0 -18
- package/modern/internals/useTreeView/useTreeViewBuildContext.js +0 -101
- package/modern/internals/useTreeView/useTreeViewModels.d.ts +0 -7
- package/modern/internals/useTreeView/useTreeViewModels.js +0 -62
- package/modern/internals/useTreeView/useTreeViewPlugins.d.ts +0 -0
- package/modern/internals/useTreeView/useTreeViewPlugins.js +0 -0
- package/modern/internals/utils/TreeViewStore.d.ts +0 -12
- package/modern/internals/utils/TreeViewStore.js +0 -24
- package/modern/internals/utils/cleanupTracking/CleanupTracking.d.ts +0 -9
- package/modern/internals/utils/cleanupTracking/CleanupTracking.js +0 -1
- package/modern/internals/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.d.ts +0 -7
- package/modern/internals/utils/cleanupTracking/FinalizationRegistryBasedCleanupTracking.js +0 -18
- package/modern/internals/utils/cleanupTracking/TimerBasedCleanupTracking.d.ts +0 -9
- package/modern/internals/utils/cleanupTracking/TimerBasedCleanupTracking.js +0 -38
- package/modern/internals/utils/plugins.d.ts +0 -2
- package/modern/internals/utils/plugins.js +0 -4
- package/modern/internals/utils/publishTreeViewEvent.d.ts +0 -5
- package/modern/internals/utils/publishTreeViewEvent.js +0 -3
- package/modern/internals/utils/selectors.d.ts +0 -16
- package/modern/internals/utils/selectors.js +0 -46
- package/modern/internals/utils/tree.d.ts +0 -32
- package/modern/internals/utils/tree.js +0 -203
- package/modern/internals/utils/utils.d.ts +0 -2
- package/modern/internals/utils/utils.js +0 -17
- package/modern/internals/zero-styled/index.d.ts +0 -3
- package/modern/internals/zero-styled/index.js +0 -7
- package/modern/models/events.d.ts +0 -4
- package/modern/models/events.js +0 -1
- package/modern/models/index.d.ts +0 -3
- package/modern/models/index.js +0 -5
- package/modern/models/items.d.ts +0 -13
- package/modern/models/items.js +0 -1
- package/modern/package.json +0 -1
- package/modern/themeAugmentation/components.d.ts +0 -21
- package/modern/themeAugmentation/index.d.ts +0 -3
- package/modern/themeAugmentation/index.js +0 -0
- package/modern/themeAugmentation/overrides.d.ts +0 -16
- package/modern/themeAugmentation/props.d.ts +0 -14
- package/modern/useTreeItem/index.d.ts +0 -2
- package/modern/useTreeItem/index.js +0 -1
- package/modern/useTreeItem/useTreeItem.d.ts +0 -2
- package/modern/useTreeItem/useTreeItem.js +0 -282
- package/modern/useTreeItem/useTreeItem.types.d.ts +0 -201
- package/modern/useTreeItem/useTreeItem.types.js +0 -1
- package/modern/utils/cache.d.ts +0 -38
- package/modern/utils/cache.js +0 -31
- package/modern/utils/index.d.ts +0 -1
- package/modern/utils/index.js +0 -1
- package/tsconfig.build.tsbuildinfo +0 -1
|
@@ -1,234 +0,0 @@
|
|
|
1
|
-
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
-
import * as React from 'react';
|
|
3
|
-
import useEnhancedEffect from '@mui/utils/useEnhancedEffect';
|
|
4
|
-
import { findOrderInTremauxTree, getAllNavigableItems, getFirstNavigableItem, getLastNavigableItem, getNonDisabledItemsInRange } from "../../utils/tree.js";
|
|
5
|
-
import { convertSelectedItemsToArray, propagateSelection, getAddedAndRemovedItems, getLookupFromArray, createSelectedItemsMap } from "./useTreeViewSelection.utils.js";
|
|
6
|
-
import { selectorIsItemSelected, selectorIsMultiSelectEnabled, selectorIsSelectionEnabled } from "./useTreeViewSelection.selectors.js";
|
|
7
|
-
import { useTreeViewSelectionItemPlugin } from "./useTreeViewSelection.itemPlugin.js";
|
|
8
|
-
export const useTreeViewSelection = ({
|
|
9
|
-
store,
|
|
10
|
-
params,
|
|
11
|
-
models
|
|
12
|
-
}) => {
|
|
13
|
-
const lastSelectedItem = React.useRef(null);
|
|
14
|
-
const lastSelectedRange = React.useRef({});
|
|
15
|
-
const setSelectedItems = (event, newModel, additionalItemsToPropagate) => {
|
|
16
|
-
let cleanModel;
|
|
17
|
-
const isMultiSelectEnabled = selectorIsMultiSelectEnabled(store.value);
|
|
18
|
-
if (isMultiSelectEnabled && (params.selectionPropagation.descendants || params.selectionPropagation.parents)) {
|
|
19
|
-
cleanModel = propagateSelection({
|
|
20
|
-
store,
|
|
21
|
-
selectionPropagation: params.selectionPropagation,
|
|
22
|
-
newModel: newModel,
|
|
23
|
-
oldModel: models.selectedItems.value,
|
|
24
|
-
additionalItemsToPropagate
|
|
25
|
-
});
|
|
26
|
-
} else {
|
|
27
|
-
cleanModel = newModel;
|
|
28
|
-
}
|
|
29
|
-
if (params.onItemSelectionToggle) {
|
|
30
|
-
if (isMultiSelectEnabled) {
|
|
31
|
-
const changes = getAddedAndRemovedItems({
|
|
32
|
-
store,
|
|
33
|
-
newModel: cleanModel,
|
|
34
|
-
oldModel: models.selectedItems.value
|
|
35
|
-
});
|
|
36
|
-
if (params.onItemSelectionToggle) {
|
|
37
|
-
changes.added.forEach(itemId => {
|
|
38
|
-
params.onItemSelectionToggle(event, itemId, true);
|
|
39
|
-
});
|
|
40
|
-
changes.removed.forEach(itemId => {
|
|
41
|
-
params.onItemSelectionToggle(event, itemId, false);
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
} else if (params.onItemSelectionToggle && cleanModel !== models.selectedItems.value) {
|
|
45
|
-
if (models.selectedItems.value != null) {
|
|
46
|
-
params.onItemSelectionToggle(event, models.selectedItems.value, false);
|
|
47
|
-
}
|
|
48
|
-
if (cleanModel != null) {
|
|
49
|
-
params.onItemSelectionToggle(event, cleanModel, true);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
if (params.onSelectedItemsChange) {
|
|
54
|
-
params.onSelectedItemsChange(event, cleanModel);
|
|
55
|
-
}
|
|
56
|
-
models.selectedItems.setControlledValue(cleanModel);
|
|
57
|
-
};
|
|
58
|
-
const setItemSelection = ({
|
|
59
|
-
itemId,
|
|
60
|
-
event = null,
|
|
61
|
-
keepExistingSelection = false,
|
|
62
|
-
shouldBeSelected
|
|
63
|
-
}) => {
|
|
64
|
-
if (!selectorIsSelectionEnabled(store.value)) {
|
|
65
|
-
return;
|
|
66
|
-
}
|
|
67
|
-
let newSelected;
|
|
68
|
-
const isMultiSelectEnabled = selectorIsMultiSelectEnabled(store.value);
|
|
69
|
-
if (keepExistingSelection) {
|
|
70
|
-
const cleanSelectedItems = convertSelectedItemsToArray(models.selectedItems.value);
|
|
71
|
-
const isSelectedBefore = selectorIsItemSelected(store.value, itemId);
|
|
72
|
-
if (isSelectedBefore && (shouldBeSelected === false || shouldBeSelected == null)) {
|
|
73
|
-
newSelected = cleanSelectedItems.filter(id => id !== itemId);
|
|
74
|
-
} else if (!isSelectedBefore && (shouldBeSelected === true || shouldBeSelected == null)) {
|
|
75
|
-
newSelected = [itemId].concat(cleanSelectedItems);
|
|
76
|
-
} else {
|
|
77
|
-
newSelected = cleanSelectedItems;
|
|
78
|
-
}
|
|
79
|
-
} else {
|
|
80
|
-
// eslint-disable-next-line no-lonely-if
|
|
81
|
-
if (shouldBeSelected === false || shouldBeSelected == null && selectorIsItemSelected(store.value, itemId)) {
|
|
82
|
-
newSelected = isMultiSelectEnabled ? [] : null;
|
|
83
|
-
} else {
|
|
84
|
-
newSelected = isMultiSelectEnabled ? [itemId] : itemId;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
setSelectedItems(event, newSelected,
|
|
88
|
-
// If shouldBeSelected === selectorIsItemSelected(store, itemId), we still want to propagate the select.
|
|
89
|
-
// This is useful when the element is in an indeterminate state.
|
|
90
|
-
[itemId]);
|
|
91
|
-
lastSelectedItem.current = itemId;
|
|
92
|
-
lastSelectedRange.current = {};
|
|
93
|
-
};
|
|
94
|
-
const selectRange = (event, [start, end]) => {
|
|
95
|
-
const isMultiSelectEnabled = selectorIsMultiSelectEnabled(store.value);
|
|
96
|
-
if (!isMultiSelectEnabled) {
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
let newSelectedItems = convertSelectedItemsToArray(models.selectedItems.value).slice();
|
|
100
|
-
|
|
101
|
-
// If the last selection was a range selection,
|
|
102
|
-
// remove the items that were part of the last range from the model
|
|
103
|
-
if (Object.keys(lastSelectedRange.current).length > 0) {
|
|
104
|
-
newSelectedItems = newSelectedItems.filter(id => !lastSelectedRange.current[id]);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// Add to the model the items that are part of the new range and not already part of the model.
|
|
108
|
-
const selectedItemsLookup = getLookupFromArray(newSelectedItems);
|
|
109
|
-
const range = getNonDisabledItemsInRange(store.value, start, end);
|
|
110
|
-
const itemsToAddToModel = range.filter(id => !selectedItemsLookup[id]);
|
|
111
|
-
newSelectedItems = newSelectedItems.concat(itemsToAddToModel);
|
|
112
|
-
setSelectedItems(event, newSelectedItems);
|
|
113
|
-
lastSelectedRange.current = getLookupFromArray(range);
|
|
114
|
-
};
|
|
115
|
-
const expandSelectionRange = (event, itemId) => {
|
|
116
|
-
if (lastSelectedItem.current != null) {
|
|
117
|
-
const [start, end] = findOrderInTremauxTree(store.value, itemId, lastSelectedItem.current);
|
|
118
|
-
selectRange(event, [start, end]);
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
const selectRangeFromStartToItem = (event, itemId) => {
|
|
122
|
-
selectRange(event, [getFirstNavigableItem(store.value), itemId]);
|
|
123
|
-
};
|
|
124
|
-
const selectRangeFromItemToEnd = (event, itemId) => {
|
|
125
|
-
selectRange(event, [itemId, getLastNavigableItem(store.value)]);
|
|
126
|
-
};
|
|
127
|
-
const selectAllNavigableItems = event => {
|
|
128
|
-
const isMultiSelectEnabled = selectorIsMultiSelectEnabled(store.value);
|
|
129
|
-
if (!isMultiSelectEnabled) {
|
|
130
|
-
return;
|
|
131
|
-
}
|
|
132
|
-
const navigableItems = getAllNavigableItems(store.value);
|
|
133
|
-
setSelectedItems(event, navigableItems);
|
|
134
|
-
lastSelectedRange.current = getLookupFromArray(navigableItems);
|
|
135
|
-
};
|
|
136
|
-
const selectItemFromArrowNavigation = (event, currentItem, nextItem) => {
|
|
137
|
-
const isMultiSelectEnabled = selectorIsMultiSelectEnabled(store.value);
|
|
138
|
-
if (!isMultiSelectEnabled) {
|
|
139
|
-
return;
|
|
140
|
-
}
|
|
141
|
-
let newSelectedItems = convertSelectedItemsToArray(models.selectedItems.value).slice();
|
|
142
|
-
if (Object.keys(lastSelectedRange.current).length === 0) {
|
|
143
|
-
newSelectedItems.push(nextItem);
|
|
144
|
-
lastSelectedRange.current = {
|
|
145
|
-
[currentItem]: true,
|
|
146
|
-
[nextItem]: true
|
|
147
|
-
};
|
|
148
|
-
} else {
|
|
149
|
-
if (!lastSelectedRange.current[currentItem]) {
|
|
150
|
-
lastSelectedRange.current = {};
|
|
151
|
-
}
|
|
152
|
-
if (lastSelectedRange.current[nextItem]) {
|
|
153
|
-
newSelectedItems = newSelectedItems.filter(id => id !== currentItem);
|
|
154
|
-
delete lastSelectedRange.current[currentItem];
|
|
155
|
-
} else {
|
|
156
|
-
newSelectedItems.push(nextItem);
|
|
157
|
-
lastSelectedRange.current[nextItem] = true;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
setSelectedItems(event, newSelectedItems);
|
|
161
|
-
};
|
|
162
|
-
useEnhancedEffect(() => {
|
|
163
|
-
store.update(prevState => _extends({}, prevState, {
|
|
164
|
-
selection: {
|
|
165
|
-
rawSelectedItems: models.selectedItems.value,
|
|
166
|
-
// Only re-compute the map when the model changes.
|
|
167
|
-
selectedItemsMap: prevState.selection.rawSelectedItems === models.selectedItems.value ? prevState.selection.selectedItemsMap : createSelectedItemsMap(models.selectedItems.value),
|
|
168
|
-
isEnabled: !params.disableSelection,
|
|
169
|
-
isMultiSelectEnabled: params.multiSelect,
|
|
170
|
-
isCheckboxSelectionEnabled: params.checkboxSelection,
|
|
171
|
-
selectionPropagation: {
|
|
172
|
-
descendants: params.selectionPropagation.descendants,
|
|
173
|
-
parents: params.selectionPropagation.parents
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
}));
|
|
177
|
-
}, [store, models.selectedItems.value, params.multiSelect, params.checkboxSelection, params.disableSelection, params.selectionPropagation.descendants, params.selectionPropagation.parents]);
|
|
178
|
-
return {
|
|
179
|
-
getRootProps: () => ({
|
|
180
|
-
'aria-multiselectable': params.multiSelect
|
|
181
|
-
}),
|
|
182
|
-
publicAPI: {
|
|
183
|
-
setItemSelection
|
|
184
|
-
},
|
|
185
|
-
instance: {
|
|
186
|
-
setItemSelection,
|
|
187
|
-
selectAllNavigableItems,
|
|
188
|
-
expandSelectionRange,
|
|
189
|
-
selectRangeFromStartToItem,
|
|
190
|
-
selectRangeFromItemToEnd,
|
|
191
|
-
selectItemFromArrowNavigation
|
|
192
|
-
}
|
|
193
|
-
};
|
|
194
|
-
};
|
|
195
|
-
useTreeViewSelection.itemPlugin = useTreeViewSelectionItemPlugin;
|
|
196
|
-
useTreeViewSelection.models = {
|
|
197
|
-
selectedItems: {
|
|
198
|
-
getDefaultValue: params => params.defaultSelectedItems
|
|
199
|
-
}
|
|
200
|
-
};
|
|
201
|
-
const DEFAULT_SELECTED_ITEMS = [];
|
|
202
|
-
const EMPTY_SELECTION_PROPAGATION = {};
|
|
203
|
-
useTreeViewSelection.getDefaultizedParams = ({
|
|
204
|
-
params
|
|
205
|
-
}) => _extends({}, params, {
|
|
206
|
-
disableSelection: params.disableSelection ?? false,
|
|
207
|
-
multiSelect: params.multiSelect ?? false,
|
|
208
|
-
checkboxSelection: params.checkboxSelection ?? false,
|
|
209
|
-
defaultSelectedItems: params.defaultSelectedItems ?? (params.multiSelect ? DEFAULT_SELECTED_ITEMS : null),
|
|
210
|
-
selectionPropagation: params.selectionPropagation ?? EMPTY_SELECTION_PROPAGATION
|
|
211
|
-
});
|
|
212
|
-
useTreeViewSelection.getInitialState = params => {
|
|
213
|
-
const rawSelectedItems = params.selectedItems === undefined ? params.defaultSelectedItems : params.selectedItems;
|
|
214
|
-
return {
|
|
215
|
-
selection: {
|
|
216
|
-
rawSelectedItems,
|
|
217
|
-
selectedItemsMap: createSelectedItemsMap(rawSelectedItems),
|
|
218
|
-
isEnabled: !params.disableSelection,
|
|
219
|
-
isMultiSelectEnabled: params.multiSelect,
|
|
220
|
-
isCheckboxSelectionEnabled: params.checkboxSelection,
|
|
221
|
-
selectionPropagation: params.selectionPropagation
|
|
222
|
-
}
|
|
223
|
-
};
|
|
224
|
-
};
|
|
225
|
-
useTreeViewSelection.params = {
|
|
226
|
-
disableSelection: true,
|
|
227
|
-
multiSelect: true,
|
|
228
|
-
checkboxSelection: true,
|
|
229
|
-
defaultSelectedItems: true,
|
|
230
|
-
selectedItems: true,
|
|
231
|
-
onSelectedItemsChange: true,
|
|
232
|
-
onItemSelectionToggle: true,
|
|
233
|
-
selectionPropagation: true
|
|
234
|
-
};
|
|
@@ -1,363 +0,0 @@
|
|
|
1
|
-
import { TreeViewRootSelector } from "../../utils/selectors.js";
|
|
2
|
-
import { UseTreeViewSelectionSignature } from "./useTreeViewSelection.types.js";
|
|
3
|
-
/**
|
|
4
|
-
* Check if an item is selected.
|
|
5
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
6
|
-
* @returns {boolean} `true` if the item is selected, `false` otherwise.
|
|
7
|
-
*/
|
|
8
|
-
export declare const selectorIsItemSelected: ((state: any, itemId: string) => boolean) & {
|
|
9
|
-
clearCache: () => void;
|
|
10
|
-
resultsCount: () => number;
|
|
11
|
-
resetResultsCount: () => void;
|
|
12
|
-
} & {
|
|
13
|
-
resultFunc: (resultFuncArgs_0: {
|
|
14
|
-
rawSelectedItems: string | string[] | null;
|
|
15
|
-
selectedItemsMap: Map<string, true>;
|
|
16
|
-
isEnabled: boolean;
|
|
17
|
-
isMultiSelectEnabled: boolean;
|
|
18
|
-
isCheckboxSelectionEnabled: boolean;
|
|
19
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
20
|
-
}, resultFuncArgs_1: string) => boolean;
|
|
21
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
22
|
-
rawSelectedItems: string | string[] | null;
|
|
23
|
-
selectedItemsMap: Map<string, true>;
|
|
24
|
-
isEnabled: boolean;
|
|
25
|
-
isMultiSelectEnabled: boolean;
|
|
26
|
-
isCheckboxSelectionEnabled: boolean;
|
|
27
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
28
|
-
}, resultFuncArgs_1: string) => boolean) & {
|
|
29
|
-
clearCache: () => void;
|
|
30
|
-
resultsCount: () => number;
|
|
31
|
-
resetResultsCount: () => void;
|
|
32
|
-
};
|
|
33
|
-
lastResult: () => boolean;
|
|
34
|
-
dependencies: [TreeViewRootSelector<UseTreeViewSelectionSignature>, (_: any, itemId: string) => string];
|
|
35
|
-
recomputations: () => number;
|
|
36
|
-
resetRecomputations: () => void;
|
|
37
|
-
dependencyRecomputations: () => number;
|
|
38
|
-
resetDependencyRecomputations: () => void;
|
|
39
|
-
} & {
|
|
40
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
41
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
42
|
-
};
|
|
43
|
-
/**
|
|
44
|
-
* Check if multi selection is enabled.
|
|
45
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
46
|
-
* @returns {boolean} `true` if multi selection is enabled, `false` otherwise.
|
|
47
|
-
*/
|
|
48
|
-
export declare const selectorIsMultiSelectEnabled: ((state: import("../../corePlugins/useTreeViewId/useTreeViewId.types").UseTreeViewIdState & import("./useTreeViewSelection.types").UseTreeViewSelectionState & Partial<{}> & {
|
|
49
|
-
cacheKey: import("../../models").TreeViewStateCacheKey;
|
|
50
|
-
}) => boolean) & {
|
|
51
|
-
clearCache: () => void;
|
|
52
|
-
resultsCount: () => number;
|
|
53
|
-
resetResultsCount: () => void;
|
|
54
|
-
} & {
|
|
55
|
-
resultFunc: (resultFuncArgs_0: {
|
|
56
|
-
rawSelectedItems: string | string[] | null;
|
|
57
|
-
selectedItemsMap: Map<string, true>;
|
|
58
|
-
isEnabled: boolean;
|
|
59
|
-
isMultiSelectEnabled: boolean;
|
|
60
|
-
isCheckboxSelectionEnabled: boolean;
|
|
61
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
62
|
-
}) => boolean;
|
|
63
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
64
|
-
rawSelectedItems: string | string[] | null;
|
|
65
|
-
selectedItemsMap: Map<string, true>;
|
|
66
|
-
isEnabled: boolean;
|
|
67
|
-
isMultiSelectEnabled: boolean;
|
|
68
|
-
isCheckboxSelectionEnabled: boolean;
|
|
69
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
70
|
-
}) => boolean) & {
|
|
71
|
-
clearCache: () => void;
|
|
72
|
-
resultsCount: () => number;
|
|
73
|
-
resetResultsCount: () => void;
|
|
74
|
-
};
|
|
75
|
-
lastResult: () => boolean;
|
|
76
|
-
dependencies: [TreeViewRootSelector<UseTreeViewSelectionSignature>];
|
|
77
|
-
recomputations: () => number;
|
|
78
|
-
resetRecomputations: () => void;
|
|
79
|
-
dependencyRecomputations: () => number;
|
|
80
|
-
resetDependencyRecomputations: () => void;
|
|
81
|
-
} & {
|
|
82
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
83
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
84
|
-
};
|
|
85
|
-
/**
|
|
86
|
-
* Check if selection is enabled.
|
|
87
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
88
|
-
* @returns {boolean} `true` if selection is enabled, `false` otherwise.
|
|
89
|
-
*/
|
|
90
|
-
export declare const selectorIsSelectionEnabled: ((state: import("../../corePlugins/useTreeViewId/useTreeViewId.types").UseTreeViewIdState & import("./useTreeViewSelection.types").UseTreeViewSelectionState & Partial<{}> & {
|
|
91
|
-
cacheKey: import("../../models").TreeViewStateCacheKey;
|
|
92
|
-
}) => boolean) & {
|
|
93
|
-
clearCache: () => void;
|
|
94
|
-
resultsCount: () => number;
|
|
95
|
-
resetResultsCount: () => void;
|
|
96
|
-
} & {
|
|
97
|
-
resultFunc: (resultFuncArgs_0: {
|
|
98
|
-
rawSelectedItems: string | string[] | null;
|
|
99
|
-
selectedItemsMap: Map<string, true>;
|
|
100
|
-
isEnabled: boolean;
|
|
101
|
-
isMultiSelectEnabled: boolean;
|
|
102
|
-
isCheckboxSelectionEnabled: boolean;
|
|
103
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
104
|
-
}) => boolean;
|
|
105
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
106
|
-
rawSelectedItems: string | string[] | null;
|
|
107
|
-
selectedItemsMap: Map<string, true>;
|
|
108
|
-
isEnabled: boolean;
|
|
109
|
-
isMultiSelectEnabled: boolean;
|
|
110
|
-
isCheckboxSelectionEnabled: boolean;
|
|
111
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
112
|
-
}) => boolean) & {
|
|
113
|
-
clearCache: () => void;
|
|
114
|
-
resultsCount: () => number;
|
|
115
|
-
resetResultsCount: () => void;
|
|
116
|
-
};
|
|
117
|
-
lastResult: () => boolean;
|
|
118
|
-
dependencies: [TreeViewRootSelector<UseTreeViewSelectionSignature>];
|
|
119
|
-
recomputations: () => number;
|
|
120
|
-
resetRecomputations: () => void;
|
|
121
|
-
dependencyRecomputations: () => number;
|
|
122
|
-
resetDependencyRecomputations: () => void;
|
|
123
|
-
} & {
|
|
124
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
125
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
126
|
-
};
|
|
127
|
-
/**
|
|
128
|
-
* Check if checkbox selection is enabled.
|
|
129
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
130
|
-
* @returns {boolean} `true` if checkbox selection is enabled, `false` otherwise.
|
|
131
|
-
*/
|
|
132
|
-
export declare const selectorIsCheckboxSelectionEnabled: ((state: import("../../corePlugins/useTreeViewId/useTreeViewId.types").UseTreeViewIdState & import("./useTreeViewSelection.types").UseTreeViewSelectionState & Partial<{}> & {
|
|
133
|
-
cacheKey: import("../../models").TreeViewStateCacheKey;
|
|
134
|
-
}) => boolean) & {
|
|
135
|
-
clearCache: () => void;
|
|
136
|
-
resultsCount: () => number;
|
|
137
|
-
resetResultsCount: () => void;
|
|
138
|
-
} & {
|
|
139
|
-
resultFunc: (resultFuncArgs_0: {
|
|
140
|
-
rawSelectedItems: string | string[] | null;
|
|
141
|
-
selectedItemsMap: Map<string, true>;
|
|
142
|
-
isEnabled: boolean;
|
|
143
|
-
isMultiSelectEnabled: boolean;
|
|
144
|
-
isCheckboxSelectionEnabled: boolean;
|
|
145
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
146
|
-
}) => boolean;
|
|
147
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
148
|
-
rawSelectedItems: string | string[] | null;
|
|
149
|
-
selectedItemsMap: Map<string, true>;
|
|
150
|
-
isEnabled: boolean;
|
|
151
|
-
isMultiSelectEnabled: boolean;
|
|
152
|
-
isCheckboxSelectionEnabled: boolean;
|
|
153
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
154
|
-
}) => boolean) & {
|
|
155
|
-
clearCache: () => void;
|
|
156
|
-
resultsCount: () => number;
|
|
157
|
-
resetResultsCount: () => void;
|
|
158
|
-
};
|
|
159
|
-
lastResult: () => boolean;
|
|
160
|
-
dependencies: [TreeViewRootSelector<UseTreeViewSelectionSignature>];
|
|
161
|
-
recomputations: () => number;
|
|
162
|
-
resetRecomputations: () => void;
|
|
163
|
-
dependencyRecomputations: () => number;
|
|
164
|
-
resetDependencyRecomputations: () => void;
|
|
165
|
-
} & {
|
|
166
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
167
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
168
|
-
};
|
|
169
|
-
/**
|
|
170
|
-
* Check if selection is enabled for an item (if selection is enabled and if the item is not disabled).
|
|
171
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
172
|
-
* @param {string} itemId The id of the item to check.
|
|
173
|
-
* @returns {boolean} `true` if selection is enabled for the item, `false` otherwise.
|
|
174
|
-
*/
|
|
175
|
-
export declare const selectorIsItemSelectionEnabled: ((state: any, itemId: string) => boolean) & {
|
|
176
|
-
clearCache: () => void;
|
|
177
|
-
resultsCount: () => number;
|
|
178
|
-
resetResultsCount: () => void;
|
|
179
|
-
} & {
|
|
180
|
-
resultFunc: (resultFuncArgs_0: boolean, resultFuncArgs_1: boolean) => boolean;
|
|
181
|
-
memoizedResultFunc: ((resultFuncArgs_0: boolean, resultFuncArgs_1: boolean) => boolean) & {
|
|
182
|
-
clearCache: () => void;
|
|
183
|
-
resultsCount: () => number;
|
|
184
|
-
resetResultsCount: () => void;
|
|
185
|
-
};
|
|
186
|
-
lastResult: () => boolean;
|
|
187
|
-
dependencies: [((state: any, itemId: string) => boolean) & {
|
|
188
|
-
clearCache: () => void;
|
|
189
|
-
resultsCount: () => number;
|
|
190
|
-
resetResultsCount: () => void;
|
|
191
|
-
} & {
|
|
192
|
-
resultFunc: (resultFuncArgs_0: {
|
|
193
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
194
|
-
}, resultFuncArgs_1: string) => boolean;
|
|
195
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
196
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
197
|
-
}, resultFuncArgs_1: string) => boolean) & {
|
|
198
|
-
clearCache: () => void;
|
|
199
|
-
resultsCount: () => number;
|
|
200
|
-
resetResultsCount: () => void;
|
|
201
|
-
};
|
|
202
|
-
lastResult: () => boolean;
|
|
203
|
-
dependencies: [((state: import("../../corePlugins/useTreeViewId/useTreeViewId.types").UseTreeViewIdState & import("../useTreeViewItems").UseTreeViewItemsState<import("../../..").TreeViewDefaultItemModelProperties> & Partial<{}> & {
|
|
204
|
-
cacheKey: import("../../models").TreeViewStateCacheKey;
|
|
205
|
-
}) => {
|
|
206
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
207
|
-
}) & {
|
|
208
|
-
clearCache: () => void;
|
|
209
|
-
resultsCount: () => number;
|
|
210
|
-
resetResultsCount: () => void;
|
|
211
|
-
} & {
|
|
212
|
-
resultFunc: (resultFuncArgs_0: {
|
|
213
|
-
disabledItemsFocusable: boolean;
|
|
214
|
-
itemModelLookup: {
|
|
215
|
-
[itemId: string]: import("../../..").TreeViewBaseItem<import("../../..").TreeViewDefaultItemModelProperties>;
|
|
216
|
-
};
|
|
217
|
-
itemMetaLookup: {
|
|
218
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
219
|
-
};
|
|
220
|
-
itemOrderedChildrenIdsLookup: {
|
|
221
|
-
[parentItemId: string]: string[];
|
|
222
|
-
};
|
|
223
|
-
itemChildrenIndexesLookup: {
|
|
224
|
-
[parentItemId: string]: {
|
|
225
|
-
[itemId: string]: number;
|
|
226
|
-
};
|
|
227
|
-
};
|
|
228
|
-
loading: boolean;
|
|
229
|
-
error: Error | null;
|
|
230
|
-
}) => {
|
|
231
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
232
|
-
};
|
|
233
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
234
|
-
disabledItemsFocusable: boolean;
|
|
235
|
-
itemModelLookup: {
|
|
236
|
-
[itemId: string]: import("../../..").TreeViewBaseItem<import("../../..").TreeViewDefaultItemModelProperties>;
|
|
237
|
-
};
|
|
238
|
-
itemMetaLookup: {
|
|
239
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
240
|
-
};
|
|
241
|
-
itemOrderedChildrenIdsLookup: {
|
|
242
|
-
[parentItemId: string]: string[];
|
|
243
|
-
};
|
|
244
|
-
itemChildrenIndexesLookup: {
|
|
245
|
-
[parentItemId: string]: {
|
|
246
|
-
[itemId: string]: number;
|
|
247
|
-
};
|
|
248
|
-
};
|
|
249
|
-
loading: boolean;
|
|
250
|
-
error: Error | null;
|
|
251
|
-
}) => {
|
|
252
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
253
|
-
}) & {
|
|
254
|
-
clearCache: () => void;
|
|
255
|
-
resultsCount: () => number;
|
|
256
|
-
resetResultsCount: () => void;
|
|
257
|
-
};
|
|
258
|
-
lastResult: () => {
|
|
259
|
-
[itemId: string]: import("../..").TreeViewItemMeta;
|
|
260
|
-
};
|
|
261
|
-
dependencies: [TreeViewRootSelector<import("../useTreeViewItems").UseTreeViewItemsSignature>];
|
|
262
|
-
recomputations: () => number;
|
|
263
|
-
resetRecomputations: () => void;
|
|
264
|
-
dependencyRecomputations: () => number;
|
|
265
|
-
resetDependencyRecomputations: () => void;
|
|
266
|
-
} & {
|
|
267
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
268
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
269
|
-
}, (_: any, itemId: string) => string];
|
|
270
|
-
recomputations: () => number;
|
|
271
|
-
resetRecomputations: () => void;
|
|
272
|
-
dependencyRecomputations: () => number;
|
|
273
|
-
resetDependencyRecomputations: () => void;
|
|
274
|
-
} & {
|
|
275
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
276
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
277
|
-
}, ((state: import("../../corePlugins/useTreeViewId/useTreeViewId.types").UseTreeViewIdState & import("./useTreeViewSelection.types").UseTreeViewSelectionState & Partial<{}> & {
|
|
278
|
-
cacheKey: import("../../models").TreeViewStateCacheKey;
|
|
279
|
-
}) => boolean) & {
|
|
280
|
-
clearCache: () => void;
|
|
281
|
-
resultsCount: () => number;
|
|
282
|
-
resetResultsCount: () => void;
|
|
283
|
-
} & {
|
|
284
|
-
resultFunc: (resultFuncArgs_0: {
|
|
285
|
-
rawSelectedItems: string | string[] | null;
|
|
286
|
-
selectedItemsMap: Map<string, true>;
|
|
287
|
-
isEnabled: boolean;
|
|
288
|
-
isMultiSelectEnabled: boolean;
|
|
289
|
-
isCheckboxSelectionEnabled: boolean;
|
|
290
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
291
|
-
}) => boolean;
|
|
292
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
293
|
-
rawSelectedItems: string | string[] | null;
|
|
294
|
-
selectedItemsMap: Map<string, true>;
|
|
295
|
-
isEnabled: boolean;
|
|
296
|
-
isMultiSelectEnabled: boolean;
|
|
297
|
-
isCheckboxSelectionEnabled: boolean;
|
|
298
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
299
|
-
}) => boolean) & {
|
|
300
|
-
clearCache: () => void;
|
|
301
|
-
resultsCount: () => number;
|
|
302
|
-
resetResultsCount: () => void;
|
|
303
|
-
};
|
|
304
|
-
lastResult: () => boolean;
|
|
305
|
-
dependencies: [TreeViewRootSelector<UseTreeViewSelectionSignature>];
|
|
306
|
-
recomputations: () => number;
|
|
307
|
-
resetRecomputations: () => void;
|
|
308
|
-
dependencyRecomputations: () => number;
|
|
309
|
-
resetDependencyRecomputations: () => void;
|
|
310
|
-
} & {
|
|
311
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
312
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
313
|
-
}];
|
|
314
|
-
recomputations: () => number;
|
|
315
|
-
resetRecomputations: () => void;
|
|
316
|
-
dependencyRecomputations: () => number;
|
|
317
|
-
resetDependencyRecomputations: () => void;
|
|
318
|
-
} & {
|
|
319
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
320
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
321
|
-
};
|
|
322
|
-
/**
|
|
323
|
-
* Get the selection propagation rules.
|
|
324
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
325
|
-
* @returns {TreeViewSelectionPropagation} The selection propagation rules.
|
|
326
|
-
*/
|
|
327
|
-
export declare const selectorSelectionPropagationRules: ((state: import("../../corePlugins/useTreeViewId/useTreeViewId.types").UseTreeViewIdState & import("./useTreeViewSelection.types").UseTreeViewSelectionState & Partial<{}> & {
|
|
328
|
-
cacheKey: import("../../models").TreeViewStateCacheKey;
|
|
329
|
-
}) => import("../../..").TreeViewSelectionPropagation) & {
|
|
330
|
-
clearCache: () => void;
|
|
331
|
-
resultsCount: () => number;
|
|
332
|
-
resetResultsCount: () => void;
|
|
333
|
-
} & {
|
|
334
|
-
resultFunc: (resultFuncArgs_0: {
|
|
335
|
-
rawSelectedItems: string | string[] | null;
|
|
336
|
-
selectedItemsMap: Map<string, true>;
|
|
337
|
-
isEnabled: boolean;
|
|
338
|
-
isMultiSelectEnabled: boolean;
|
|
339
|
-
isCheckboxSelectionEnabled: boolean;
|
|
340
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
341
|
-
}) => import("../../..").TreeViewSelectionPropagation;
|
|
342
|
-
memoizedResultFunc: ((resultFuncArgs_0: {
|
|
343
|
-
rawSelectedItems: string | string[] | null;
|
|
344
|
-
selectedItemsMap: Map<string, true>;
|
|
345
|
-
isEnabled: boolean;
|
|
346
|
-
isMultiSelectEnabled: boolean;
|
|
347
|
-
isCheckboxSelectionEnabled: boolean;
|
|
348
|
-
selectionPropagation: import("../../..").TreeViewSelectionPropagation;
|
|
349
|
-
}) => import("../../..").TreeViewSelectionPropagation) & {
|
|
350
|
-
clearCache: () => void;
|
|
351
|
-
resultsCount: () => number;
|
|
352
|
-
resetResultsCount: () => void;
|
|
353
|
-
};
|
|
354
|
-
lastResult: () => import("../../..").TreeViewSelectionPropagation;
|
|
355
|
-
dependencies: [TreeViewRootSelector<UseTreeViewSelectionSignature>];
|
|
356
|
-
recomputations: () => number;
|
|
357
|
-
resetRecomputations: () => void;
|
|
358
|
-
dependencyRecomputations: () => number;
|
|
359
|
-
resetDependencyRecomputations: () => void;
|
|
360
|
-
} & {
|
|
361
|
-
argsMemoize: typeof import("reselect").weakMapMemoize;
|
|
362
|
-
memoize: typeof import("reselect").weakMapMemoize;
|
|
363
|
-
};
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { createSelector } from "../../utils/selectors.js";
|
|
2
|
-
import { selectorIsItemDisabled } from "../useTreeViewItems/useTreeViewItems.selectors.js";
|
|
3
|
-
const selectorTreeViewSelectionState = state => state.selection;
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Check if an item is selected.
|
|
7
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
8
|
-
* @returns {boolean} `true` if the item is selected, `false` otherwise.
|
|
9
|
-
*/
|
|
10
|
-
export const selectorIsItemSelected = createSelector([selectorTreeViewSelectionState, (_, itemId) => itemId], (selectionState, itemId) => selectionState.selectedItemsMap.has(itemId));
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Check if multi selection is enabled.
|
|
14
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
15
|
-
* @returns {boolean} `true` if multi selection is enabled, `false` otherwise.
|
|
16
|
-
*/
|
|
17
|
-
export const selectorIsMultiSelectEnabled = createSelector([selectorTreeViewSelectionState], selectionState => selectionState.isEnabled && selectionState.isMultiSelectEnabled);
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Check if selection is enabled.
|
|
21
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
22
|
-
* @returns {boolean} `true` if selection is enabled, `false` otherwise.
|
|
23
|
-
*/
|
|
24
|
-
export const selectorIsSelectionEnabled = createSelector([selectorTreeViewSelectionState], selectionState => selectionState.isEnabled);
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Check if checkbox selection is enabled.
|
|
28
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
29
|
-
* @returns {boolean} `true` if checkbox selection is enabled, `false` otherwise.
|
|
30
|
-
*/
|
|
31
|
-
export const selectorIsCheckboxSelectionEnabled = createSelector([selectorTreeViewSelectionState], selectionState => selectionState.isCheckboxSelectionEnabled);
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Check if selection is enabled for an item (if selection is enabled and if the item is not disabled).
|
|
35
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
36
|
-
* @param {string} itemId The id of the item to check.
|
|
37
|
-
* @returns {boolean} `true` if selection is enabled for the item, `false` otherwise.
|
|
38
|
-
*/
|
|
39
|
-
export const selectorIsItemSelectionEnabled = createSelector([selectorIsItemDisabled, selectorIsSelectionEnabled], (isItemDisabled, isSelectionEnabled) => isSelectionEnabled && !isItemDisabled);
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Get the selection propagation rules.
|
|
43
|
-
* @param {TreeViewState<[UseTreeViewSelectionSignature]>} state The state of the tree view.
|
|
44
|
-
* @returns {TreeViewSelectionPropagation} The selection propagation rules.
|
|
45
|
-
*/
|
|
46
|
-
export const selectorSelectionPropagationRules = createSelector([selectorTreeViewSelectionState], selectionState => selectionState.selectionPropagation);
|