@itwin/tree-widget-react 3.0.0-dev.1 → 3.0.0-dev.3

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.
Files changed (233) hide show
  1. package/README.md +136 -1
  2. package/lib/cjs/components/SelectableTree.d.ts +12 -6
  3. package/lib/cjs/components/SelectableTree.js.map +1 -1
  4. package/lib/cjs/components/TreeSelector.d.ts +2 -2
  5. package/lib/cjs/components/TreeSelector.js.map +1 -1
  6. package/lib/cjs/components/TreeWidgetUiItemsProvider.d.ts +3 -2
  7. package/lib/cjs/components/TreeWidgetUiItemsProvider.js.map +1 -1
  8. package/lib/cjs/components/tree-header/TreeHeader.d.ts +1 -1
  9. package/lib/cjs/components/tree-header/TreeHeader.js.map +1 -1
  10. package/lib/cjs/components/trees/categories-tree/CategoriesTree.d.ts +6 -5
  11. package/lib/cjs/components/trees/categories-tree/CategoriesTree.js +8 -9
  12. package/lib/cjs/components/trees/categories-tree/CategoriesTree.js.map +1 -1
  13. package/lib/cjs/components/trees/categories-tree/CategoriesTreeButtons.d.ts +3 -3
  14. package/lib/cjs/components/trees/categories-tree/CategoriesTreeButtons.js +3 -3
  15. package/lib/cjs/components/trees/categories-tree/CategoriesTreeButtons.js.map +1 -1
  16. package/lib/cjs/components/trees/categories-tree/CategoriesTreeComponent.d.ts +4 -4
  17. package/lib/cjs/components/trees/categories-tree/CategoriesTreeComponent.js +7 -7
  18. package/lib/cjs/components/trees/categories-tree/CategoriesTreeComponent.js.map +1 -1
  19. package/lib/cjs/components/trees/common/CategoriesVisibilityUtils.d.ts +1 -5
  20. package/lib/cjs/components/trees/common/CategoriesVisibilityUtils.js +0 -5
  21. package/lib/cjs/components/trees/common/CategoriesVisibilityUtils.js.map +1 -1
  22. package/lib/cjs/components/trees/common/FocusedInstancesContext.d.ts +0 -3
  23. package/lib/cjs/components/trees/common/FocusedInstancesContext.js +0 -2
  24. package/lib/cjs/components/trees/common/FocusedInstancesContext.js.map +1 -1
  25. package/lib/cjs/components/trees/common/FocusedInstancesContextProvider.d.ts +0 -1
  26. package/lib/cjs/components/trees/common/FocusedInstancesContextProvider.js +0 -1
  27. package/lib/cjs/components/trees/common/FocusedInstancesContextProvider.js.map +1 -1
  28. package/lib/cjs/components/trees/common/UseFiltering.d.ts +0 -1
  29. package/lib/cjs/components/trees/common/UseFiltering.js +0 -1
  30. package/lib/cjs/components/trees/common/UseFiltering.js.map +1 -1
  31. package/lib/cjs/components/trees/common/UseHierarchiesLocalization.d.ts +0 -1
  32. package/lib/cjs/components/trees/common/UseHierarchiesLocalization.js +1 -1
  33. package/lib/cjs/components/trees/common/UseHierarchiesLocalization.js.map +1 -1
  34. package/lib/cjs/components/trees/common/UseHierarchyFiltering.d.ts +1 -7
  35. package/lib/cjs/components/trees/common/UseHierarchyFiltering.js +4 -3
  36. package/lib/cjs/components/trees/common/UseHierarchyFiltering.js.map +1 -1
  37. package/lib/cjs/components/trees/common/UseHierarchyVisibility.d.ts +15 -10
  38. package/lib/cjs/components/trees/common/UseHierarchyVisibility.js +20 -17
  39. package/lib/cjs/components/trees/common/UseHierarchyVisibility.js.map +1 -1
  40. package/lib/cjs/components/trees/common/UseIModelChangeListener.d.ts +0 -1
  41. package/lib/cjs/components/trees/common/UseIModelChangeListener.js +0 -1
  42. package/lib/cjs/components/trees/common/UseIModelChangeListener.js.map +1 -1
  43. package/lib/cjs/components/trees/common/UseMultiCheckboxHandler.d.ts +0 -1
  44. package/lib/cjs/components/trees/common/UseMultiCheckboxHandler.js +0 -1
  45. package/lib/cjs/components/trees/common/UseMultiCheckboxHandler.js.map +1 -1
  46. package/lib/cjs/components/trees/common/UseNodeHighlighting.d.ts +9 -5
  47. package/lib/cjs/components/trees/common/UseNodeHighlighting.js +15 -24
  48. package/lib/cjs/components/trees/common/UseNodeHighlighting.js.map +1 -1
  49. package/lib/cjs/components/trees/common/UseTelemetryContext.d.ts +29 -0
  50. package/lib/cjs/components/trees/common/UseTelemetryContext.js +49 -0
  51. package/lib/cjs/components/trees/common/UseTelemetryContext.js.map +1 -0
  52. package/lib/cjs/components/trees/common/Utils.d.ts +3 -0
  53. package/lib/cjs/components/trees/common/Utils.js +11 -1
  54. package/lib/cjs/components/trees/common/Utils.js.map +1 -1
  55. package/lib/cjs/components/trees/common/components/Delayed.d.ts +0 -1
  56. package/lib/cjs/components/trees/common/components/Delayed.js +0 -1
  57. package/lib/cjs/components/trees/common/components/Delayed.js.map +1 -1
  58. package/lib/cjs/components/trees/common/components/ProgressOverlay.d.ts +0 -1
  59. package/lib/cjs/components/trees/common/components/ProgressOverlay.js +0 -1
  60. package/lib/cjs/components/trees/common/components/ProgressOverlay.js.map +1 -1
  61. package/lib/cjs/components/trees/common/components/Tree.d.ts +54 -0
  62. package/lib/cjs/components/trees/common/components/{BaseTree.js → Tree.js} +26 -22
  63. package/lib/cjs/components/trees/common/components/Tree.js.map +1 -0
  64. package/lib/cjs/components/trees/common/components/TreeNodeCheckbox.d.ts +14 -7
  65. package/lib/cjs/components/trees/common/components/TreeNodeCheckbox.js.map +1 -1
  66. package/lib/cjs/components/trees/common/components/TreeNodeRenderer.d.ts +7 -6
  67. package/lib/cjs/components/trees/common/components/TreeNodeRenderer.js +1 -1
  68. package/lib/cjs/components/trees/common/components/TreeNodeRenderer.js.map +1 -1
  69. package/lib/cjs/components/trees/common/components/TreeRenderer.d.ts +13 -5
  70. package/lib/cjs/components/trees/common/components/TreeRenderer.js +21 -4
  71. package/lib/cjs/components/trees/common/components/TreeRenderer.js.map +1 -1
  72. package/lib/cjs/components/trees/common/components/VisibilityTree.d.ts +27 -9
  73. package/lib/cjs/components/trees/common/components/VisibilityTree.js +8 -23
  74. package/lib/cjs/components/trees/common/components/VisibilityTree.js.map +1 -1
  75. package/lib/cjs/components/trees/common/components/VisibilityTreeRenderer.d.ts +12 -0
  76. package/lib/cjs/components/trees/common/components/VisibilityTreeRenderer.js +26 -0
  77. package/lib/cjs/components/trees/common/components/VisibilityTreeRenderer.js.map +1 -0
  78. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTree.d.ts +8 -7
  79. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTree.js +7 -10
  80. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTree.js.map +1 -1
  81. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTreeComponent.d.ts +5 -5
  82. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js +3 -3
  83. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js.map +1 -1
  84. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTree.d.ts +8 -7
  85. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTree.js +9 -12
  86. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTree.js.map +1 -1
  87. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTreeComponent.d.ts +5 -5
  88. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTreeComponent.js +3 -3
  89. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTreeComponent.js.map +1 -1
  90. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTreeDefinition.js.map +1 -1
  91. package/lib/cjs/components/trees/index.d.ts +7 -0
  92. package/lib/cjs/components/trees/index.js +11 -1
  93. package/lib/cjs/components/trees/index.js.map +1 -1
  94. package/lib/cjs/components/trees/models-tree/ModelsTree.d.ts +10 -9
  95. package/lib/cjs/components/trees/models-tree/ModelsTree.js +19 -20
  96. package/lib/cjs/components/trees/models-tree/ModelsTree.js.map +1 -1
  97. package/lib/cjs/components/trees/models-tree/ModelsTreeButtons.d.ts +10 -5
  98. package/lib/cjs/components/trees/models-tree/ModelsTreeButtons.js +19 -6
  99. package/lib/cjs/components/trees/models-tree/ModelsTreeButtons.js.map +1 -1
  100. package/lib/cjs/components/trees/models-tree/ModelsTreeComponent.d.ts +11 -5
  101. package/lib/cjs/components/trees/models-tree/ModelsTreeComponent.js +15 -23
  102. package/lib/cjs/components/trees/models-tree/ModelsTreeComponent.js.map +1 -1
  103. package/lib/cjs/components/trees/models-tree/ModelsTreeDefinition.d.ts +9 -5
  104. package/lib/cjs/components/trees/models-tree/ModelsTreeDefinition.js.map +1 -1
  105. package/lib/cjs/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.d.ts +11 -3
  106. package/lib/cjs/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js.map +1 -1
  107. package/lib/cjs/tree-widget-react.d.ts +1 -1
  108. package/lib/cjs/tree-widget-react.js.map +1 -1
  109. package/lib/esm/components/SelectableTree.d.ts +12 -6
  110. package/lib/esm/components/SelectableTree.js.map +1 -1
  111. package/lib/esm/components/TreeSelector.d.ts +2 -2
  112. package/lib/esm/components/TreeSelector.js.map +1 -1
  113. package/lib/esm/components/TreeWidgetUiItemsProvider.d.ts +3 -2
  114. package/lib/esm/components/TreeWidgetUiItemsProvider.js.map +1 -1
  115. package/lib/esm/components/tree-header/TreeHeader.d.ts +1 -1
  116. package/lib/esm/components/tree-header/TreeHeader.js.map +1 -1
  117. package/lib/esm/components/trees/categories-tree/CategoriesTree.d.ts +6 -5
  118. package/lib/esm/components/trees/categories-tree/CategoriesTree.js +8 -9
  119. package/lib/esm/components/trees/categories-tree/CategoriesTree.js.map +1 -1
  120. package/lib/esm/components/trees/categories-tree/CategoriesTreeButtons.d.ts +3 -3
  121. package/lib/esm/components/trees/categories-tree/CategoriesTreeButtons.js +3 -3
  122. package/lib/esm/components/trees/categories-tree/CategoriesTreeButtons.js.map +1 -1
  123. package/lib/esm/components/trees/categories-tree/CategoriesTreeComponent.d.ts +4 -4
  124. package/lib/esm/components/trees/categories-tree/CategoriesTreeComponent.js +7 -7
  125. package/lib/esm/components/trees/categories-tree/CategoriesTreeComponent.js.map +1 -1
  126. package/lib/esm/components/trees/common/CategoriesVisibilityUtils.d.ts +1 -5
  127. package/lib/esm/components/trees/common/CategoriesVisibilityUtils.js +0 -5
  128. package/lib/esm/components/trees/common/CategoriesVisibilityUtils.js.map +1 -1
  129. package/lib/esm/components/trees/common/FocusedInstancesContext.d.ts +0 -3
  130. package/lib/esm/components/trees/common/FocusedInstancesContext.js +0 -2
  131. package/lib/esm/components/trees/common/FocusedInstancesContext.js.map +1 -1
  132. package/lib/esm/components/trees/common/FocusedInstancesContextProvider.d.ts +0 -1
  133. package/lib/esm/components/trees/common/FocusedInstancesContextProvider.js +0 -1
  134. package/lib/esm/components/trees/common/FocusedInstancesContextProvider.js.map +1 -1
  135. package/lib/esm/components/trees/common/UseFiltering.d.ts +0 -1
  136. package/lib/esm/components/trees/common/UseFiltering.js +0 -1
  137. package/lib/esm/components/trees/common/UseFiltering.js.map +1 -1
  138. package/lib/esm/components/trees/common/UseHierarchiesLocalization.d.ts +0 -1
  139. package/lib/esm/components/trees/common/UseHierarchiesLocalization.js +1 -1
  140. package/lib/esm/components/trees/common/UseHierarchiesLocalization.js.map +1 -1
  141. package/lib/esm/components/trees/common/UseHierarchyFiltering.d.ts +1 -7
  142. package/lib/esm/components/trees/common/UseHierarchyFiltering.js +4 -3
  143. package/lib/esm/components/trees/common/UseHierarchyFiltering.js.map +1 -1
  144. package/lib/esm/components/trees/common/UseHierarchyVisibility.d.ts +15 -10
  145. package/lib/esm/components/trees/common/UseHierarchyVisibility.js +20 -17
  146. package/lib/esm/components/trees/common/UseHierarchyVisibility.js.map +1 -1
  147. package/lib/esm/components/trees/common/UseIModelChangeListener.d.ts +0 -1
  148. package/lib/esm/components/trees/common/UseIModelChangeListener.js +0 -1
  149. package/lib/esm/components/trees/common/UseIModelChangeListener.js.map +1 -1
  150. package/lib/esm/components/trees/common/UseMultiCheckboxHandler.d.ts +0 -1
  151. package/lib/esm/components/trees/common/UseMultiCheckboxHandler.js +0 -1
  152. package/lib/esm/components/trees/common/UseMultiCheckboxHandler.js.map +1 -1
  153. package/lib/esm/components/trees/common/UseNodeHighlighting.d.ts +9 -5
  154. package/lib/esm/components/trees/common/UseNodeHighlighting.js +14 -23
  155. package/lib/esm/components/trees/common/UseNodeHighlighting.js.map +1 -1
  156. package/lib/esm/components/trees/common/UseTelemetryContext.d.ts +29 -0
  157. package/lib/esm/components/trees/common/UseTelemetryContext.js +43 -0
  158. package/lib/esm/components/trees/common/UseTelemetryContext.js.map +1 -0
  159. package/lib/esm/components/trees/common/Utils.d.ts +3 -0
  160. package/lib/esm/components/trees/common/Utils.js +9 -0
  161. package/lib/esm/components/trees/common/Utils.js.map +1 -1
  162. package/lib/esm/components/trees/common/components/Delayed.d.ts +0 -1
  163. package/lib/esm/components/trees/common/components/Delayed.js +0 -1
  164. package/lib/esm/components/trees/common/components/Delayed.js.map +1 -1
  165. package/lib/esm/components/trees/common/components/ProgressOverlay.d.ts +0 -1
  166. package/lib/esm/components/trees/common/components/ProgressOverlay.js +0 -1
  167. package/lib/esm/components/trees/common/components/ProgressOverlay.js.map +1 -1
  168. package/lib/esm/components/trees/common/components/Tree.d.ts +54 -0
  169. package/lib/esm/components/trees/common/components/{BaseTree.js → Tree.js} +25 -21
  170. package/lib/esm/components/trees/common/components/Tree.js.map +1 -0
  171. package/lib/esm/components/trees/common/components/TreeNodeCheckbox.d.ts +14 -7
  172. package/lib/esm/components/trees/common/components/TreeNodeCheckbox.js.map +1 -1
  173. package/lib/esm/components/trees/common/components/TreeNodeRenderer.d.ts +7 -6
  174. package/lib/esm/components/trees/common/components/TreeNodeRenderer.js +1 -1
  175. package/lib/esm/components/trees/common/components/TreeNodeRenderer.js.map +1 -1
  176. package/lib/esm/components/trees/common/components/TreeRenderer.d.ts +13 -5
  177. package/lib/esm/components/trees/common/components/TreeRenderer.js +21 -4
  178. package/lib/esm/components/trees/common/components/TreeRenderer.js.map +1 -1
  179. package/lib/esm/components/trees/common/components/VisibilityTree.d.ts +27 -9
  180. package/lib/esm/components/trees/common/components/VisibilityTree.js +8 -23
  181. package/lib/esm/components/trees/common/components/VisibilityTree.js.map +1 -1
  182. package/lib/esm/components/trees/common/components/VisibilityTreeRenderer.d.ts +12 -0
  183. package/lib/esm/components/trees/common/components/VisibilityTreeRenderer.js +22 -0
  184. package/lib/esm/components/trees/common/components/VisibilityTreeRenderer.js.map +1 -0
  185. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTree.d.ts +8 -7
  186. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTree.js +7 -10
  187. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTree.js.map +1 -1
  188. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTreeComponent.d.ts +5 -5
  189. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js +3 -3
  190. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js.map +1 -1
  191. package/lib/esm/components/trees/imodel-content-tree/IModelContentTree.d.ts +8 -7
  192. package/lib/esm/components/trees/imodel-content-tree/IModelContentTree.js +9 -12
  193. package/lib/esm/components/trees/imodel-content-tree/IModelContentTree.js.map +1 -1
  194. package/lib/esm/components/trees/imodel-content-tree/IModelContentTreeComponent.d.ts +5 -5
  195. package/lib/esm/components/trees/imodel-content-tree/IModelContentTreeComponent.js +3 -3
  196. package/lib/esm/components/trees/imodel-content-tree/IModelContentTreeComponent.js.map +1 -1
  197. package/lib/esm/components/trees/imodel-content-tree/IModelContentTreeDefinition.js.map +1 -1
  198. package/lib/esm/components/trees/index.d.ts +7 -0
  199. package/lib/esm/components/trees/index.js +5 -0
  200. package/lib/esm/components/trees/index.js.map +1 -1
  201. package/lib/esm/components/trees/models-tree/ModelsTree.d.ts +10 -9
  202. package/lib/esm/components/trees/models-tree/ModelsTree.js +19 -20
  203. package/lib/esm/components/trees/models-tree/ModelsTree.js.map +1 -1
  204. package/lib/esm/components/trees/models-tree/ModelsTreeButtons.d.ts +10 -5
  205. package/lib/esm/components/trees/models-tree/ModelsTreeButtons.js +18 -6
  206. package/lib/esm/components/trees/models-tree/ModelsTreeButtons.js.map +1 -1
  207. package/lib/esm/components/trees/models-tree/ModelsTreeComponent.d.ts +11 -5
  208. package/lib/esm/components/trees/models-tree/ModelsTreeComponent.js +16 -24
  209. package/lib/esm/components/trees/models-tree/ModelsTreeComponent.js.map +1 -1
  210. package/lib/esm/components/trees/models-tree/ModelsTreeDefinition.d.ts +9 -5
  211. package/lib/esm/components/trees/models-tree/ModelsTreeDefinition.js.map +1 -1
  212. package/lib/esm/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.d.ts +11 -3
  213. package/lib/esm/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js.map +1 -1
  214. package/lib/esm/tree-widget-react.d.ts +1 -1
  215. package/lib/esm/tree-widget-react.js.map +1 -1
  216. package/lib/public/locales/en/TreeWidget.json +2 -1
  217. package/package.json +2 -2
  218. package/lib/cjs/components/trees/common/UseFeatureReporting.d.ts +0 -34
  219. package/lib/cjs/components/trees/common/UseFeatureReporting.js +0 -39
  220. package/lib/cjs/components/trees/common/UseFeatureReporting.js.map +0 -1
  221. package/lib/cjs/components/trees/common/UsePerformanceReporting.d.ts +0 -18
  222. package/lib/cjs/components/trees/common/UsePerformanceReporting.js +0 -25
  223. package/lib/cjs/components/trees/common/UsePerformanceReporting.js.map +0 -1
  224. package/lib/cjs/components/trees/common/components/BaseTree.d.ts +0 -34
  225. package/lib/cjs/components/trees/common/components/BaseTree.js.map +0 -1
  226. package/lib/esm/components/trees/common/UseFeatureReporting.d.ts +0 -34
  227. package/lib/esm/components/trees/common/UseFeatureReporting.js +0 -34
  228. package/lib/esm/components/trees/common/UseFeatureReporting.js.map +0 -1
  229. package/lib/esm/components/trees/common/UsePerformanceReporting.d.ts +0 -18
  230. package/lib/esm/components/trees/common/UsePerformanceReporting.js +0 -21
  231. package/lib/esm/components/trees/common/UsePerformanceReporting.js.map +0 -1
  232. package/lib/esm/components/trees/common/components/BaseTree.d.ts +0 -34
  233. package/lib/esm/components/trees/common/components/BaseTree.js.map +0 -1
@@ -0,0 +1,54 @@
1
+ import { useSelectionHandler } from "@itwin/presentation-hierarchies-react";
2
+ import type { ComponentPropsWithoutRef, ReactNode } from "react";
3
+ import type { IModelConnection } from "@itwin/core-frontend";
4
+ import type { SchemaContext } from "@itwin/ecschema-metadata";
5
+ import type { SelectionStorage, useTree } from "@itwin/presentation-hierarchies-react";
6
+ import type { HighlightInfo } from "../UseNodeHighlighting";
7
+ import type { TreeRenderer } from "./TreeRenderer";
8
+ /**
9
+ * Properties that are passed to `treeRenderer` from `Tree` component.
10
+ * @beta
11
+ */
12
+ export type TreeRendererProps = Required<Pick<ComponentPropsWithoutRef<typeof TreeRenderer>, "rootNodes" | "expandNode" | "onNodeClick" | "onNodeKeyDown" | "onFilterClick" | "isNodeSelected" | "getHierarchyLevelDetails" | "size" | "getLabel">>;
13
+ /** @beta */
14
+ interface TreeOwnProps {
15
+ height: number;
16
+ width: number;
17
+ /** iModel connection that should be used to pull data from. */
18
+ imodel: IModelConnection;
19
+ /** Callback for getting `SchemaContext` for specific iModel. */
20
+ getSchemaContext: (imodel: IModelConnection) => SchemaContext;
21
+ /** Unique tree component name that will be used as unified selection change event source when selecting node. */
22
+ treeName: string;
23
+ /** Unified selection storage that should be used by tree to handle tree selection changes. */
24
+ selectionStorage: SelectionStorage;
25
+ /** Tree renderer that should be used to render tree data. */
26
+ treeRenderer: (treeProps: TreeRendererProps) => ReactNode;
27
+ /** Custom iModel access that is stored outside tree component. If not provided it new iModel access will be created using `imodel` prop. */
28
+ imodelAccess?: IModelAccess;
29
+ /** Size limit that should be applied on each hierarchy level. Default to `1000`. */
30
+ hierarchyLevelSizeLimit?: number;
31
+ /** Modifies the density of tree nodes. `enlarged` tree nodes have bigger button hit boxes. */
32
+ density?: "default" | "enlarged";
33
+ /** Message that should be renderer if there are no tree nodes. */
34
+ noDataMessage?: ReactNode;
35
+ /** Callback that this invoked when tree reloads. */
36
+ onReload?: () => void;
37
+ /** Options for highlighting node labels. */
38
+ highlight?: HighlightInfo;
39
+ }
40
+ /** @beta */
41
+ type UseTreeProps = Parameters<typeof useTree>[0];
42
+ /** @beta */
43
+ type UseSelectionHandlerProps = Parameters<typeof useSelectionHandler>[0];
44
+ /** @beta */
45
+ type IModelAccess = UseTreeProps["imodelAccess"];
46
+ /** @beta */
47
+ type TreeProps = TreeOwnProps & Pick<UseTreeProps, "getFilteredPaths" | "getHierarchyDefinition"> & Pick<Partial<UseSelectionHandlerProps>, "selectionMode">;
48
+ /**
49
+ * Default tree component that manages tree state and renders using supplied `treeRenderer`.
50
+ * @Beta
51
+ */
52
+ export declare function Tree({ getSchemaContext, hierarchyLevelSizeLimit, selectionStorage, imodelAccess: providedIModelAccess, ...props }: TreeProps): JSX.Element;
53
+ export {};
54
+ //# sourceMappingURL=Tree.d.ts.map
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BaseTree = void 0;
3
+ exports.Tree = void 0;
4
4
  const jsx_runtime_1 = require("react/jsx-runtime");
5
5
  /*---------------------------------------------------------------------------------------------
6
6
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
@@ -11,48 +11,55 @@ const itwinui_react_1 = require("@itwin/itwinui-react");
11
11
  const presentation_components_1 = require("@itwin/presentation-components");
12
12
  const presentation_hierarchies_react_1 = require("@itwin/presentation-hierarchies-react");
13
13
  const TreeWidget_1 = require("../../../../TreeWidget");
14
- const UseFeatureReporting_1 = require("../UseFeatureReporting");
15
14
  const UseHierarchiesLocalization_1 = require("../UseHierarchiesLocalization");
16
15
  const UseHierarchyFiltering_1 = require("../UseHierarchyFiltering");
17
16
  const UseIModelChangeListener_1 = require("../UseIModelChangeListener");
18
17
  const UseNodeHighlighting_1 = require("../UseNodeHighlighting");
18
+ const UseTelemetryContext_1 = require("../UseTelemetryContext");
19
19
  const Utils_1 = require("../Utils");
20
20
  const Delayed_1 = require("./Delayed");
21
21
  const ProgressOverlay_1 = require("./ProgressOverlay");
22
- const TreeRenderer_1 = require("./TreeRenderer");
23
- /** @internal */
24
- function BaseTree({ getSchemaContext, hierarchyLevelSizeLimit, imodelAccess: providedIModelAccess, ...props }) {
22
+ /**
23
+ * Default tree component that manages tree state and renders using supplied `treeRenderer`.
24
+ * @Beta
25
+ */
26
+ function Tree({ getSchemaContext, hierarchyLevelSizeLimit, selectionStorage, imodelAccess: providedIModelAccess, ...props }) {
25
27
  const defaultHierarchyLevelSizeLimit = hierarchyLevelSizeLimit ?? 1000;
26
28
  const imodelAccess = (0, react_1.useMemo)(() => {
27
29
  return providedIModelAccess ?? (0, Utils_1.createIModelAccess)({ getSchemaContext, imodel: props.imodel });
28
30
  }, [providedIModelAccess, getSchemaContext, props.imodel]);
29
- return ((0, jsx_runtime_1.jsx)(presentation_components_1.SchemaMetadataContextProvider, { imodel: props.imodel, schemaContextProvider: getSchemaContext, children: (0, jsx_runtime_1.jsx)(BaseTreeRenderer, { ...props, imodelAccess: imodelAccess, defaultHierarchyLevelSizeLimit: defaultHierarchyLevelSizeLimit }) }));
31
+ return ((0, jsx_runtime_1.jsx)(presentation_components_1.SchemaMetadataContextProvider, { imodel: props.imodel, schemaContextProvider: getSchemaContext, children: (0, jsx_runtime_1.jsx)(presentation_hierarchies_react_1.UnifiedSelectionProvider, { storage: selectionStorage, children: (0, jsx_runtime_1.jsx)(TreeImpl, { ...props, imodelAccess: imodelAccess, defaultHierarchyLevelSizeLimit: defaultHierarchyLevelSizeLimit }) }) }));
30
32
  }
31
- exports.BaseTree = BaseTree;
32
- /** @internal */
33
- function BaseTreeRenderer({ imodel, imodelAccess, height, width, treeName, noDataMessage, getFilteredPaths, defaultHierarchyLevelSizeLimit, getHierarchyDefinition, selectionMode, onPerformanceMeasured, reportUsage, treeRenderer, density, getIcon, getSublabel, onNodeDoubleClick, searchText, }) {
33
+ exports.Tree = Tree;
34
+ function TreeImpl({ imodel, imodelAccess, height, width, treeName, noDataMessage, getFilteredPaths, defaultHierarchyLevelSizeLimit, getHierarchyDefinition, selectionMode, onReload, treeRenderer, density, highlight, }) {
34
35
  const localizedStrings = (0, UseHierarchiesLocalization_1.useHierarchiesLocalization)();
35
- const { rootNodes, isLoading, reloadTree, selectNodes, setFormatter: _setFormatter, expandNode, ...treeProps } = (0, presentation_hierarchies_react_1.useUnifiedSelectionTree)({
36
+ const { onFeatureUsed, onPerformanceMeasured } = (0, UseTelemetryContext_1.useTelemetryContext)();
37
+ const { rootNodes, isLoading, selectNodes, setFormatter: _setFormatter, expandNode, ...treeProps } = (0, presentation_hierarchies_react_1.useUnifiedSelectionTree)({
36
38
  imodelAccess,
37
39
  getHierarchyDefinition,
38
40
  getFilteredPaths,
39
41
  imodelKey: imodel.key,
40
42
  sourceName: treeName,
41
43
  localizedStrings,
42
- onPerformanceMeasured,
43
- onHierarchyLimitExceeded: () => reportUsage?.({ featureId: "hierarchy-level-size-limit-hit", reportInteraction: false }),
44
+ onPerformanceMeasured: (action, duration) => {
45
+ if (action === "reload") {
46
+ onReload?.();
47
+ }
48
+ onPerformanceMeasured(action, duration);
49
+ },
50
+ onHierarchyLimitExceeded: () => onFeatureUsed({ featureId: "hierarchy-level-size-limit-hit", reportInteraction: false }),
44
51
  });
52
+ const reloadTree = treeProps.reloadTree;
45
53
  (0, UseIModelChangeListener_1.useIModelChangeListener)({ imodel, action: (0, react_1.useCallback)(() => reloadTree({ dataSourceChanged: true }), [reloadTree]) });
46
- const reportingSelectNodes = (0, UseFeatureReporting_1.useReportingAction)({ action: selectNodes, reportUsage });
54
+ const reportingSelectNodes = (0, UseTelemetryContext_1.useReportingAction)({ action: selectNodes });
47
55
  const { onNodeClick, onNodeKeyDown } = (0, presentation_hierarchies_react_1.useSelectionHandler)({ rootNodes, selectNodes: reportingSelectNodes, selectionMode: selectionMode ?? "single" });
48
56
  const { filteringDialog, onFilterClick } = (0, UseHierarchyFiltering_1.useHierarchyLevelFiltering)({
49
57
  imodel,
50
58
  defaultHierarchyLevelSizeLimit,
51
- reportUsage,
52
59
  });
53
- const reportingExpandNode = (0, UseFeatureReporting_1.useReportingAction)({ action: expandNode, reportUsage });
54
- const reportingOnFilterClicked = (0, UseFeatureReporting_1.useReportingAction)({ action: onFilterClick, reportUsage });
55
- const { getLabel } = (0, UseNodeHighlighting_1.useNodeHighlighting)({ rootNodes, searchText });
60
+ const reportingExpandNode = (0, UseTelemetryContext_1.useReportingAction)({ action: expandNode });
61
+ const reportingOnFilterClicked = (0, UseTelemetryContext_1.useReportingAction)({ action: onFilterClick });
62
+ const { getLabel } = (0, UseNodeHighlighting_1.useNodeHighlighting)({ rootNodes, highlight });
56
63
  if (rootNodes === undefined) {
57
64
  return ((0, jsx_runtime_1.jsx)(itwinui_react_1.Flex, { alignItems: "center", justifyContent: "center", flexDirection: "column", style: { width, height }, children: (0, jsx_runtime_1.jsx)(Delayed_1.Delayed, { show: true, children: (0, jsx_runtime_1.jsx)(itwinui_react_1.ProgressRadial, { size: "large" }) }) }));
58
65
  }
@@ -66,12 +73,9 @@ function BaseTreeRenderer({ imodel, imodelAccess, height, width, treeName, noDat
66
73
  onNodeKeyDown,
67
74
  expandNode: reportingExpandNode,
68
75
  onFilterClick: reportingOnFilterClicked,
69
- getIcon,
70
76
  getLabel,
71
- getSublabel,
72
- onNodeDoubleClick,
73
77
  size: density === "enlarged" ? "default" : "small",
74
78
  };
75
- return ((0, jsx_runtime_1.jsxs)("div", { style: { position: "relative", height, overflow: "hidden" }, children: [(0, jsx_runtime_1.jsxs)("div", { id: "tw-tree-renderer-container", style: { overflow: "auto", height: "100%" }, children: [treeRenderer ? treeRenderer(treeRendererProps) : (0, jsx_runtime_1.jsx)(TreeRenderer_1.TreeRenderer, { ...treeRendererProps }), filteringDialog] }), (0, jsx_runtime_1.jsx)(Delayed_1.Delayed, { show: isLoading, children: (0, jsx_runtime_1.jsx)(ProgressOverlay_1.ProgressOverlay, {}) })] }));
79
+ return ((0, jsx_runtime_1.jsxs)("div", { style: { position: "relative", height, overflow: "hidden" }, children: [(0, jsx_runtime_1.jsxs)("div", { id: "tw-tree-renderer-container", style: { overflow: "auto", height: "100%" }, children: [treeRenderer(treeRendererProps), filteringDialog] }), (0, jsx_runtime_1.jsx)(Delayed_1.Delayed, { show: isLoading, children: (0, jsx_runtime_1.jsx)(ProgressOverlay_1.ProgressOverlay, {}) })] }));
76
80
  }
77
- //# sourceMappingURL=BaseTree.js.map
81
+ //# sourceMappingURL=Tree.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Tree.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/Tree.tsx"],"names":[],"mappings":";;;;AAAA;;;gGAGgG;AAEhG,iCAA6C;AAC7C,wDAAkE;AAClE,4EAA+E;AAC/E,0FAA+H;AAC/H,uDAAoD;AACpD,8EAA2E;AAC3E,oEAAsE;AACtE,wEAAqE;AACrE,gEAA6D;AAC7D,gEAAiF;AACjF,oCAA8C;AAC9C,uCAAoC;AACpC,uDAAoD;AA6DpD;;;GAGG;AACH,SAAgB,IAAI,CAAC,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,KAAK,EAAa;IAC3I,MAAM,8BAA8B,GAAG,uBAAuB,IAAI,IAAI,CAAC;IAEvE,MAAM,YAAY,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE;QAChC,OAAO,oBAAoB,IAAI,IAAA,0BAAkB,EAAC,EAAE,gBAAgB,EAAE,MAAM,EAAE,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;IAChG,CAAC,EAAE,CAAC,oBAAoB,EAAE,gBAAgB,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IAE3D,OAAO,CACL,uBAAC,uDAA6B,IAAC,MAAM,EAAE,KAAK,CAAC,MAAM,EAAE,qBAAqB,EAAE,gBAAgB,YAC1F,uBAAC,yDAAwB,IAAC,OAAO,EAAE,gBAAgB,YACjD,uBAAC,QAAQ,OAAK,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,8BAA8B,EAAE,8BAA8B,GAAI,GAC1F,GACG,CACjC,CAAC;AACJ,CAAC;AAdD,oBAcC;AAED,SAAS,QAAQ,CAAC,EAChB,MAAM,EACN,YAAY,EACZ,MAAM,EACN,KAAK,EACL,QAAQ,EACR,aAAa,EACb,gBAAgB,EAChB,8BAA8B,EAC9B,sBAAsB,EACtB,aAAa,EACb,QAAQ,EACR,YAAY,EACZ,OAAO,EACP,SAAS,GAC2H;IACpI,MAAM,gBAAgB,GAAG,IAAA,uDAA0B,GAAE,CAAC;IACtD,MAAM,EAAE,aAAa,EAAE,qBAAqB,EAAE,GAAG,IAAA,yCAAmB,GAAE,CAAC;IACvE,MAAM,EACJ,SAAS,EACT,SAAS,EACT,WAAW,EACX,YAAY,EAAE,aAAa,EAC3B,UAAU,EACV,GAAG,SAAS,EACb,GAAG,IAAA,wDAAuB,EAAC;QAC1B,YAAY;QACZ,sBAAsB;QACtB,gBAAgB;QAChB,SAAS,EAAE,MAAM,CAAC,GAAG;QACrB,UAAU,EAAE,QAAQ;QACpB,gBAAgB;QAChB,qBAAqB,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;YAC1C,IAAI,MAAM,KAAK,QAAQ,EAAE;gBACvB,QAAQ,EAAE,EAAE,CAAC;aACd;YACD,qBAAqB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAC1C,CAAC;QACD,wBAAwB,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,EAAE,SAAS,EAAE,gCAAgC,EAAE,iBAAiB,EAAE,KAAK,EAAE,CAAC;KACzH,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,SAAS,CAAC,UAAU,CAAC;IACxC,IAAA,iDAAuB,EAAC,EAAE,MAAM,EAAE,MAAM,EAAE,IAAA,mBAAW,EAAC,GAAG,EAAE,CAAC,UAAU,CAAC,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC;IACtH,MAAM,oBAAoB,GAAG,IAAA,wCAAkB,EAAC,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC,CAAC;IACzE,MAAM,EAAE,WAAW,EAAE,aAAa,EAAE,GAAG,IAAA,oDAAmB,EAAC,EAAE,SAAS,EAAE,WAAW,EAAE,oBAAoB,EAAE,aAAa,EAAE,aAAa,IAAI,QAAQ,EAAE,CAAC,CAAC;IACvJ,MAAM,EAAE,eAAe,EAAE,aAAa,EAAE,GAAG,IAAA,kDAA0B,EAAC;QACpE,MAAM;QACN,8BAA8B;KAC/B,CAAC,CAAC;IACH,MAAM,mBAAmB,GAAG,IAAA,wCAAkB,EAAC,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;IACvE,MAAM,wBAAwB,GAAG,IAAA,wCAAkB,EAAC,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC;IAC/E,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAA,yCAAmB,EAAC,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;IAEnE,IAAI,SAAS,KAAK,SAAS,EAAE;QAC3B,OAAO,CACL,uBAAC,oBAAI,IAAC,UAAU,EAAC,QAAQ,EAAC,cAAc,EAAC,QAAQ,EAAC,aAAa,EAAC,QAAQ,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,YAC/F,uBAAC,iBAAO,IAAC,IAAI,EAAE,IAAI,YACjB,uBAAC,8BAAc,IAAC,IAAI,EAAC,OAAO,GAAG,GACvB,GACL,CACR,CAAC;KACH;IAED,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,SAAS,EAAE;QACxC,OAAO,CACL,uBAAC,oBAAI,IAAC,UAAU,EAAC,QAAQ,EAAC,cAAc,EAAC,QAAQ,EAAC,aAAa,EAAC,QAAQ,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,YAC9F,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,uBAAC,oBAAI,cAAE,uBAAU,CAAC,SAAS,CAAC,6BAA6B,CAAC,GAAQ,GAC9F,CACR,CAAC;KACH;IAED,MAAM,iBAAiB,GAAsB;QAC3C,GAAG,SAAS;QACZ,SAAS;QACT,WAAW;QACX,aAAa;QACb,UAAU,EAAE,mBAAmB;QAC/B,aAAa,EAAE,wBAAwB;QACvC,QAAQ;QACR,IAAI,EAAE,OAAO,KAAK,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO;KACnD,CAAC;IAEF,OAAO,CACL,iCAAK,KAAK,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,aAC9D,iCAAK,EAAE,EAAC,4BAA4B,EAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,aAC7E,YAAY,CAAC,iBAAiB,CAAC,EAC/B,eAAe,IACZ,EACN,uBAAC,iBAAO,IAAC,IAAI,EAAE,SAAS,YACtB,uBAAC,iCAAe,KAAG,GACX,IACN,CACP,CAAC;AACJ,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport { useCallback, useMemo } from \"react\";\nimport { Flex, ProgressRadial, Text } from \"@itwin/itwinui-react\";\nimport { SchemaMetadataContextProvider } from \"@itwin/presentation-components\";\nimport { UnifiedSelectionProvider, useSelectionHandler, useUnifiedSelectionTree } from \"@itwin/presentation-hierarchies-react\";\nimport { TreeWidget } from \"../../../../TreeWidget\";\nimport { useHierarchiesLocalization } from \"../UseHierarchiesLocalization\";\nimport { useHierarchyLevelFiltering } from \"../UseHierarchyFiltering\";\nimport { useIModelChangeListener } from \"../UseIModelChangeListener\";\nimport { useNodeHighlighting } from \"../UseNodeHighlighting\";\nimport { useReportingAction, useTelemetryContext } from \"../UseTelemetryContext\";\nimport { createIModelAccess } from \"../Utils\";\nimport { Delayed } from \"./Delayed\";\nimport { ProgressOverlay } from \"./ProgressOverlay\";\n\nimport type { ComponentPropsWithoutRef, ReactNode } from \"react\";\nimport type { MarkRequired } from \"@itwin/core-bentley\";\nimport type { IModelConnection } from \"@itwin/core-frontend\";\nimport type { SchemaContext } from \"@itwin/ecschema-metadata\";\nimport type { SelectionStorage, useTree } from \"@itwin/presentation-hierarchies-react\";\nimport type { HighlightInfo } from \"../UseNodeHighlighting\";\nimport type { TreeRenderer } from \"./TreeRenderer\";\n\n/**\n * Properties that are passed to `treeRenderer` from `Tree` component.\n * @beta\n */\nexport type TreeRendererProps = Required<\n Pick<\n ComponentPropsWithoutRef<typeof TreeRenderer>,\n \"rootNodes\" | \"expandNode\" | \"onNodeClick\" | \"onNodeKeyDown\" | \"onFilterClick\" | \"isNodeSelected\" | \"getHierarchyLevelDetails\" | \"size\" | \"getLabel\"\n >\n>;\n\n/** @beta */\ninterface TreeOwnProps {\n height: number;\n width: number;\n /** iModel connection that should be used to pull data from. */\n imodel: IModelConnection;\n /** Callback for getting `SchemaContext` for specific iModel. */\n getSchemaContext: (imodel: IModelConnection) => SchemaContext;\n /** Unique tree component name that will be used as unified selection change event source when selecting node. */\n treeName: string;\n /** Unified selection storage that should be used by tree to handle tree selection changes. */\n selectionStorage: SelectionStorage;\n /** Tree renderer that should be used to render tree data. */\n treeRenderer: (treeProps: TreeRendererProps) => ReactNode;\n /** Custom iModel access that is stored outside tree component. If not provided it new iModel access will be created using `imodel` prop. */\n imodelAccess?: IModelAccess;\n /** Size limit that should be applied on each hierarchy level. Default to `1000`. */\n hierarchyLevelSizeLimit?: number;\n /** Modifies the density of tree nodes. `enlarged` tree nodes have bigger button hit boxes. */\n density?: \"default\" | \"enlarged\";\n /** Message that should be renderer if there are no tree nodes. */\n noDataMessage?: ReactNode;\n /** Callback that this invoked when tree reloads. */\n onReload?: () => void;\n /** Options for highlighting node labels. */\n highlight?: HighlightInfo;\n}\n\n/** @beta */\ntype UseTreeProps = Parameters<typeof useTree>[0];\n\n/** @beta */\ntype UseSelectionHandlerProps = Parameters<typeof useSelectionHandler>[0];\n\n/** @beta */\ntype IModelAccess = UseTreeProps[\"imodelAccess\"];\n\n/** @beta */\ntype TreeProps = TreeOwnProps & Pick<UseTreeProps, \"getFilteredPaths\" | \"getHierarchyDefinition\"> & Pick<Partial<UseSelectionHandlerProps>, \"selectionMode\">;\n\n/**\n * Default tree component that manages tree state and renders using supplied `treeRenderer`.\n * @Beta\n */\nexport function Tree({ getSchemaContext, hierarchyLevelSizeLimit, selectionStorage, imodelAccess: providedIModelAccess, ...props }: TreeProps) {\n const defaultHierarchyLevelSizeLimit = hierarchyLevelSizeLimit ?? 1000;\n\n const imodelAccess = useMemo(() => {\n return providedIModelAccess ?? createIModelAccess({ getSchemaContext, imodel: props.imodel });\n }, [providedIModelAccess, getSchemaContext, props.imodel]);\n\n return (\n <SchemaMetadataContextProvider imodel={props.imodel} schemaContextProvider={getSchemaContext}>\n <UnifiedSelectionProvider storage={selectionStorage}>\n <TreeImpl {...props} imodelAccess={imodelAccess} defaultHierarchyLevelSizeLimit={defaultHierarchyLevelSizeLimit} />\n </UnifiedSelectionProvider>\n </SchemaMetadataContextProvider>\n );\n}\n\nfunction TreeImpl({\n imodel,\n imodelAccess,\n height,\n width,\n treeName,\n noDataMessage,\n getFilteredPaths,\n defaultHierarchyLevelSizeLimit,\n getHierarchyDefinition,\n selectionMode,\n onReload,\n treeRenderer,\n density,\n highlight,\n}: MarkRequired<Omit<TreeProps, \"getSchemaContext\" | \"selectionStorage\">, \"imodelAccess\"> & { defaultHierarchyLevelSizeLimit: number }) {\n const localizedStrings = useHierarchiesLocalization();\n const { onFeatureUsed, onPerformanceMeasured } = useTelemetryContext();\n const {\n rootNodes,\n isLoading,\n selectNodes,\n setFormatter: _setFormatter,\n expandNode,\n ...treeProps\n } = useUnifiedSelectionTree({\n imodelAccess,\n getHierarchyDefinition,\n getFilteredPaths,\n imodelKey: imodel.key,\n sourceName: treeName,\n localizedStrings,\n onPerformanceMeasured: (action, duration) => {\n if (action === \"reload\") {\n onReload?.();\n }\n onPerformanceMeasured(action, duration);\n },\n onHierarchyLimitExceeded: () => onFeatureUsed({ featureId: \"hierarchy-level-size-limit-hit\", reportInteraction: false }),\n });\n\n const reloadTree = treeProps.reloadTree;\n useIModelChangeListener({ imodel, action: useCallback(() => reloadTree({ dataSourceChanged: true }), [reloadTree]) });\n const reportingSelectNodes = useReportingAction({ action: selectNodes });\n const { onNodeClick, onNodeKeyDown } = useSelectionHandler({ rootNodes, selectNodes: reportingSelectNodes, selectionMode: selectionMode ?? \"single\" });\n const { filteringDialog, onFilterClick } = useHierarchyLevelFiltering({\n imodel,\n defaultHierarchyLevelSizeLimit,\n });\n const reportingExpandNode = useReportingAction({ action: expandNode });\n const reportingOnFilterClicked = useReportingAction({ action: onFilterClick });\n const { getLabel } = useNodeHighlighting({ rootNodes, highlight });\n\n if (rootNodes === undefined) {\n return (\n <Flex alignItems=\"center\" justifyContent=\"center\" flexDirection=\"column\" style={{ width, height }}>\n <Delayed show={true}>\n <ProgressRadial size=\"large\" />\n </Delayed>\n </Flex>\n );\n }\n\n if (rootNodes.length === 0 && !isLoading) {\n return (\n <Flex alignItems=\"center\" justifyContent=\"center\" flexDirection=\"column\" style={{ width, height }}>\n {noDataMessage ? noDataMessage : <Text>{TreeWidget.translate(\"baseTree.dataIsNotAvailable\")}</Text>}\n </Flex>\n );\n }\n\n const treeRendererProps: TreeRendererProps = {\n ...treeProps,\n rootNodes,\n onNodeClick,\n onNodeKeyDown,\n expandNode: reportingExpandNode,\n onFilterClick: reportingOnFilterClicked,\n getLabel,\n size: density === \"enlarged\" ? \"default\" : \"small\",\n };\n\n return (\n <div style={{ position: \"relative\", height, overflow: \"hidden\" }}>\n <div id=\"tw-tree-renderer-container\" style={{ overflow: \"auto\", height: \"100%\" }}>\n {treeRenderer(treeRendererProps)}\n {filteringDialog}\n </div>\n <Delayed show={isLoading}>\n <ProgressOverlay />\n </Delayed>\n </div>\n );\n}\n"]}
@@ -1,20 +1,27 @@
1
1
  import { Checkbox } from "@itwin/itwinui-react";
2
2
  import type { PresentationHierarchyNode, RenderedTreeNode } from "@itwin/presentation-hierarchies-react";
3
3
  import type { ComponentPropsWithoutRef } from "react";
4
- /** @internal */
5
- export interface TreeNodeCheckboxState {
4
+ /**
5
+ * Data structure that describes tree node checkbox state.
6
+ * @beta
7
+ */
8
+ interface TreeNodeCheckboxState {
6
9
  state: "on" | "off" | "partial";
7
10
  isDisabled?: boolean;
8
11
  tooltip?: string;
9
12
  }
10
- interface TreeNodeCheckboxOwnProps {
11
- node: RenderedTreeNode;
13
+ /** @beta */
14
+ export interface TreeCheckboxProps {
15
+ /** Callback that should be invoked when checkbox is clicked. */
12
16
  onCheckboxClicked: (node: PresentationHierarchyNode, checked: boolean) => void;
17
+ /** Callback that should be used to determine current checkbox state. */
13
18
  getCheckboxState: (node: PresentationHierarchyNode) => TreeNodeCheckboxState;
14
19
  }
15
- type CheckboxProps = ComponentPropsWithoutRef<typeof Checkbox>;
16
- type TreeNodeCheckboxProps = TreeNodeCheckboxOwnProps & Omit<CheckboxProps, "onClick" | "checked" | "onChange" | "indeterminate" | "disabled" | "title">;
17
20
  /** @internal */
18
- export declare function TreeNodeCheckbox({ node, onCheckboxClicked, getCheckboxState, ...props }: TreeNodeCheckboxProps): JSX.Element | null;
21
+ type TreeNodeCheckboxProps = TreeCheckboxProps & Omit<ComponentPropsWithoutRef<typeof Checkbox>, "onClick" | "checked" | "onChange" | "indeterminate" | "disabled" | "title">;
22
+ /** @internal */
23
+ export declare function TreeNodeCheckbox({ node, onCheckboxClicked, getCheckboxState, ...props }: TreeNodeCheckboxProps & {
24
+ node: RenderedTreeNode;
25
+ }): JSX.Element | null;
19
26
  export {};
20
27
  //# sourceMappingURL=TreeNodeCheckbox.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TreeNodeCheckbox.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/TreeNodeCheckbox.tsx"],"names":[],"mappings":";;;;;;;AAAA;;;gGAGgG;AAEhG,4DAA4B;AAC5B,wDAAgD;AAChD,0FAAoF;AAqBpF,gBAAgB;AAChB,SAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,GAAG,KAAK,EAAyB;IAC7G,IAAI,MAAM,IAAI,IAAI,IAAI,CAAC,IAAA,4DAA2B,EAAC,IAAI,CAAC,EAAE;QACxD,OAAO,IAAI,CAAC;KACb;IAED,MAAM,aAAa,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC;IAC7C,OAAO,CACL,uBAAC,wBAAQ,OACH,KAAK,EACT,SAAS,EAAE,IAAA,oBAAE,EAAC,uBAAuB,EAAE,KAAK,CAAC,SAAS,CAAC,EACvD,OAAO,EAAE,aAAa,CAAC,KAAK,KAAK,IAAI,EACrC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;YACb,CAAC,CAAC,eAAe,EAAE,CAAC;QACtB,CAAC,EACD,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;YACd,iBAAiB,CAAC,IAAI,EAAE,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACnD,CAAC,EACD,aAAa,EAAE,aAAa,CAAC,KAAK,KAAK,SAAS,EAChD,QAAQ,EAAE,aAAa,CAAC,UAAU,EAClC,KAAK,EAAE,aAAa,CAAC,OAAO,GAC5B,CACH,CAAC;AACJ,CAAC;AAtBD,4CAsBC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport cx from \"classnames\";\nimport { Checkbox } from \"@itwin/itwinui-react\";\nimport { isPresentationHierarchyNode } from \"@itwin/presentation-hierarchies-react\";\n\nimport type { PresentationHierarchyNode, RenderedTreeNode } from \"@itwin/presentation-hierarchies-react\";\nimport type { ComponentPropsWithoutRef } from \"react\";\n\n/** @internal */\nexport interface TreeNodeCheckboxState {\n state: \"on\" | \"off\" | \"partial\";\n isDisabled?: boolean;\n tooltip?: string;\n}\n\ninterface TreeNodeCheckboxOwnProps {\n node: RenderedTreeNode;\n onCheckboxClicked: (node: PresentationHierarchyNode, checked: boolean) => void;\n getCheckboxState: (node: PresentationHierarchyNode) => TreeNodeCheckboxState;\n}\n\ntype CheckboxProps = ComponentPropsWithoutRef<typeof Checkbox>;\ntype TreeNodeCheckboxProps = TreeNodeCheckboxOwnProps & Omit<CheckboxProps, \"onClick\" | \"checked\" | \"onChange\" | \"indeterminate\" | \"disabled\" | \"title\">;\n\n/** @internal */\nexport function TreeNodeCheckbox({ node, onCheckboxClicked, getCheckboxState, ...props }: TreeNodeCheckboxProps) {\n if (\"type\" in node || !isPresentationHierarchyNode(node)) {\n return null;\n }\n\n const checkboxState = getCheckboxState(node);\n return (\n <Checkbox\n {...props}\n className={cx(\"tw-tree-node-checkbox\", props.className)}\n checked={checkboxState.state === \"on\"}\n onClick={(e) => {\n e.stopPropagation();\n }}\n onChange={(e) => {\n onCheckboxClicked(node, e.currentTarget.checked);\n }}\n indeterminate={checkboxState.state === \"partial\"}\n disabled={checkboxState.isDisabled}\n title={checkboxState.tooltip}\n />\n );\n}\n"]}
1
+ {"version":3,"file":"TreeNodeCheckbox.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/TreeNodeCheckbox.tsx"],"names":[],"mappings":";;;;;;;AAAA;;;gGAGgG;AAEhG,4DAA4B;AAC5B,wDAAgD;AAChD,0FAAoF;AA2BpF,gBAAgB;AAChB,SAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,GAAG,KAAK,EAAsD;IAC1I,IAAI,MAAM,IAAI,IAAI,IAAI,CAAC,IAAA,4DAA2B,EAAC,IAAI,CAAC,EAAE;QACxD,OAAO,IAAI,CAAC;KACb;IAED,MAAM,aAAa,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC;IAC7C,OAAO,CACL,uBAAC,wBAAQ,OACH,KAAK,EACT,SAAS,EAAE,IAAA,oBAAE,EAAC,uBAAuB,EAAE,KAAK,CAAC,SAAS,CAAC,EACvD,OAAO,EAAE,aAAa,CAAC,KAAK,KAAK,IAAI,EACrC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;YACb,CAAC,CAAC,eAAe,EAAE,CAAC;QACtB,CAAC,EACD,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;YACd,iBAAiB,CAAC,IAAI,EAAE,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACnD,CAAC,EACD,aAAa,EAAE,aAAa,CAAC,KAAK,KAAK,SAAS,EAChD,QAAQ,EAAE,aAAa,CAAC,UAAU,EAClC,KAAK,EAAE,aAAa,CAAC,OAAO,GAC5B,CACH,CAAC;AACJ,CAAC;AAtBD,4CAsBC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport cx from \"classnames\";\nimport { Checkbox } from \"@itwin/itwinui-react\";\nimport { isPresentationHierarchyNode } from \"@itwin/presentation-hierarchies-react\";\n\nimport type { PresentationHierarchyNode, RenderedTreeNode } from \"@itwin/presentation-hierarchies-react\";\nimport type { ComponentPropsWithoutRef } from \"react\";\n\n/**\n * Data structure that describes tree node checkbox state.\n * @beta\n */\ninterface TreeNodeCheckboxState {\n state: \"on\" | \"off\" | \"partial\";\n isDisabled?: boolean;\n tooltip?: string;\n}\n\n/** @beta */\nexport interface TreeCheckboxProps {\n /** Callback that should be invoked when checkbox is clicked. */\n onCheckboxClicked: (node: PresentationHierarchyNode, checked: boolean) => void;\n /** Callback that should be used to determine current checkbox state. */\n getCheckboxState: (node: PresentationHierarchyNode) => TreeNodeCheckboxState;\n}\n\n/** @internal */\ntype TreeNodeCheckboxProps = TreeCheckboxProps &\n Omit<ComponentPropsWithoutRef<typeof Checkbox>, \"onClick\" | \"checked\" | \"onChange\" | \"indeterminate\" | \"disabled\" | \"title\">;\n\n/** @internal */\nexport function TreeNodeCheckbox({ node, onCheckboxClicked, getCheckboxState, ...props }: TreeNodeCheckboxProps & { node: RenderedTreeNode }) {\n if (\"type\" in node || !isPresentationHierarchyNode(node)) {\n return null;\n }\n\n const checkboxState = getCheckboxState(node);\n return (\n <Checkbox\n {...props}\n className={cx(\"tw-tree-node-checkbox\", props.className)}\n checked={checkboxState.state === \"on\"}\n onClick={(e) => {\n e.stopPropagation();\n }}\n onChange={(e) => {\n onCheckboxClicked(node, e.currentTarget.checked);\n }}\n indeterminate={checkboxState.state === \"partial\"}\n disabled={checkboxState.isDisabled}\n title={checkboxState.tooltip}\n />\n );\n}\n"]}
@@ -1,13 +1,14 @@
1
1
  import { TreeNodeRenderer as CoreTreeNodeRenderer } from "@itwin/presentation-hierarchies-react";
2
- import { TreeNodeCheckbox } from "./TreeNodeCheckbox";
3
2
  import type { ComponentPropsWithoutRef } from "react";
4
- type TreeNodeCheckboxProps = ComponentPropsWithoutRef<typeof TreeNodeCheckbox>;
3
+ import type { TreeCheckboxProps } from "./TreeNodeCheckbox";
4
+ /** @beta */
5
5
  interface TreeNodeRendererOwnProps {
6
- checkboxProps?: Omit<TreeNodeCheckboxProps, "node">;
6
+ /** Props for rendering tree node checkbox. If not provided, checkbox is not rendered. */
7
+ checkboxProps?: TreeCheckboxProps;
7
8
  }
8
- type CoreTreeNodeRendererProps = ComponentPropsWithoutRef<typeof CoreTreeNodeRenderer>;
9
- type TreeNodeRendererProps = CoreTreeNodeRendererProps & TreeNodeRendererOwnProps;
10
- /** @internal */
9
+ /** @beta */
10
+ type TreeNodeRendererProps = ComponentPropsWithoutRef<typeof CoreTreeNodeRenderer> & TreeNodeRendererOwnProps;
11
+ /** @beta */
11
12
  export declare function TreeNodeRenderer({ checkboxProps, ...props }: TreeNodeRendererProps): JSX.Element;
12
13
  export {};
13
14
  //# sourceMappingURL=TreeNodeRenderer.d.ts.map
@@ -12,7 +12,7 @@ const jsx_runtime_1 = require("react/jsx-runtime");
12
12
  const classnames_1 = __importDefault(require("classnames"));
13
13
  const presentation_hierarchies_react_1 = require("@itwin/presentation-hierarchies-react");
14
14
  const TreeNodeCheckbox_1 = require("./TreeNodeCheckbox");
15
- /** @internal */
15
+ /** @beta */
16
16
  function TreeNodeRenderer({ checkboxProps, ...props }) {
17
17
  return ((0, jsx_runtime_1.jsx)(presentation_hierarchies_react_1.TreeNodeRenderer, { ...props, nodeProps: { className: (0, classnames_1.default)("tw-tree-node", props.isSelected && "selected", props.className) }, actionButtonsClassName: "tw-tree-node-action-buttons", checkbox: checkboxProps ? (0, jsx_runtime_1.jsx)(TreeNodeCheckbox_1.TreeNodeCheckbox, { ...checkboxProps, node: props.node }) : null, contentProps: { className: "tw-tree-node-content" }, checkboxProps: { className: "tw-tree-node-checkbox-container" } }));
18
18
  }
@@ -1 +1 @@
1
- {"version":3,"file":"TreeNodeRenderer.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/TreeNodeRenderer.tsx"],"names":[],"mappings":";;;;;;;AAAA;;;gGAGgG;AAEhG,4DAA4B;AAC5B,0FAAiG;AACjG,yDAAsD;AAatD,gBAAgB;AAChB,SAAgB,gBAAgB,CAAC,EAAE,aAAa,EAAE,GAAG,KAAK,EAAyB;IACjF,OAAO,CACL,uBAAC,iDAAoB,OACf,KAAK,EACT,SAAS,EAAE,EAAE,SAAS,EAAE,IAAA,oBAAE,EAAC,cAAc,EAAE,KAAK,CAAC,UAAU,IAAI,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,EAAE,EAC7F,sBAAsB,EAAC,6BAA6B,EACpD,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,uBAAC,mCAAgB,OAAK,aAAa,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,GAAI,CAAC,CAAC,CAAC,IAAI,EAC1F,YAAY,EAAE,EAAE,SAAS,EAAE,sBAAsB,EAAE,EACnD,aAAa,EAAE,EAAE,SAAS,EAAE,iCAAiC,EAAE,GAC/D,CACH,CAAC;AACJ,CAAC;AAXD,4CAWC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport cx from \"classnames\";\nimport { TreeNodeRenderer as CoreTreeNodeRenderer } from \"@itwin/presentation-hierarchies-react\";\nimport { TreeNodeCheckbox } from \"./TreeNodeCheckbox\";\n\nimport type { ComponentPropsWithoutRef } from \"react\";\n\ntype TreeNodeCheckboxProps = ComponentPropsWithoutRef<typeof TreeNodeCheckbox>;\n\ninterface TreeNodeRendererOwnProps {\n checkboxProps?: Omit<TreeNodeCheckboxProps, \"node\">;\n}\n\ntype CoreTreeNodeRendererProps = ComponentPropsWithoutRef<typeof CoreTreeNodeRenderer>;\ntype TreeNodeRendererProps = CoreTreeNodeRendererProps & TreeNodeRendererOwnProps;\n\n/** @internal */\nexport function TreeNodeRenderer({ checkboxProps, ...props }: TreeNodeRendererProps) {\n return (\n <CoreTreeNodeRenderer\n {...props}\n nodeProps={{ className: cx(\"tw-tree-node\", props.isSelected && \"selected\", props.className) }}\n actionButtonsClassName=\"tw-tree-node-action-buttons\"\n checkbox={checkboxProps ? <TreeNodeCheckbox {...checkboxProps} node={props.node} /> : null}\n contentProps={{ className: \"tw-tree-node-content\" }}\n checkboxProps={{ className: \"tw-tree-node-checkbox-container\" }}\n />\n );\n}\n"]}
1
+ {"version":3,"file":"TreeNodeRenderer.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/TreeNodeRenderer.tsx"],"names":[],"mappings":";;;;;;;AAAA;;;gGAGgG;AAEhG,4DAA4B;AAC5B,0FAAiG;AACjG,yDAAsD;AActD,YAAY;AACZ,SAAgB,gBAAgB,CAAC,EAAE,aAAa,EAAE,GAAG,KAAK,EAAyB;IACjF,OAAO,CACL,uBAAC,iDAAoB,OACf,KAAK,EACT,SAAS,EAAE,EAAE,SAAS,EAAE,IAAA,oBAAE,EAAC,cAAc,EAAE,KAAK,CAAC,UAAU,IAAI,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,EAAE,EAC7F,sBAAsB,EAAC,6BAA6B,EACpD,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,uBAAC,mCAAgB,OAAK,aAAa,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,GAAI,CAAC,CAAC,CAAC,IAAI,EAC1F,YAAY,EAAE,EAAE,SAAS,EAAE,sBAAsB,EAAE,EACnD,aAAa,EAAE,EAAE,SAAS,EAAE,iCAAiC,EAAE,GAC/D,CACH,CAAC;AACJ,CAAC;AAXD,4CAWC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport cx from \"classnames\";\nimport { TreeNodeRenderer as CoreTreeNodeRenderer } from \"@itwin/presentation-hierarchies-react\";\nimport { TreeNodeCheckbox } from \"./TreeNodeCheckbox\";\n\nimport type { ComponentPropsWithoutRef } from \"react\";\nimport type { TreeCheckboxProps } from \"./TreeNodeCheckbox\";\n\n/** @beta */\ninterface TreeNodeRendererOwnProps {\n /** Props for rendering tree node checkbox. If not provided, checkbox is not rendered. */\n checkboxProps?: TreeCheckboxProps;\n}\n\n/** @beta */\ntype TreeNodeRendererProps = ComponentPropsWithoutRef<typeof CoreTreeNodeRenderer> & TreeNodeRendererOwnProps;\n\n/** @beta */\nexport function TreeNodeRenderer({ checkboxProps, ...props }: TreeNodeRendererProps) {\n return (\n <CoreTreeNodeRenderer\n {...props}\n nodeProps={{ className: cx(\"tw-tree-node\", props.isSelected && \"selected\", props.className) }}\n actionButtonsClassName=\"tw-tree-node-action-buttons\"\n checkbox={checkboxProps ? <TreeNodeCheckbox {...checkboxProps} node={props.node} /> : null}\n contentProps={{ className: \"tw-tree-node-content\" }}\n checkboxProps={{ className: \"tw-tree-node-checkbox-container\" }}\n />\n );\n}\n"]}
@@ -1,19 +1,27 @@
1
1
  import "./TreeRenderer.scss";
2
2
  import { Tree } from "@itwin/itwinui-react";
3
- import { LocalizationContextProvider } from "@itwin/presentation-hierarchies-react";
4
3
  import { TreeNodeRenderer } from "./TreeNodeRenderer";
5
4
  import type { ComponentPropsWithoutRef } from "react";
6
5
  import type { PresentationHierarchyNode, PresentationTreeNode, RenderedTreeNode } from "@itwin/presentation-hierarchies-react";
6
+ /** @beta */
7
7
  interface TreeRendererOwnProps {
8
+ /** Tree nodes to render. */
8
9
  rootNodes: PresentationTreeNode[];
10
+ /** Callback to check if specific node is selected. */
9
11
  isNodeSelected: (nodeId: string) => boolean;
12
+ /** Callback that is invoked when node is double clicked. */
10
13
  onNodeDoubleClick?: (node: PresentationHierarchyNode, isSelected: boolean) => void;
11
14
  }
12
- type TreeRendererProps = Pick<TreeNodeRendererProps, "expandNode" | "onNodeClick" | "onNodeKeyDown" | "onFilterClick" | "getIcon" | "getLabel" | "getSublabel" | "getHierarchyLevelDetails" | "checkboxProps"> & Omit<TreeProps<RenderedTreeNode>, "data" | "nodeRenderer" | "getNode"> & Pick<LocalizationContextProviderProps, "localizedStrings"> & TreeRendererOwnProps;
13
- /** @internal */
14
- export declare function TreeRenderer({ rootNodes, expandNode, onNodeClick, onNodeKeyDown, onNodeDoubleClick, isNodeSelected, onFilterClick, getIcon, getLabel, getSublabel, getHierarchyLevelDetails, checkboxProps, localizedStrings, ...props }: TreeRendererProps): JSX.Element;
15
+ /** @beta */
16
+ type TreeRendererProps = Pick<TreeNodeRendererProps, "expandNode" | "onNodeClick" | "onNodeKeyDown" | "onFilterClick" | "getIcon" | "getLabel" | "getSublabel" | "getHierarchyLevelDetails" | "checkboxProps" | "reloadTree"> & Omit<TreeProps<RenderedTreeNode>, "data" | "nodeRenderer" | "getNode"> & TreeRendererOwnProps;
17
+ /**
18
+ * Default renderer for rendering tree data.
19
+ * @beta
20
+ */
21
+ export declare function TreeRenderer({ rootNodes, expandNode, onNodeClick, onNodeKeyDown, onNodeDoubleClick, isNodeSelected, onFilterClick, getIcon, getLabel, getSublabel, getHierarchyLevelDetails, checkboxProps, reloadTree, ...props }: TreeRendererProps): JSX.Element;
22
+ /** @beta */
15
23
  type TreeProps<T> = ComponentPropsWithoutRef<typeof Tree<T>>;
24
+ /** @beta */
16
25
  type TreeNodeRendererProps = ComponentPropsWithoutRef<typeof TreeNodeRenderer>;
17
- type LocalizationContextProviderProps = ComponentPropsWithoutRef<typeof LocalizationContextProvider>;
18
26
  export {};
19
27
  //# sourceMappingURL=TreeRenderer.d.ts.map
@@ -10,9 +10,14 @@ require("./TreeRenderer.scss");
10
10
  const react_1 = require("react");
11
11
  const itwinui_react_1 = require("@itwin/itwinui-react");
12
12
  const presentation_hierarchies_react_1 = require("@itwin/presentation-hierarchies-react");
13
+ const UseHierarchiesLocalization_1 = require("../UseHierarchiesLocalization");
13
14
  const TreeNodeRenderer_1 = require("./TreeNodeRenderer");
14
- /** @internal */
15
- function TreeRenderer({ rootNodes, expandNode, onNodeClick, onNodeKeyDown, onNodeDoubleClick, isNodeSelected, onFilterClick, getIcon, getLabel, getSublabel, getHierarchyLevelDetails, checkboxProps, localizedStrings, ...props }) {
15
+ /**
16
+ * Default renderer for rendering tree data.
17
+ * @beta
18
+ */
19
+ function TreeRenderer({ rootNodes, expandNode, onNodeClick, onNodeKeyDown, onNodeDoubleClick, isNodeSelected, onFilterClick, getIcon, getLabel, getSublabel, getHierarchyLevelDetails, checkboxProps, reloadTree, ...props }) {
20
+ const localizedStrings = (0, UseHierarchiesLocalization_1.useHierarchiesLocalization)();
16
21
  const nodeRenderer = (0, react_1.useCallback)((nodeProps) => {
17
22
  return ((0, jsx_runtime_1.jsx)(TreeNodeRenderer_1.TreeNodeRenderer, { ...nodeProps, onNodeClick: (node, isSelected, event) => {
18
23
  if (onNodeDoubleClick && event.detail === 2) {
@@ -21,8 +26,20 @@ function TreeRenderer({ rootNodes, expandNode, onNodeClick, onNodeKeyDown, onNod
21
26
  return onNodeClick?.(node, true, event);
22
27
  }
23
28
  onNodeClick?.(node, isSelected, event);
24
- }, expandNode: expandNode, onNodeKeyDown: onNodeKeyDown, getIcon: getIcon, getLabel: getLabel, getSublabel: getSublabel, onFilterClick: onFilterClick, getHierarchyLevelDetails: getHierarchyLevelDetails, checkboxProps: checkboxProps, className: getSublabel ? "with-description" : "without-description" }));
25
- }, [expandNode, onNodeClick, onNodeKeyDown, onNodeDoubleClick, getHierarchyLevelDetails, getIcon, getLabel, getSublabel, onFilterClick, checkboxProps]);
29
+ }, expandNode: expandNode, onNodeKeyDown: onNodeKeyDown, getIcon: getIcon, getLabel: getLabel, getSublabel: getSublabel, onFilterClick: onFilterClick, getHierarchyLevelDetails: getHierarchyLevelDetails, checkboxProps: checkboxProps, reloadTree: reloadTree, className: getSublabel ? "with-description" : "without-description" }));
30
+ }, [
31
+ expandNode,
32
+ onNodeClick,
33
+ onNodeKeyDown,
34
+ onNodeDoubleClick,
35
+ getHierarchyLevelDetails,
36
+ getIcon,
37
+ getLabel,
38
+ getSublabel,
39
+ onFilterClick,
40
+ checkboxProps,
41
+ reloadTree,
42
+ ]);
26
43
  const getNode = (0, react_1.useCallback)((node) => (0, presentation_hierarchies_react_1.createRenderedTreeNodeData)(node, isNodeSelected), [isNodeSelected]);
27
44
  return ((0, jsx_runtime_1.jsx)(presentation_hierarchies_react_1.LocalizationContextProvider, { localizedStrings: localizedStrings, children: (0, jsx_runtime_1.jsx)(itwinui_react_1.Tree, { ...props, className: "tw-tree-renderer", data: rootNodes, nodeRenderer: nodeRenderer, getNode: getNode, enableVirtualization: true }) }));
28
45
  }
@@ -1 +1 @@
1
- {"version":3,"file":"TreeRenderer.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/TreeRenderer.tsx"],"names":[],"mappings":";;;;AAAA;;;gGAGgG;AAEhG,+BAA6B;AAC7B,iCAAoC;AACpC,wDAA4C;AAC5C,0FAAgH;AAChH,yDAAsD;AAmBtD,gBAAgB;AAChB,SAAgB,YAAY,CAAC,EAC3B,SAAS,EACT,UAAU,EACV,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,OAAO,EACP,QAAQ,EACR,WAAW,EACX,wBAAwB,EACxB,aAAa,EACb,gBAAgB,EAChB,GAAG,KAAK,EACU;IAClB,MAAM,YAAY,GAAG,IAAA,mBAAW,EAC9B,CAAC,SAAS,EAAE,EAAE;QACZ,OAAO,CACL,uBAAC,mCAAgB,OACX,SAAS,EACb,WAAW,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,EAAE;gBACvC,IAAI,iBAAiB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC3C,iBAAiB,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;oBAClD,mCAAmC;oBACnC,OAAO,WAAW,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;iBACzC;gBACD,WAAW,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;YACzC,CAAC,EACD,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,aAAa,EAC5B,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,EAClB,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,wBAAwB,EAAE,wBAAwB,EAClD,aAAa,EAAE,aAAa,EAC5B,SAAS,EAAE,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,qBAAqB,GACnE,CACH,CAAC;IACJ,CAAC,EACD,CAAC,UAAU,EAAE,WAAW,EAAE,aAAa,EAAE,iBAAiB,EAAE,wBAAwB,EAAE,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE,aAAa,CAAC,CACpJ,CAAC;IAEF,MAAM,OAAO,GAAG,IAAA,mBAAW,EAAyC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAA,2DAA0B,EAAC,IAAI,EAAE,cAAc,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;IAElJ,OAAO,CACL,uBAAC,4DAA2B,IAAC,gBAAgB,EAAE,gBAAgB,YAC7D,uBAAC,oBAAI,OACC,KAAK,EACT,SAAS,EAAC,kBAAkB,EAC5B,IAAI,EAAE,SAAS,EACf,YAAY,EAAE,YAAY,EAC1B,OAAO,EAAE,OAAO,EAChB,oBAAoB,EAAE,IAAI,GAC1B,GAC0B,CAC/B,CAAC;AACJ,CAAC;AA1DD,oCA0DC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport \"./TreeRenderer.scss\";\nimport { useCallback } from \"react\";\nimport { Tree } from \"@itwin/itwinui-react\";\nimport { createRenderedTreeNodeData, LocalizationContextProvider } from \"@itwin/presentation-hierarchies-react\";\nimport { TreeNodeRenderer } from \"./TreeNodeRenderer\";\n\nimport type { ComponentPropsWithoutRef } from \"react\";\nimport type { PresentationHierarchyNode, PresentationTreeNode, RenderedTreeNode } from \"@itwin/presentation-hierarchies-react\";\n\ninterface TreeRendererOwnProps {\n rootNodes: PresentationTreeNode[];\n isNodeSelected: (nodeId: string) => boolean;\n onNodeDoubleClick?: (node: PresentationHierarchyNode, isSelected: boolean) => void;\n}\n\ntype TreeRendererProps = Pick<\n TreeNodeRendererProps,\n \"expandNode\" | \"onNodeClick\" | \"onNodeKeyDown\" | \"onFilterClick\" | \"getIcon\" | \"getLabel\" | \"getSublabel\" | \"getHierarchyLevelDetails\" | \"checkboxProps\"\n> &\n Omit<TreeProps<RenderedTreeNode>, \"data\" | \"nodeRenderer\" | \"getNode\"> &\n Pick<LocalizationContextProviderProps, \"localizedStrings\"> &\n TreeRendererOwnProps;\n\n/** @internal */\nexport function TreeRenderer({\n rootNodes,\n expandNode,\n onNodeClick,\n onNodeKeyDown,\n onNodeDoubleClick,\n isNodeSelected,\n onFilterClick,\n getIcon,\n getLabel,\n getSublabel,\n getHierarchyLevelDetails,\n checkboxProps,\n localizedStrings,\n ...props\n}: TreeRendererProps) {\n const nodeRenderer = useCallback<TreeProps<RenderedTreeNode>[\"nodeRenderer\"]>(\n (nodeProps) => {\n return (\n <TreeNodeRenderer\n {...nodeProps}\n onNodeClick={(node, isSelected, event) => {\n if (onNodeDoubleClick && event.detail === 2) {\n onNodeDoubleClick?.(node, !!nodeProps.isSelected);\n // Click node to not lose selection\n return onNodeClick?.(node, true, event);\n }\n onNodeClick?.(node, isSelected, event);\n }}\n expandNode={expandNode}\n onNodeKeyDown={onNodeKeyDown}\n getIcon={getIcon}\n getLabel={getLabel}\n getSublabel={getSublabel}\n onFilterClick={onFilterClick}\n getHierarchyLevelDetails={getHierarchyLevelDetails}\n checkboxProps={checkboxProps}\n className={getSublabel ? \"with-description\" : \"without-description\"}\n />\n );\n },\n [expandNode, onNodeClick, onNodeKeyDown, onNodeDoubleClick, getHierarchyLevelDetails, getIcon, getLabel, getSublabel, onFilterClick, checkboxProps],\n );\n\n const getNode = useCallback<TreeProps<RenderedTreeNode>[\"getNode\"]>((node) => createRenderedTreeNodeData(node, isNodeSelected), [isNodeSelected]);\n\n return (\n <LocalizationContextProvider localizedStrings={localizedStrings}>\n <Tree<RenderedTreeNode>\n {...props}\n className=\"tw-tree-renderer\"\n data={rootNodes}\n nodeRenderer={nodeRenderer}\n getNode={getNode}\n enableVirtualization={true}\n />\n </LocalizationContextProvider>\n );\n}\n\ntype TreeProps<T> = ComponentPropsWithoutRef<typeof Tree<T>>;\ntype TreeNodeRendererProps = ComponentPropsWithoutRef<typeof TreeNodeRenderer>;\ntype LocalizationContextProviderProps = ComponentPropsWithoutRef<typeof LocalizationContextProvider>;\n"]}
1
+ {"version":3,"file":"TreeRenderer.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/TreeRenderer.tsx"],"names":[],"mappings":";;;;AAAA;;;gGAGgG;AAEhG,+BAA6B;AAC7B,iCAAoC;AACpC,wDAA4C;AAC5C,0FAAgH;AAChH,8EAA2E;AAC3E,yDAAsD;AAgCtD;;;GAGG;AACH,SAAgB,YAAY,CAAC,EAC3B,SAAS,EACT,UAAU,EACV,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,OAAO,EACP,QAAQ,EACR,WAAW,EACX,wBAAwB,EACxB,aAAa,EACb,UAAU,EACV,GAAG,KAAK,EACU;IAClB,MAAM,gBAAgB,GAAG,IAAA,uDAA0B,GAAE,CAAC;IACtD,MAAM,YAAY,GAAG,IAAA,mBAAW,EAC9B,CAAC,SAAS,EAAE,EAAE;QACZ,OAAO,CACL,uBAAC,mCAAgB,OACX,SAAS,EACb,WAAW,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,EAAE;gBACvC,IAAI,iBAAiB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC3C,iBAAiB,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;oBAClD,mCAAmC;oBACnC,OAAO,WAAW,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;iBACzC;gBACD,WAAW,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;YACzC,CAAC,EACD,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,aAAa,EAC5B,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,EAClB,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,wBAAwB,EAAE,wBAAwB,EAClD,aAAa,EAAE,aAAa,EAC5B,UAAU,EAAE,UAAU,EACtB,SAAS,EAAE,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,qBAAqB,GACnE,CACH,CAAC;IACJ,CAAC,EACD;QACE,UAAU;QACV,WAAW;QACX,aAAa;QACb,iBAAiB;QACjB,wBAAwB;QACxB,OAAO;QACP,QAAQ;QACR,WAAW;QACX,aAAa;QACb,aAAa;QACb,UAAU;KACX,CACF,CAAC;IAEF,MAAM,OAAO,GAAG,IAAA,mBAAW,EAAyC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAA,2DAA0B,EAAC,IAAI,EAAE,cAAc,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;IAElJ,OAAO,CACL,uBAAC,4DAA2B,IAAC,gBAAgB,EAAE,gBAAgB,YAC7D,uBAAC,oBAAI,OACC,KAAK,EACT,SAAS,EAAC,kBAAkB,EAC5B,IAAI,EAAE,SAAS,EACf,YAAY,EAAE,YAAY,EAC1B,OAAO,EAAE,OAAO,EAChB,oBAAoB,EAAE,IAAI,GAC1B,GAC0B,CAC/B,CAAC;AACJ,CAAC;AAxED,oCAwEC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport \"./TreeRenderer.scss\";\nimport { useCallback } from \"react\";\nimport { Tree } from \"@itwin/itwinui-react\";\nimport { createRenderedTreeNodeData, LocalizationContextProvider } from \"@itwin/presentation-hierarchies-react\";\nimport { useHierarchiesLocalization } from \"../UseHierarchiesLocalization\";\nimport { TreeNodeRenderer } from \"./TreeNodeRenderer\";\n\nimport type { ComponentPropsWithoutRef } from \"react\";\nimport type { PresentationHierarchyNode, PresentationTreeNode, RenderedTreeNode } from \"@itwin/presentation-hierarchies-react\";\n\n/** @beta */\ninterface TreeRendererOwnProps {\n /** Tree nodes to render. */\n rootNodes: PresentationTreeNode[];\n /** Callback to check if specific node is selected. */\n isNodeSelected: (nodeId: string) => boolean;\n /** Callback that is invoked when node is double clicked. */\n onNodeDoubleClick?: (node: PresentationHierarchyNode, isSelected: boolean) => void;\n}\n\n/** @beta */\ntype TreeRendererProps = Pick<\n TreeNodeRendererProps,\n | \"expandNode\"\n | \"onNodeClick\"\n | \"onNodeKeyDown\"\n | \"onFilterClick\"\n | \"getIcon\"\n | \"getLabel\"\n | \"getSublabel\"\n | \"getHierarchyLevelDetails\"\n | \"checkboxProps\"\n | \"reloadTree\"\n> &\n Omit<TreeProps<RenderedTreeNode>, \"data\" | \"nodeRenderer\" | \"getNode\"> &\n TreeRendererOwnProps;\n\n/**\n * Default renderer for rendering tree data.\n * @beta\n */\nexport function TreeRenderer({\n rootNodes,\n expandNode,\n onNodeClick,\n onNodeKeyDown,\n onNodeDoubleClick,\n isNodeSelected,\n onFilterClick,\n getIcon,\n getLabel,\n getSublabel,\n getHierarchyLevelDetails,\n checkboxProps,\n reloadTree,\n ...props\n}: TreeRendererProps) {\n const localizedStrings = useHierarchiesLocalization();\n const nodeRenderer = useCallback<TreeProps<RenderedTreeNode>[\"nodeRenderer\"]>(\n (nodeProps) => {\n return (\n <TreeNodeRenderer\n {...nodeProps}\n onNodeClick={(node, isSelected, event) => {\n if (onNodeDoubleClick && event.detail === 2) {\n onNodeDoubleClick?.(node, !!nodeProps.isSelected);\n // Click node to not lose selection\n return onNodeClick?.(node, true, event);\n }\n onNodeClick?.(node, isSelected, event);\n }}\n expandNode={expandNode}\n onNodeKeyDown={onNodeKeyDown}\n getIcon={getIcon}\n getLabel={getLabel}\n getSublabel={getSublabel}\n onFilterClick={onFilterClick}\n getHierarchyLevelDetails={getHierarchyLevelDetails}\n checkboxProps={checkboxProps}\n reloadTree={reloadTree}\n className={getSublabel ? \"with-description\" : \"without-description\"}\n />\n );\n },\n [\n expandNode,\n onNodeClick,\n onNodeKeyDown,\n onNodeDoubleClick,\n getHierarchyLevelDetails,\n getIcon,\n getLabel,\n getSublabel,\n onFilterClick,\n checkboxProps,\n reloadTree,\n ],\n );\n\n const getNode = useCallback<TreeProps<RenderedTreeNode>[\"getNode\"]>((node) => createRenderedTreeNodeData(node, isNodeSelected), [isNodeSelected]);\n\n return (\n <LocalizationContextProvider localizedStrings={localizedStrings}>\n <Tree<RenderedTreeNode>\n {...props}\n className=\"tw-tree-renderer\"\n data={rootNodes}\n nodeRenderer={nodeRenderer}\n getNode={getNode}\n enableVirtualization={true}\n />\n </LocalizationContextProvider>\n );\n}\n\n/** @beta */\ntype TreeProps<T> = ComponentPropsWithoutRef<typeof Tree<T>>;\n/** @beta */\ntype TreeNodeRendererProps = ComponentPropsWithoutRef<typeof TreeNodeRenderer>;\n"]}
@@ -1,14 +1,32 @@
1
- import { useHierarchyVisibility } from "../UseHierarchyVisibility";
2
- import { BaseTree } from "./BaseTree";
1
+ import { Tree } from "./Tree";
2
+ import type React from "react";
3
+ import type { VisibilityTreeRenderer } from "./VisibilityTreeRenderer";
4
+ import type { TreeRendererProps } from "./Tree";
3
5
  import type { ECClassHierarchyInspector } from "@itwin/presentation-shared";
4
6
  import type { HierarchyVisibilityHandler } from "../UseHierarchyVisibility";
5
7
  import type { ComponentPropsWithoutRef } from "react";
6
- type BaseTreeProps = ComponentPropsWithoutRef<typeof BaseTree>;
7
- type UseHierarchyVisibilityProps = Parameters<typeof useHierarchyVisibility>[0];
8
- type VisibilityTreeProps = Omit<BaseTreeProps, "treeRenderer" | "imodelAccess"> & Omit<UseHierarchyVisibilityProps, "visibilityHandlerFactory"> & {
9
- visibilityHandlerFactory: (imodelAccess: ECClassHierarchyInspector) => HierarchyVisibilityHandler;
10
- };
11
- /** @internal */
12
- export declare function VisibilityTree({ visibilityHandlerFactory, onPerformanceMeasured, ...props }: VisibilityTreeProps): JSX.Element;
8
+ /** @beta */
9
+ type TreeProps = ComponentPropsWithoutRef<typeof Tree>;
10
+ /**
11
+ * Properties that are passed to `treeRenderer` from `VisibilityTree` component.
12
+ * @beta
13
+ */
14
+ export type VisibilityTreeRendererProps = TreeRendererProps & Pick<ComponentPropsWithoutRef<typeof VisibilityTreeRenderer>, "getCheckboxState" | "onCheckboxClicked">;
15
+ /** @beta */
16
+ interface VisibilityTreeOwnProps {
17
+ /** Callback for creating visibility handler used to control visibility of instances represented by tree nodes. */
18
+ visibilityHandlerFactory: (props: {
19
+ imodelAccess: ECClassHierarchyInspector;
20
+ }) => HierarchyVisibilityHandler;
21
+ /** Tree renderer that should be used to render tree data. */
22
+ treeRenderer: (treeProps: VisibilityTreeRendererProps) => React.ReactNode;
23
+ }
24
+ /** @beta */
25
+ type VisibilityTreeProps = VisibilityTreeOwnProps & Omit<TreeProps, "treeRenderer" | "imodelAccess">;
26
+ /**
27
+ * Tree component that can control visibility of instances represented by tree nodes.
28
+ * @beta
29
+ */
30
+ export declare function VisibilityTree({ visibilityHandlerFactory, treeRenderer, ...props }: VisibilityTreeProps): JSX.Element;
13
31
  export {};
14
32
  //# sourceMappingURL=VisibilityTree.d.ts.map
@@ -7,35 +7,20 @@ const jsx_runtime_1 = require("react/jsx-runtime");
7
7
  * See LICENSE.md in the project root for license terms and full copyright notice.
8
8
  *--------------------------------------------------------------------------------------------*/
9
9
  const react_1 = require("react");
10
- const UseFeatureReporting_1 = require("../UseFeatureReporting");
11
10
  const UseHierarchyVisibility_1 = require("../UseHierarchyVisibility");
12
- const UseMultiCheckboxHandler_1 = require("../UseMultiCheckboxHandler");
13
11
  const Utils_1 = require("../Utils");
14
- const BaseTree_1 = require("./BaseTree");
15
- const TreeRenderer_1 = require("./TreeRenderer");
16
- /** @internal */
17
- function VisibilityTree({ visibilityHandlerFactory, onPerformanceMeasured, ...props }) {
12
+ const Tree_1 = require("./Tree");
13
+ /**
14
+ * Tree component that can control visibility of instances represented by tree nodes.
15
+ * @beta
16
+ */
17
+ function VisibilityTree({ visibilityHandlerFactory, treeRenderer, ...props }) {
18
18
  const { imodel, getSchemaContext } = props;
19
19
  const imodelAccess = (0, react_1.useMemo)(() => (0, Utils_1.createIModelAccess)({ imodel, getSchemaContext }), [imodel, getSchemaContext]);
20
20
  const { getCheckboxState, onCheckboxClicked, triggerRefresh } = (0, UseHierarchyVisibility_1.useHierarchyVisibility)({
21
- visibilityHandlerFactory: (0, react_1.useCallback)(() => visibilityHandlerFactory(imodelAccess), [visibilityHandlerFactory, imodelAccess]),
21
+ visibilityHandlerFactory: (0, react_1.useCallback)(() => visibilityHandlerFactory({ imodelAccess }), [visibilityHandlerFactory, imodelAccess]),
22
22
  });
23
- return ((0, jsx_runtime_1.jsx)(BaseTree_1.BaseTree, { ...props, onPerformanceMeasured: (action, duration) => {
24
- onPerformanceMeasured?.(action, duration);
25
- if (action === "reload") {
26
- triggerRefresh();
27
- }
28
- }, imodelAccess: imodelAccess, treeRenderer: (treeProps) => (0, jsx_runtime_1.jsx)(VisibilityTreeRenderer, { ...treeProps, getCheckboxState: getCheckboxState, onCheckboxClicked: onCheckboxClicked }) }));
23
+ return ((0, jsx_runtime_1.jsx)(Tree_1.Tree, { ...props, onReload: triggerRefresh, imodelAccess: imodelAccess, treeRenderer: (treeProps) => treeRenderer({ ...treeProps, getCheckboxState, onCheckboxClicked }) }));
29
24
  }
30
25
  exports.VisibilityTree = VisibilityTree;
31
- function VisibilityTreeRenderer({ getCheckboxState, onCheckboxClicked: onClick, reportUsage, ...props }) {
32
- const { onCheckboxClicked } = (0, UseMultiCheckboxHandler_1.useMultiCheckboxHandler)({ rootNodes: props.rootNodes, isNodeSelected: props.isNodeSelected, onClick });
33
- const reportingOnCheckboxClicked = (0, UseFeatureReporting_1.useReportingAction)({ featureId: "visibility-change", action: onCheckboxClicked, reportUsage });
34
- const checkboxProps = (0, react_1.useMemo)(() => ({
35
- variant: "eyeball",
36
- getCheckboxState,
37
- onCheckboxClicked: reportingOnCheckboxClicked,
38
- }), [getCheckboxState, reportingOnCheckboxClicked]);
39
- return (0, jsx_runtime_1.jsx)(TreeRenderer_1.TreeRenderer, { ...props, checkboxProps: checkboxProps });
40
- }
41
26
  //# sourceMappingURL=VisibilityTree.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"VisibilityTree.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/VisibilityTree.tsx"],"names":[],"mappings":";;;;AAAA;;;gGAGgG;AAEhG,iCAA6C;AAC7C,gEAA4D;AAC5D,sEAAmE;AACnE,wEAAqE;AACrE,oCAA8C;AAC9C,yCAAsC;AACtC,iDAA8C;AAa9C,gBAAgB;AAChB,SAAgB,cAAc,CAAC,EAAE,wBAAwB,EAAE,qBAAqB,EAAE,GAAG,KAAK,EAAuB;IAC/G,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,GAAG,KAAK,CAAC;IAC3C,MAAM,YAAY,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,IAAA,0BAAkB,EAAC,EAAE,MAAM,EAAE,gBAAgB,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC,CAAC;IACjH,MAAM,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,cAAc,EAAE,GAAG,IAAA,+CAAsB,EAAC;QACrF,wBAAwB,EAAE,IAAA,mBAAW,EAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC,YAAY,CAAC,EAAE,CAAC,wBAAwB,EAAE,YAAY,CAAC,CAAC;KAC9H,CAAC,CAAC;IAEH,OAAO,CACL,uBAAC,mBAAQ,OACH,KAAK,EACT,qBAAqB,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;YAC1C,qBAAqB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YAC1C,IAAI,MAAM,KAAK,QAAQ,EAAE;gBACvB,cAAc,EAAE,CAAC;aAClB;QACH,CAAC,EACD,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,uBAAC,sBAAsB,OAAK,SAAS,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,iBAAiB,GAAI,GAChJ,CACH,CAAC;AACJ,CAAC;AApBD,wCAoBC;AAID,SAAS,sBAAsB,CAAC,EAC9B,gBAAgB,EAChB,iBAAiB,EAAE,OAAO,EAC1B,WAAW,EACX,GAAG,KAAK,EAC2I;IACnJ,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAA,iDAAuB,EAAC,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,EAAE,cAAc,EAAE,KAAK,CAAC,cAAc,EAAE,OAAO,EAAE,CAAC,CAAC;IACrI,MAAM,0BAA0B,GAAG,IAAA,wCAAkB,EAAC,EAAE,SAAS,EAAE,mBAAmB,EAAE,MAAM,EAAE,iBAAiB,EAAE,WAAW,EAAE,CAAC,CAAC;IAElI,MAAM,aAAa,GAAuC,IAAA,eAAO,EAC/D,GAAG,EAAE,CAAC,CAAC;QACL,OAAO,EAAE,SAAS;QAClB,gBAAgB;QAChB,iBAAiB,EAAE,0BAA0B;KAC9C,CAAC,EACF,CAAC,gBAAgB,EAAE,0BAA0B,CAAC,CAC/C,CAAC;IAEF,OAAO,uBAAC,2BAAY,OAAK,KAAK,EAAE,aAAa,EAAE,aAAa,GAAI,CAAC;AACnE,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport { useCallback, useMemo } from \"react\";\nimport { useReportingAction } from \"../UseFeatureReporting\";\nimport { useHierarchyVisibility } from \"../UseHierarchyVisibility\";\nimport { useMultiCheckboxHandler } from \"../UseMultiCheckboxHandler\";\nimport { createIModelAccess } from \"../Utils\";\nimport { BaseTree } from \"./BaseTree\";\nimport { TreeRenderer } from \"./TreeRenderer\";\n\nimport type { ECClassHierarchyInspector } from \"@itwin/presentation-shared\";\nimport type { HierarchyVisibilityHandler } from \"../UseHierarchyVisibility\";\nimport type { ComponentPropsWithoutRef } from \"react\";\n\ntype BaseTreeProps = ComponentPropsWithoutRef<typeof BaseTree>;\ntype UseHierarchyVisibilityProps = Parameters<typeof useHierarchyVisibility>[0];\ntype VisibilityTreeProps = Omit<BaseTreeProps, \"treeRenderer\" | \"imodelAccess\"> &\n Omit<UseHierarchyVisibilityProps, \"visibilityHandlerFactory\"> & {\n visibilityHandlerFactory: (imodelAccess: ECClassHierarchyInspector) => HierarchyVisibilityHandler;\n };\n\n/** @internal */\nexport function VisibilityTree({ visibilityHandlerFactory, onPerformanceMeasured, ...props }: VisibilityTreeProps) {\n const { imodel, getSchemaContext } = props;\n const imodelAccess = useMemo(() => createIModelAccess({ imodel, getSchemaContext }), [imodel, getSchemaContext]);\n const { getCheckboxState, onCheckboxClicked, triggerRefresh } = useHierarchyVisibility({\n visibilityHandlerFactory: useCallback(() => visibilityHandlerFactory(imodelAccess), [visibilityHandlerFactory, imodelAccess]),\n });\n\n return (\n <BaseTree\n {...props}\n onPerformanceMeasured={(action, duration) => {\n onPerformanceMeasured?.(action, duration);\n if (action === \"reload\") {\n triggerRefresh();\n }\n }}\n imodelAccess={imodelAccess}\n treeRenderer={(treeProps) => <VisibilityTreeRenderer {...treeProps} getCheckboxState={getCheckboxState} onCheckboxClicked={onCheckboxClicked} />}\n />\n );\n}\n\ntype TreeRendererProps = ComponentPropsWithoutRef<typeof TreeRenderer>;\n\nfunction VisibilityTreeRenderer({\n getCheckboxState,\n onCheckboxClicked: onClick,\n reportUsage,\n ...props\n}: TreeRendererProps & Pick<ReturnType<typeof useHierarchyVisibility>, \"getCheckboxState\" | \"onCheckboxClicked\"> & Pick<BaseTreeProps, \"reportUsage\">) {\n const { onCheckboxClicked } = useMultiCheckboxHandler({ rootNodes: props.rootNodes, isNodeSelected: props.isNodeSelected, onClick });\n const reportingOnCheckboxClicked = useReportingAction({ featureId: \"visibility-change\", action: onCheckboxClicked, reportUsage });\n\n const checkboxProps: TreeRendererProps[\"checkboxProps\"] = useMemo(\n () => ({\n variant: \"eyeball\",\n getCheckboxState,\n onCheckboxClicked: reportingOnCheckboxClicked,\n }),\n [getCheckboxState, reportingOnCheckboxClicked],\n );\n\n return <TreeRenderer {...props} checkboxProps={checkboxProps} />;\n}\n"]}
1
+ {"version":3,"file":"VisibilityTree.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/VisibilityTree.tsx"],"names":[],"mappings":";;;;AAAA;;;gGAGgG;AAEhG,iCAA6C;AAC7C,sEAAmE;AACnE,oCAA8C;AAC9C,iCAA8B;AA8B9B;;;GAGG;AACH,SAAgB,cAAc,CAAC,EAAE,wBAAwB,EAAE,YAAY,EAAE,GAAG,KAAK,EAAuB;IACtG,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,GAAG,KAAK,CAAC;IAC3C,MAAM,YAAY,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,IAAA,0BAAkB,EAAC,EAAE,MAAM,EAAE,gBAAgB,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC,CAAC;IACjH,MAAM,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,cAAc,EAAE,GAAG,IAAA,+CAAsB,EAAC;QACrF,wBAAwB,EAAE,IAAA,mBAAW,EAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,wBAAwB,EAAE,YAAY,CAAC,CAAC;KAClI,CAAC,CAAC;IAEH,OAAO,CACL,uBAAC,WAAI,OACC,KAAK,EACT,QAAQ,EAAE,cAAc,EACxB,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,YAAY,CAAC,EAAE,GAAG,SAAS,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,CAAC,GAChG,CACH,CAAC;AACJ,CAAC;AAfD,wCAeC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport { useCallback, useMemo } from \"react\";\nimport { useHierarchyVisibility } from \"../UseHierarchyVisibility\";\nimport { createIModelAccess } from \"../Utils\";\nimport { Tree } from \"./Tree\";\n\nimport type React from \"react\";\nimport type { VisibilityTreeRenderer } from \"./VisibilityTreeRenderer\";\nimport type { TreeRendererProps } from \"./Tree\";\nimport type { ECClassHierarchyInspector } from \"@itwin/presentation-shared\";\nimport type { HierarchyVisibilityHandler } from \"../UseHierarchyVisibility\";\nimport type { ComponentPropsWithoutRef } from \"react\";\n\n/** @beta */\ntype TreeProps = ComponentPropsWithoutRef<typeof Tree>;\n\n/**\n * Properties that are passed to `treeRenderer` from `VisibilityTree` component.\n * @beta\n */\nexport type VisibilityTreeRendererProps = TreeRendererProps &\n Pick<ComponentPropsWithoutRef<typeof VisibilityTreeRenderer>, \"getCheckboxState\" | \"onCheckboxClicked\">;\n\n/** @beta */\ninterface VisibilityTreeOwnProps {\n /** Callback for creating visibility handler used to control visibility of instances represented by tree nodes. */\n visibilityHandlerFactory: (props: { imodelAccess: ECClassHierarchyInspector }) => HierarchyVisibilityHandler;\n /** Tree renderer that should be used to render tree data. */\n treeRenderer: (treeProps: VisibilityTreeRendererProps) => React.ReactNode;\n}\n\n/** @beta */\ntype VisibilityTreeProps = VisibilityTreeOwnProps & Omit<TreeProps, \"treeRenderer\" | \"imodelAccess\">;\n\n/**\n * Tree component that can control visibility of instances represented by tree nodes.\n * @beta\n */\nexport function VisibilityTree({ visibilityHandlerFactory, treeRenderer, ...props }: VisibilityTreeProps) {\n const { imodel, getSchemaContext } = props;\n const imodelAccess = useMemo(() => createIModelAccess({ imodel, getSchemaContext }), [imodel, getSchemaContext]);\n const { getCheckboxState, onCheckboxClicked, triggerRefresh } = useHierarchyVisibility({\n visibilityHandlerFactory: useCallback(() => visibilityHandlerFactory({ imodelAccess }), [visibilityHandlerFactory, imodelAccess]),\n });\n\n return (\n <Tree\n {...props}\n onReload={triggerRefresh}\n imodelAccess={imodelAccess}\n treeRenderer={(treeProps) => treeRenderer({ ...treeProps, getCheckboxState, onCheckboxClicked })}\n />\n );\n}\n"]}
@@ -0,0 +1,12 @@
1
+ import { TreeRenderer } from "./TreeRenderer";
2
+ import type { ComponentPropsWithoutRef } from "react";
3
+ import type { TreeCheckboxProps } from "./TreeNodeCheckbox";
4
+ /** @beta */
5
+ type TreeRendererProps = ComponentPropsWithoutRef<typeof TreeRenderer>;
6
+ /**
7
+ * Tree renderer that renders tree nodes with eye checkboxes for controlling visibility of instances represented by tree nodes.
8
+ * @beta
9
+ */
10
+ export declare function VisibilityTreeRenderer({ getCheckboxState, onCheckboxClicked: onClick, ...props }: TreeRendererProps & TreeCheckboxProps): JSX.Element;
11
+ export {};
12
+ //# sourceMappingURL=VisibilityTreeRenderer.d.ts.map
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.VisibilityTreeRenderer = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ /*---------------------------------------------------------------------------------------------
6
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
7
+ * See LICENSE.md in the project root for license terms and full copyright notice.
8
+ *--------------------------------------------------------------------------------------------*/
9
+ const react_1 = require("react");
10
+ const UseMultiCheckboxHandler_1 = require("../UseMultiCheckboxHandler");
11
+ const TreeRenderer_1 = require("./TreeRenderer");
12
+ /**
13
+ * Tree renderer that renders tree nodes with eye checkboxes for controlling visibility of instances represented by tree nodes.
14
+ * @beta
15
+ */
16
+ function VisibilityTreeRenderer({ getCheckboxState, onCheckboxClicked: onClick, ...props }) {
17
+ const { onCheckboxClicked } = (0, UseMultiCheckboxHandler_1.useMultiCheckboxHandler)({ rootNodes: props.rootNodes, isNodeSelected: props.isNodeSelected, onClick });
18
+ const checkboxProps = (0, react_1.useMemo)(() => ({
19
+ variant: "eyeball",
20
+ getCheckboxState,
21
+ onCheckboxClicked,
22
+ }), [getCheckboxState, onCheckboxClicked]);
23
+ return (0, jsx_runtime_1.jsx)(TreeRenderer_1.TreeRenderer, { ...props, checkboxProps: checkboxProps });
24
+ }
25
+ exports.VisibilityTreeRenderer = VisibilityTreeRenderer;
26
+ //# sourceMappingURL=VisibilityTreeRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VisibilityTreeRenderer.js","sourceRoot":"","sources":["../../../../../../src/components/trees/common/components/VisibilityTreeRenderer.tsx"],"names":[],"mappings":";;;;AAAA;;;gGAGgG;AAEhG,iCAAgC;AAChC,wEAAqE;AACrE,iDAA8C;AAQ9C;;;GAGG;AACH,SAAgB,sBAAsB,CAAC,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,OAAO,EAAE,GAAG,KAAK,EAAyC;IACtI,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAA,iDAAuB,EAAC,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,EAAE,cAAc,EAAE,KAAK,CAAC,cAAc,EAAE,OAAO,EAAE,CAAC,CAAC;IAErI,MAAM,aAAa,GAAuC,IAAA,eAAO,EAC/D,GAAG,EAAE,CAAC,CAAC;QACL,OAAO,EAAE,SAAS;QAClB,gBAAgB;QAChB,iBAAiB;KAClB,CAAC,EACF,CAAC,gBAAgB,EAAE,iBAAiB,CAAC,CACtC,CAAC;IAEF,OAAO,uBAAC,2BAAY,OAAK,KAAK,EAAE,aAAa,EAAE,aAAa,GAAI,CAAC;AACnE,CAAC;AAbD,wDAaC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n\nimport { useMemo } from \"react\";\nimport { useMultiCheckboxHandler } from \"../UseMultiCheckboxHandler\";\nimport { TreeRenderer } from \"./TreeRenderer\";\n\nimport type { ComponentPropsWithoutRef } from \"react\";\nimport type { TreeCheckboxProps } from \"./TreeNodeCheckbox\";\n\n/** @beta */\ntype TreeRendererProps = ComponentPropsWithoutRef<typeof TreeRenderer>;\n\n/**\n * Tree renderer that renders tree nodes with eye checkboxes for controlling visibility of instances represented by tree nodes.\n * @beta\n */\nexport function VisibilityTreeRenderer({ getCheckboxState, onCheckboxClicked: onClick, ...props }: TreeRendererProps & TreeCheckboxProps) {\n const { onCheckboxClicked } = useMultiCheckboxHandler({ rootNodes: props.rootNodes, isNodeSelected: props.isNodeSelected, onClick });\n\n const checkboxProps: TreeRendererProps[\"checkboxProps\"] = useMemo(\n () => ({\n variant: \"eyeball\",\n getCheckboxState,\n onCheckboxClicked,\n }),\n [getCheckboxState, onCheckboxClicked],\n );\n\n return <TreeRenderer {...props} checkboxProps={checkboxProps} />;\n}\n"]}
@@ -1,15 +1,16 @@
1
1
  /// <reference types="react" />
2
- import { BaseTree } from "../common/components/BaseTree";
2
+ import { Tree } from "../common/components/Tree";
3
+ /** @beta */
3
4
  interface ExternalSourcesTreeOwnProps {
4
5
  hierarchyLevelConfig?: {
5
6
  sizeLimit?: number;
6
7
  };
7
- onPerformanceMeasured?: (featureId: string, duration: number) => void;
8
- onFeatureUsed?: (feature: string) => void;
9
8
  }
10
- type BaseTreeProps = Parameters<typeof BaseTree>[0];
11
- type ExternalSourcesTreeProps = ExternalSourcesTreeOwnProps & Pick<BaseTreeProps, "imodel" | "getSchemaContext" | "height" | "width" | "density" | "selectionMode">;
12
- /** @internal */
13
- export declare function ExternalSourcesTree({ onPerformanceMeasured, onFeatureUsed, ...props }: ExternalSourcesTreeProps): JSX.Element;
9
+ /** @beta */
10
+ type TreeProps = Parameters<typeof Tree>[0];
11
+ /** @beta */
12
+ type ExternalSourcesTreeProps = ExternalSourcesTreeOwnProps & Pick<TreeProps, "imodel" | "getSchemaContext" | "selectionStorage" | "height" | "width" | "density" | "selectionMode">;
13
+ /** @beta */
14
+ export declare function ExternalSourcesTree(props: ExternalSourcesTreeProps): JSX.Element;
14
15
  export {};
15
16
  //# sourceMappingURL=ExternalSourcesTree.d.ts.map