@itwin/tree-widget-react 3.4.1 → 4.0.0-alpha.1

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 (265) hide show
  1. package/CHANGELOG.md +1 -18
  2. package/README.md +3 -76
  3. package/lib/esm/tree-widget-react/components/SelectableTree.d.ts +1 -1
  4. package/lib/esm/tree-widget-react/components/SelectableTree.js +4 -4
  5. package/lib/esm/tree-widget-react/components/SelectableTree.js.map +1 -1
  6. package/lib/esm/tree-widget-react/components/TreeSelector.d.ts +1 -2
  7. package/lib/esm/tree-widget-react/components/TreeSelector.js +11 -14
  8. package/lib/esm/tree-widget-react/components/TreeSelector.js.map +1 -1
  9. package/lib/esm/tree-widget-react/components/TreeWidgetUiItemsProvider.d.ts +1 -2
  10. package/lib/esm/tree-widget-react/components/TreeWidgetUiItemsProvider.js +3 -5
  11. package/lib/esm/tree-widget-react/components/TreeWidgetUiItemsProvider.js.map +1 -1
  12. package/lib/esm/tree-widget-react/components/tree-header/TreeHeader.d.ts +1 -2
  13. package/lib/esm/tree-widget-react/components/tree-header/TreeHeader.js +6 -49
  14. package/lib/esm/tree-widget-react/components/tree-header/TreeHeader.js.map +1 -1
  15. package/lib/esm/tree-widget-react/components/tree-header/TreeHeader.scss +0 -1
  16. package/lib/esm/tree-widget-react/components/tree-header/TreeWithHeader.d.ts +1 -1
  17. package/lib/esm/tree-widget-react/components/trees/categories-tree/CategoriesTree.d.ts +1 -2
  18. package/lib/esm/tree-widget-react/components/trees/categories-tree/CategoriesTreeButtons.d.ts +4 -4
  19. package/lib/esm/tree-widget-react/components/trees/categories-tree/CategoriesTreeButtons.js +10 -8
  20. package/lib/esm/tree-widget-react/components/trees/categories-tree/CategoriesTreeButtons.js.map +1 -1
  21. package/lib/esm/tree-widget-react/components/trees/categories-tree/CategoriesTreeComponent.d.ts +1 -1
  22. package/lib/esm/tree-widget-react/components/trees/categories-tree/CategoriesTreeComponent.js +3 -3
  23. package/lib/esm/tree-widget-react/components/trees/categories-tree/CategoriesTreeComponent.js.map +1 -1
  24. package/lib/esm/tree-widget-react/components/trees/categories-tree/UseCategoriesTree.js +1 -1
  25. package/lib/esm/tree-widget-react/components/trees/categories-tree/UseCategoriesTree.js.map +1 -1
  26. package/lib/esm/tree-widget-react/components/trees/common/FocusedInstancesContext.d.ts +4 -28
  27. package/lib/esm/tree-widget-react/components/trees/common/FocusedInstancesContext.js +2 -73
  28. package/lib/esm/tree-widget-react/components/trees/common/FocusedInstancesContext.js.map +1 -1
  29. package/lib/esm/tree-widget-react/components/trees/common/FocusedInstancesContextProvider.d.ts +7 -0
  30. package/lib/{cjs/tree-widget-react/components/trees/common/FocusedInstancesContext.js → esm/tree-widget-react/components/trees/common/FocusedInstancesContextProvider.js} +14 -34
  31. package/lib/esm/tree-widget-react/components/trees/common/FocusedInstancesContextProvider.js.map +1 -0
  32. package/lib/esm/tree-widget-react/components/trees/common/UseHierarchyFiltering.d.ts +1 -1
  33. package/lib/esm/tree-widget-react/components/trees/common/UseHierarchyFiltering.js +2 -2
  34. package/lib/esm/tree-widget-react/components/trees/common/UseHierarchyFiltering.js.map +1 -1
  35. package/lib/esm/tree-widget-react/components/trees/common/UseHierarchyVisibility.d.ts +2 -2
  36. package/lib/esm/tree-widget-react/components/trees/common/UseHierarchyVisibility.js +12 -10
  37. package/lib/esm/tree-widget-react/components/trees/common/UseHierarchyVisibility.js.map +1 -1
  38. package/lib/esm/tree-widget-react/components/trees/common/UseTelemetryContext.d.ts +1 -1
  39. package/lib/esm/tree-widget-react/components/trees/common/components/Delayed.d.ts +1 -1
  40. package/lib/esm/tree-widget-react/components/trees/common/components/ProgressOverlay.d.ts +1 -2
  41. package/lib/esm/tree-widget-react/components/trees/common/components/ProgressOverlay.js +3 -2
  42. package/lib/esm/tree-widget-react/components/trees/common/components/ProgressOverlay.js.map +1 -1
  43. package/lib/esm/tree-widget-react/components/trees/common/components/Tree.d.ts +4 -5
  44. package/lib/esm/tree-widget-react/components/trees/common/components/Tree.js +11 -12
  45. package/lib/esm/tree-widget-react/components/trees/common/components/Tree.js.map +1 -1
  46. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeVisibilityButton.css +8 -0
  47. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeVisibilityButton.d.ts +28 -0
  48. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeVisibilityButton.js +34 -0
  49. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeVisibilityButton.js.map +1 -0
  50. package/lib/esm/tree-widget-react/components/trees/common/components/TreeRenderer.d.ts +6 -12
  51. package/lib/esm/tree-widget-react/components/trees/common/components/TreeRenderer.js +5 -31
  52. package/lib/esm/tree-widget-react/components/trees/common/components/TreeRenderer.js.map +1 -1
  53. package/lib/esm/tree-widget-react/components/trees/common/components/UseVisibilityButtonHandler.d.ts +13 -0
  54. package/lib/esm/tree-widget-react/components/trees/common/{UseMultiCheckboxHandler.js → components/UseVisibilityButtonHandler.js} +7 -7
  55. package/lib/esm/tree-widget-react/components/trees/common/components/UseVisibilityButtonHandler.js.map +1 -0
  56. package/lib/esm/tree-widget-react/components/trees/common/components/VisibilityTree.d.ts +2 -2
  57. package/lib/esm/tree-widget-react/components/trees/common/components/VisibilityTree.js +2 -2
  58. package/lib/esm/tree-widget-react/components/trees/common/components/VisibilityTree.js.map +1 -1
  59. package/lib/esm/tree-widget-react/components/trees/common/components/VisibilityTreeRenderer.d.ts +3 -4
  60. package/lib/esm/tree-widget-react/components/trees/common/components/VisibilityTreeRenderer.js +9 -8
  61. package/lib/esm/tree-widget-react/components/trees/common/components/VisibilityTreeRenderer.js.map +1 -1
  62. package/lib/esm/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTree.d.ts +1 -2
  63. package/lib/esm/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTreeComponent.d.ts +1 -2
  64. package/lib/esm/tree-widget-react/components/trees/imodel-content-tree/IModelContentTree.d.ts +1 -2
  65. package/lib/esm/tree-widget-react/components/trees/imodel-content-tree/IModelContentTreeComponent.d.ts +1 -2
  66. package/lib/esm/tree-widget-react/components/trees/index.d.ts +0 -1
  67. package/lib/esm/tree-widget-react/components/trees/index.js +0 -1
  68. package/lib/esm/tree-widget-react/components/trees/index.js.map +1 -1
  69. package/lib/esm/tree-widget-react/components/trees/models-tree/ModelsTree.d.ts +1 -2
  70. package/lib/esm/tree-widget-react/components/trees/models-tree/ModelsTreeButtons.d.ts +8 -9
  71. package/lib/esm/tree-widget-react/components/trees/models-tree/ModelsTreeButtons.js +19 -16
  72. package/lib/esm/tree-widget-react/components/trees/models-tree/ModelsTreeButtons.js.map +1 -1
  73. package/lib/esm/tree-widget-react/components/trees/models-tree/ModelsTreeComponent.d.ts +2 -7
  74. package/lib/esm/tree-widget-react/components/trees/models-tree/ModelsTreeComponent.js +9 -13
  75. package/lib/esm/tree-widget-react/components/trees/models-tree/ModelsTreeComponent.js.map +1 -1
  76. package/lib/esm/tree-widget-react/components/trees/models-tree/UseModelsTree.d.ts +1 -1
  77. package/lib/esm/tree-widget-react/components/trees/models-tree/UseModelsTree.js +7 -14
  78. package/lib/esm/tree-widget-react/components/trees/models-tree/UseModelsTree.js.map +1 -1
  79. package/lib/esm/tree-widget-react/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js.map +1 -1
  80. package/package.json +19 -24
  81. package/lib/cjs/package.json +0 -1
  82. package/lib/cjs/tree-widget-react/TreeWidget.d.ts +0 -24
  83. package/lib/cjs/tree-widget-react/TreeWidget.js +0 -54
  84. package/lib/cjs/tree-widget-react/TreeWidget.js.map +0 -1
  85. package/lib/cjs/tree-widget-react/components/SelectableTree.d.ts +0 -47
  86. package/lib/cjs/tree-widget-react/components/SelectableTree.js +0 -107
  87. package/lib/cjs/tree-widget-react/components/SelectableTree.js.map +0 -1
  88. package/lib/cjs/tree-widget-react/components/SelectableTree.scss +0 -18
  89. package/lib/cjs/tree-widget-react/components/TreeSelector.d.ts +0 -31
  90. package/lib/cjs/tree-widget-react/components/TreeSelector.js +0 -30
  91. package/lib/cjs/tree-widget-react/components/TreeSelector.js.map +0 -1
  92. package/lib/cjs/tree-widget-react/components/TreeSelector.scss +0 -27
  93. package/lib/cjs/tree-widget-react/components/TreeWidgetUiItemsProvider.d.ts +0 -36
  94. package/lib/cjs/tree-widget-react/components/TreeWidgetUiItemsProvider.js +0 -74
  95. package/lib/cjs/tree-widget-react/components/TreeWidgetUiItemsProvider.js.map +0 -1
  96. package/lib/cjs/tree-widget-react/components/TreeWidgetUiItemsProvider.scss +0 -9
  97. package/lib/cjs/tree-widget-react/components/tree-header/TreeHeader.d.ts +0 -33
  98. package/lib/cjs/tree-widget-react/components/tree-header/TreeHeader.js +0 -75
  99. package/lib/cjs/tree-widget-react/components/tree-header/TreeHeader.js.map +0 -1
  100. package/lib/cjs/tree-widget-react/components/tree-header/TreeHeader.scss +0 -57
  101. package/lib/cjs/tree-widget-react/components/tree-header/TreeWithHeader.d.ts +0 -13
  102. package/lib/cjs/tree-widget-react/components/tree-header/TreeWithHeader.js +0 -20
  103. package/lib/cjs/tree-widget-react/components/tree-header/TreeWithHeader.js.map +0 -1
  104. package/lib/cjs/tree-widget-react/components/tree-header/TreeWithHeader.scss +0 -23
  105. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTree.d.ts +0 -12
  106. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTree.js +0 -22
  107. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTree.js.map +0 -1
  108. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeButtons.d.ts +0 -47
  109. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeButtons.js +0 -75
  110. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeButtons.js.map +0 -1
  111. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeComponent.d.ts +0 -53
  112. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeComponent.js +0 -73
  113. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeComponent.js.map +0 -1
  114. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeDefinition.d.ts +0 -23
  115. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeDefinition.js +0 -207
  116. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesTreeDefinition.js.map +0 -1
  117. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesVisibilityHandler.d.ts +0 -28
  118. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesVisibilityHandler.js +0 -91
  119. package/lib/cjs/tree-widget-react/components/trees/categories-tree/CategoriesVisibilityHandler.js.map +0 -1
  120. package/lib/cjs/tree-widget-react/components/trees/categories-tree/UseCategoriesTree.d.ts +0 -22
  121. package/lib/cjs/tree-widget-react/components/trees/categories-tree/UseCategoriesTree.js +0 -117
  122. package/lib/cjs/tree-widget-react/components/trees/categories-tree/UseCategoriesTree.js.map +0 -1
  123. package/lib/cjs/tree-widget-react/components/trees/common/CategoriesVisibilityUtils.d.ts +0 -42
  124. package/lib/cjs/tree-widget-react/components/trees/common/CategoriesVisibilityUtils.js +0 -119
  125. package/lib/cjs/tree-widget-react/components/trees/common/CategoriesVisibilityUtils.js.map +0 -1
  126. package/lib/cjs/tree-widget-react/components/trees/common/FocusedInstancesContext.d.ts +0 -35
  127. package/lib/cjs/tree-widget-react/components/trees/common/FocusedInstancesContext.js.map +0 -1
  128. package/lib/cjs/tree-widget-react/components/trees/common/Rxjs.d.ts +0 -10
  129. package/lib/cjs/tree-widget-react/components/trees/common/Rxjs.js +0 -46
  130. package/lib/cjs/tree-widget-react/components/trees/common/Rxjs.js.map +0 -1
  131. package/lib/cjs/tree-widget-react/components/trees/common/Tooltip.d.ts +0 -17
  132. package/lib/cjs/tree-widget-react/components/trees/common/Tooltip.js +0 -29
  133. package/lib/cjs/tree-widget-react/components/trees/common/Tooltip.js.map +0 -1
  134. package/lib/cjs/tree-widget-react/components/trees/common/TreeErrors.d.ts +0 -9
  135. package/lib/cjs/tree-widget-react/components/trees/common/TreeErrors.js +0 -19
  136. package/lib/cjs/tree-widget-react/components/trees/common/TreeErrors.js.map +0 -1
  137. package/lib/cjs/tree-widget-react/components/trees/common/UseActiveViewport.d.ts +0 -7
  138. package/lib/cjs/tree-widget-react/components/trees/common/UseActiveViewport.js +0 -25
  139. package/lib/cjs/tree-widget-react/components/trees/common/UseActiveViewport.js.map +0 -1
  140. package/lib/cjs/tree-widget-react/components/trees/common/UseFiltering.d.ts +0 -11
  141. package/lib/cjs/tree-widget-react/components/trees/common/UseFiltering.js +0 -28
  142. package/lib/cjs/tree-widget-react/components/trees/common/UseFiltering.js.map +0 -1
  143. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchiesLocalization.d.ts +0 -7
  144. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchiesLocalization.js +0 -33
  145. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchiesLocalization.js.map +0 -1
  146. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchyFiltering.d.ts +0 -13
  147. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchyFiltering.js +0 -158
  148. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchyFiltering.js.map +0 -1
  149. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchyVisibility.d.ts +0 -55
  150. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchyVisibility.js +0 -114
  151. package/lib/cjs/tree-widget-react/components/trees/common/UseHierarchyVisibility.js.map +0 -1
  152. package/lib/cjs/tree-widget-react/components/trees/common/UseIModelChangeListener.d.ts +0 -8
  153. package/lib/cjs/tree-widget-react/components/trees/common/UseIModelChangeListener.js +0 -19
  154. package/lib/cjs/tree-widget-react/components/trees/common/UseIModelChangeListener.js.map +0 -1
  155. package/lib/cjs/tree-widget-react/components/trees/common/UseMultiCheckboxHandler.d.ts +0 -12
  156. package/lib/cjs/tree-widget-react/components/trees/common/UseMultiCheckboxHandler.js +0 -34
  157. package/lib/cjs/tree-widget-react/components/trees/common/UseMultiCheckboxHandler.js.map +0 -1
  158. package/lib/cjs/tree-widget-react/components/trees/common/UseNodeHighlighting.d.ts +0 -20
  159. package/lib/cjs/tree-widget-react/components/trees/common/UseNodeHighlighting.js +0 -131
  160. package/lib/cjs/tree-widget-react/components/trees/common/UseNodeHighlighting.js.map +0 -1
  161. package/lib/cjs/tree-widget-react/components/trees/common/UseTelemetryContext.d.ts +0 -29
  162. package/lib/cjs/tree-widget-react/components/trees/common/UseTelemetryContext.js +0 -49
  163. package/lib/cjs/tree-widget-react/components/trees/common/UseTelemetryContext.js.map +0 -1
  164. package/lib/cjs/tree-widget-react/components/trees/common/Utils.d.ts +0 -27
  165. package/lib/cjs/tree-widget-react/components/trees/common/Utils.js +0 -66
  166. package/lib/cjs/tree-widget-react/components/trees/common/Utils.js.map +0 -1
  167. package/lib/cjs/tree-widget-react/components/trees/common/components/Delayed.d.ts +0 -5
  168. package/lib/cjs/tree-widget-react/components/trees/common/components/Delayed.js +0 -30
  169. package/lib/cjs/tree-widget-react/components/trees/common/components/Delayed.js.map +0 -1
  170. package/lib/cjs/tree-widget-react/components/trees/common/components/ProgressOverlay.d.ts +0 -4
  171. package/lib/cjs/tree-widget-react/components/trees/common/components/ProgressOverlay.js +0 -15
  172. package/lib/cjs/tree-widget-react/components/trees/common/components/ProgressOverlay.js.map +0 -1
  173. package/lib/cjs/tree-widget-react/components/trees/common/components/ProgressOverlay.scss +0 -21
  174. package/lib/cjs/tree-widget-react/components/trees/common/components/Tree.d.ts +0 -44
  175. package/lib/cjs/tree-widget-react/components/trees/common/components/Tree.js +0 -98
  176. package/lib/cjs/tree-widget-react/components/trees/common/components/Tree.js.map +0 -1
  177. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeNodeCheckbox.d.ts +0 -27
  178. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeNodeCheckbox.js +0 -27
  179. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeNodeCheckbox.js.map +0 -1
  180. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeNodeRenderer.d.ts +0 -11
  181. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeNodeRenderer.js +0 -19
  182. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeNodeRenderer.js.map +0 -1
  183. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeRenderer.d.ts +0 -19
  184. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeRenderer.js +0 -48
  185. package/lib/cjs/tree-widget-react/components/trees/common/components/TreeRenderer.js.map +0 -1
  186. package/lib/cjs/tree-widget-react/components/trees/common/components/VisibilityTree.d.ts +0 -21
  187. package/lib/cjs/tree-widget-react/components/trees/common/components/VisibilityTree.js +0 -26
  188. package/lib/cjs/tree-widget-react/components/trees/common/components/VisibilityTree.js.map +0 -1
  189. package/lib/cjs/tree-widget-react/components/trees/common/components/VisibilityTreeRenderer.d.ts +0 -11
  190. package/lib/cjs/tree-widget-react/components/trees/common/components/VisibilityTreeRenderer.js +0 -26
  191. package/lib/cjs/tree-widget-react/components/trees/common/components/VisibilityTreeRenderer.js.map +0 -1
  192. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTree.d.ts +0 -11
  193. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTree.js +0 -38
  194. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTree.js.map +0 -1
  195. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTreeComponent.d.ts +0 -26
  196. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js +0 -35
  197. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js.map +0 -1
  198. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTreeDefinition.d.ts +0 -24
  199. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTreeDefinition.js +0 -265
  200. package/lib/cjs/tree-widget-react/components/trees/external-sources-tree/ExternalSourcesTreeDefinition.js.map +0 -1
  201. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTree.d.ts +0 -11
  202. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTree.js +0 -50
  203. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTree.js.map +0 -1
  204. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTreeComponent.d.ts +0 -26
  205. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTreeComponent.js +0 -35
  206. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTreeComponent.js.map +0 -1
  207. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTreeDefinition.d.ts +0 -29
  208. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTreeDefinition.js +0 -622
  209. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/IModelContentTreeDefinition.js.map +0 -1
  210. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/internal/IModelContentTreeIdsCache.d.ts +0 -26
  211. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/internal/IModelContentTreeIdsCache.js +0 -203
  212. package/lib/cjs/tree-widget-react/components/trees/imodel-content-tree/internal/IModelContentTreeIdsCache.js.map +0 -1
  213. package/lib/cjs/tree-widget-react/components/trees/index.d.ts +0 -18
  214. package/lib/cjs/tree-widget-react/components/trees/index.js +0 -39
  215. package/lib/cjs/tree-widget-react/components/trees/index.js.map +0 -1
  216. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTree.d.ts +0 -12
  217. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTree.js +0 -26
  218. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTree.js.map +0 -1
  219. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeButtons.d.ts +0 -65
  220. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeButtons.js +0 -144
  221. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeButtons.js.map +0 -1
  222. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeComponent.d.ts +0 -78
  223. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeComponent.js +0 -106
  224. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeComponent.js.map +0 -1
  225. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeDefinition.d.ts +0 -79
  226. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeDefinition.js +0 -650
  227. package/lib/cjs/tree-widget-react/components/trees/models-tree/ModelsTreeDefinition.js.map +0 -1
  228. package/lib/cjs/tree-widget-react/components/trees/models-tree/UseModelsTree.d.ts +0 -44
  229. package/lib/cjs/tree-widget-react/components/trees/models-tree/UseModelsTree.js +0 -312
  230. package/lib/cjs/tree-widget-react/components/trees/models-tree/UseModelsTree.js.map +0 -1
  231. package/lib/cjs/tree-widget-react/components/trees/models-tree/Utils.d.ts +0 -7
  232. package/lib/cjs/tree-widget-react/components/trees/models-tree/Utils.js +0 -25
  233. package/lib/cjs/tree-widget-react/components/trees/models-tree/Utils.js.map +0 -1
  234. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/AlwaysAndNeverDrawnElementInfo.d.ts +0 -29
  235. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/AlwaysAndNeverDrawnElementInfo.js +0 -142
  236. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/AlwaysAndNeverDrawnElementInfo.js.map +0 -1
  237. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/FilteredTree.d.ts +0 -25
  238. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/FilteredTree.js +0 -178
  239. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/FilteredTree.js.map +0 -1
  240. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeIdsCache.d.ts +0 -44
  241. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeIdsCache.js +0 -385
  242. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeIdsCache.js.map +0 -1
  243. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeNode.d.ts +0 -37
  244. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeNode.js +0 -57
  245. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeNode.js.map +0 -1
  246. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.d.ts +0 -106
  247. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js +0 -672
  248. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js.map +0 -1
  249. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/VisibilityChangeEventListener.d.ts +0 -12
  250. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/VisibilityChangeEventListener.js +0 -52
  251. package/lib/cjs/tree-widget-react/components/trees/models-tree/internal/VisibilityChangeEventListener.js.map +0 -1
  252. package/lib/cjs/tree-widget-react/components/utils/IsPromiseLike.d.ts +0 -6
  253. package/lib/cjs/tree-widget-react/components/utils/IsPromiseLike.js +0 -16
  254. package/lib/cjs/tree-widget-react/components/utils/IsPromiseLike.js.map +0 -1
  255. package/lib/cjs/tree-widget-react.d.ts +0 -6
  256. package/lib/cjs/tree-widget-react.js +0 -32
  257. package/lib/cjs/tree-widget-react.js.map +0 -1
  258. package/lib/esm/tree-widget-react/components/trees/common/UseMultiCheckboxHandler.d.ts +0 -12
  259. package/lib/esm/tree-widget-react/components/trees/common/UseMultiCheckboxHandler.js.map +0 -1
  260. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeCheckbox.d.ts +0 -27
  261. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeCheckbox.js +0 -23
  262. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeCheckbox.js.map +0 -1
  263. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeRenderer.d.ts +0 -11
  264. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeRenderer.js +0 -16
  265. package/lib/esm/tree-widget-react/components/trees/common/components/TreeNodeRenderer.js.map +0 -1
@@ -1,23 +0,0 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
-
6
- .tw-tree-with-header {
7
- --tree-header-height: var(--iui-size-xl);
8
- --tree-header-contracted-width: var(--iui-size-xl);
9
-
10
- width: 100%;
11
- height: 100%;
12
- display: flex;
13
- flex-direction: column;
14
-
15
- &.enlarge {
16
- --tree-header-height: calc(var(--iui-size-xl) + var(--iui-size-l));
17
- --tree-header-contracted-width: calc(var(--iui-size-xl) + var(--iui-size-l));
18
- }
19
-
20
- .tw-tree-content {
21
- height: calc(100% - var(--tree-header-height));
22
- }
23
- }
@@ -1,12 +0,0 @@
1
- /// <reference types="react" />
2
- import type { UseCategoriesTreeProps } from "./UseCategoriesTree.js";
3
- import type { VisibilityTreeProps } from "../common/components/VisibilityTree.js";
4
- /** @beta */
5
- export type CategoriesTreeProps = Pick<VisibilityTreeProps, "imodel" | "getSchemaContext" | "selectionStorage" | "density" | "selectionMode"> & UseCategoriesTreeProps & {
6
- hierarchyLevelConfig?: {
7
- sizeLimit?: number;
8
- };
9
- };
10
- /** @beta */
11
- export declare function CategoriesTree({ imodel, getSchemaContext, selectionStorage, activeView, filter, density, hierarchyLevelConfig, selectionMode, onCategoriesFiltered, }: CategoriesTreeProps): JSX.Element;
12
- //# sourceMappingURL=CategoriesTree.d.ts.map
@@ -1,22 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CategoriesTree = 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 VisibilityTree_js_1 = require("../common/components/VisibilityTree.js");
10
- const VisibilityTreeRenderer_js_1 = require("../common/components/VisibilityTreeRenderer.js");
11
- const UseCategoriesTree_js_1 = require("./UseCategoriesTree.js");
12
- /** @beta */
13
- function CategoriesTree({ imodel, getSchemaContext, selectionStorage, activeView, filter, density, hierarchyLevelConfig, selectionMode, onCategoriesFiltered, }) {
14
- const { categoriesTreeProps, rendererProps } = (0, UseCategoriesTree_js_1.useCategoriesTree)({
15
- filter,
16
- activeView,
17
- onCategoriesFiltered,
18
- });
19
- return ((0, jsx_runtime_1.jsx)(VisibilityTree_js_1.VisibilityTree, { ...categoriesTreeProps, imodel: imodel, selectionStorage: selectionStorage, getSchemaContext: getSchemaContext, hierarchyLevelSizeLimit: hierarchyLevelConfig?.sizeLimit, density: density, selectionMode: selectionMode ?? "none", treeRenderer: (treeProps) => (0, jsx_runtime_1.jsx)(VisibilityTreeRenderer_js_1.VisibilityTreeRenderer, { ...treeProps, ...rendererProps }) }));
20
- }
21
- exports.CategoriesTree = CategoriesTree;
22
- //# sourceMappingURL=CategoriesTree.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CategoriesTree.js","sourceRoot":"","sources":["../../../../../../src/tree-widget-react/components/trees/categories-tree/CategoriesTree.tsx"],"names":[],"mappings":";;;;AAAA;;;gGAGgG;AAEhG,8EAAwE;AACxE,8FAAwF;AACxF,iEAA2D;AAa3D,YAAY;AACZ,SAAgB,cAAc,CAAC,EAC7B,MAAM,EACN,gBAAgB,EAChB,gBAAgB,EAChB,UAAU,EACV,MAAM,EACN,OAAO,EACP,oBAAoB,EACpB,aAAa,EACb,oBAAoB,GACA;IACpB,MAAM,EAAE,mBAAmB,EAAE,aAAa,EAAE,GAAG,IAAA,wCAAiB,EAAC;QAC/D,MAAM;QACN,UAAU;QACV,oBAAoB;KACrB,CAAC,CAAC;IAEH,OAAO,CACL,uBAAC,kCAAc,OACT,mBAAmB,EACvB,MAAM,EAAE,MAAM,EACd,gBAAgB,EAAE,gBAAgB,EAClC,gBAAgB,EAAE,gBAAgB,EAClC,uBAAuB,EAAE,oBAAoB,EAAE,SAAS,EACxD,OAAO,EAAE,OAAO,EAChB,aAAa,EAAE,aAAa,IAAI,MAAM,EACtC,YAAY,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,uBAAC,kDAAsB,OAAK,SAAS,KAAM,aAAa,GAAI,GACzF,CACH,CAAC;AACJ,CAAC;AA7BD,wCA6BC","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 { VisibilityTree } from \"../common/components/VisibilityTree.js\";\nimport { VisibilityTreeRenderer } from \"../common/components/VisibilityTreeRenderer.js\";\nimport { useCategoriesTree } from \"./UseCategoriesTree.js\";\n\nimport type { UseCategoriesTreeProps } from \"./UseCategoriesTree.js\";\nimport type { VisibilityTreeProps } from \"../common/components/VisibilityTree.js\";\n\n/** @beta */\nexport type CategoriesTreeProps = Pick<VisibilityTreeProps, \"imodel\" | \"getSchemaContext\" | \"selectionStorage\" | \"density\" | \"selectionMode\"> &\n UseCategoriesTreeProps & {\n hierarchyLevelConfig?: {\n sizeLimit?: number;\n };\n };\n\n/** @beta */\nexport function CategoriesTree({\n imodel,\n getSchemaContext,\n selectionStorage,\n activeView,\n filter,\n density,\n hierarchyLevelConfig,\n selectionMode,\n onCategoriesFiltered,\n}: CategoriesTreeProps) {\n const { categoriesTreeProps, rendererProps } = useCategoriesTree({\n filter,\n activeView,\n onCategoriesFiltered,\n });\n\n return (\n <VisibilityTree\n {...categoriesTreeProps}\n imodel={imodel}\n selectionStorage={selectionStorage}\n getSchemaContext={getSchemaContext}\n hierarchyLevelSizeLimit={hierarchyLevelConfig?.sizeLimit}\n density={density}\n selectionMode={selectionMode ?? \"none\"}\n treeRenderer={(treeProps) => <VisibilityTreeRenderer {...treeProps} {...rendererProps} />}\n />\n );\n}\n"]}
@@ -1,47 +0,0 @@
1
- /// <reference types="react" />
2
- import type { CategoryInfo } from "../common/CategoriesVisibilityUtils.js";
3
- import type { TreeHeaderButtonProps } from "../../tree-header/TreeHeader.js";
4
- import type { Viewport } from "@itwin/core-frontend";
5
- /**
6
- * Props that get passed to `CategoriesTreeComponent` header button renderer.
7
- * @see CategoriesTreeComponentProps.headerButtons
8
- * @public
9
- */
10
- export interface CategoriesTreeHeaderButtonProps extends TreeHeaderButtonProps {
11
- /** A list of categories available in the iModel */
12
- categories: CategoryInfo[];
13
- }
14
- /**
15
- * Custom hook that creates props required to render `CategoriesTreeComponent` header button.
16
- *
17
- * Example:
18
- * ```tsx
19
- * const { buttonProps, onCategoriesFiltered } = useCategoriesTreeButtonProps({ viewport });
20
- * <TreeWithHeader
21
- * buttons={[
22
- * <CategoriesTreeComponent.ShowAllButton {...buttonProps} />,
23
- * <CategoriesTreeComponent.HideAllButton {...buttonProps} />,
24
- * ]}
25
- * >
26
- * <CategoriesTree {...treeProps} onCategoriesFiltered={onCategoriesFiltered} />
27
- * </TreeWithHeader>
28
- * ```
29
- *
30
- * @public
31
- */
32
- export declare function useCategoriesTreeButtonProps({ viewport }: {
33
- viewport: Viewport;
34
- }): {
35
- buttonProps: Pick<CategoriesTreeHeaderButtonProps, "categories" | "viewport">;
36
- onCategoriesFiltered: (categories: CategoryInfo[] | undefined) => void;
37
- };
38
- /** @public */
39
- export type CategoriesTreeHeaderButtonType = (props: CategoriesTreeHeaderButtonProps) => JSX.Element | null;
40
- /** @public */
41
- export declare function ShowAllButton(props: CategoriesTreeHeaderButtonProps): JSX.Element;
42
- /** @public */
43
- export declare function HideAllButton(props: CategoriesTreeHeaderButtonProps): JSX.Element;
44
- /** @public */
45
- export declare function InvertAllButton(props: CategoriesTreeHeaderButtonProps): JSX.Element;
46
- export declare function useCategories(viewport: Viewport): CategoryInfo[];
47
- //# sourceMappingURL=CategoriesTreeButtons.d.ts.map
@@ -1,75 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useCategories = exports.InvertAllButton = exports.HideAllButton = exports.ShowAllButton = exports.useCategoriesTreeButtonProps = 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 components_react_1 = require("@itwin/components-react");
11
- const itwinui_icons_react_1 = require("@itwin/itwinui-icons-react");
12
- const itwinui_react_1 = require("@itwin/itwinui-react");
13
- const TreeWidget_js_1 = require("../../../TreeWidget.js");
14
- const CategoriesVisibilityUtils_js_1 = require("../common/CategoriesVisibilityUtils.js");
15
- /**
16
- * Custom hook that creates props required to render `CategoriesTreeComponent` header button.
17
- *
18
- * Example:
19
- * ```tsx
20
- * const { buttonProps, onCategoriesFiltered } = useCategoriesTreeButtonProps({ viewport });
21
- * <TreeWithHeader
22
- * buttons={[
23
- * <CategoriesTreeComponent.ShowAllButton {...buttonProps} />,
24
- * <CategoriesTreeComponent.HideAllButton {...buttonProps} />,
25
- * ]}
26
- * >
27
- * <CategoriesTree {...treeProps} onCategoriesFiltered={onCategoriesFiltered} />
28
- * </TreeWithHeader>
29
- * ```
30
- *
31
- * @public
32
- */
33
- function useCategoriesTreeButtonProps({ viewport }) {
34
- const [filteredCategories, setFilteredCategories] = (0, react_1.useState)();
35
- const categories = useCategories(viewport);
36
- return {
37
- buttonProps: {
38
- viewport,
39
- categories: filteredCategories ?? categories,
40
- },
41
- onCategoriesFiltered: setFilteredCategories,
42
- };
43
- }
44
- exports.useCategoriesTreeButtonProps = useCategoriesTreeButtonProps;
45
- /** @public */
46
- function ShowAllButton(props) {
47
- return ((0, jsx_runtime_1.jsx)(itwinui_react_1.IconButton, { size: props.density === "enlarged" ? "large" : "small", styleType: "borderless", label: TreeWidget_js_1.TreeWidget.translate("categoriesTree.buttons.showAll.tooltip"), onClick: () => {
48
- props.onFeatureUsed?.(`categories-tree-showall`);
49
- void (0, CategoriesVisibilityUtils_js_1.showAllCategories)(props.categories.map((category) => category.categoryId), props.viewport);
50
- }, children: (0, jsx_runtime_1.jsx)(itwinui_icons_react_1.SvgVisibilityShow, {}) }));
51
- }
52
- exports.ShowAllButton = ShowAllButton;
53
- /** @public */
54
- function HideAllButton(props) {
55
- return ((0, jsx_runtime_1.jsx)(itwinui_react_1.IconButton, { size: props.density === "enlarged" ? "large" : "small", styleType: "borderless", label: TreeWidget_js_1.TreeWidget.translate("categoriesTree.buttons.hideAll.tooltip"), onClick: () => {
56
- props.onFeatureUsed?.(`categories-tree-hideall`);
57
- void (0, CategoriesVisibilityUtils_js_1.hideAllCategories)(props.categories.map((category) => category.categoryId), props.viewport);
58
- }, children: (0, jsx_runtime_1.jsx)(itwinui_icons_react_1.SvgVisibilityHide, {}) }));
59
- }
60
- exports.HideAllButton = HideAllButton;
61
- /** @public */
62
- function InvertAllButton(props) {
63
- return ((0, jsx_runtime_1.jsx)(itwinui_react_1.IconButton, { label: TreeWidget_js_1.TreeWidget.translate("categoriesTree.buttons.invert.tooltip"), size: props.density === "enlarged" ? "large" : "small", styleType: "borderless", onClick: () => {
64
- props.onFeatureUsed?.(`categories-tree-invert`);
65
- void (0, CategoriesVisibilityUtils_js_1.invertAllCategories)(props.categories, props.viewport);
66
- }, children: (0, jsx_runtime_1.jsx)(itwinui_icons_react_1.SvgVisibilityHalf, {}) }));
67
- }
68
- exports.InvertAllButton = InvertAllButton;
69
- const EMPTY_CATEGORIES_ARRAY = [];
70
- function useCategories(viewport) {
71
- const categoriesPromise = (0, react_1.useMemo)(async () => (0, CategoriesVisibilityUtils_js_1.loadCategoriesFromViewport)(viewport), [viewport]);
72
- return (0, components_react_1.useAsyncValue)(categoriesPromise) ?? EMPTY_CATEGORIES_ARRAY;
73
- }
74
- exports.useCategories = useCategories;
75
- //# sourceMappingURL=CategoriesTreeButtons.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CategoriesTreeButtons.js","sourceRoot":"","sources":["../../../../../../src/tree-widget-react/components/trees/categories-tree/CategoriesTreeButtons.tsx"],"names":[],"mappings":"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","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, useState } from \"react\";\nimport { useAsyncValue } from \"@itwin/components-react\";\nimport { SvgVisibilityHalf, SvgVisibilityHide, SvgVisibilityShow } from \"@itwin/itwinui-icons-react\";\nimport { IconButton } from \"@itwin/itwinui-react\";\nimport { TreeWidget } from \"../../../TreeWidget.js\";\nimport { hideAllCategories, invertAllCategories, loadCategoriesFromViewport, showAllCategories } from \"../common/CategoriesVisibilityUtils.js\";\n\nimport type { CategoryInfo } from \"../common/CategoriesVisibilityUtils.js\";\nimport type { TreeHeaderButtonProps } from \"../../tree-header/TreeHeader.js\";\nimport type { Viewport } from \"@itwin/core-frontend\";\n\n/**\n * Props that get passed to `CategoriesTreeComponent` header button renderer.\n * @see CategoriesTreeComponentProps.headerButtons\n * @public\n */\nexport interface CategoriesTreeHeaderButtonProps extends TreeHeaderButtonProps {\n /** A list of categories available in the iModel */\n categories: CategoryInfo[];\n}\n\n/**\n * Custom hook that creates props required to render `CategoriesTreeComponent` header button.\n *\n * Example:\n * ```tsx\n * const { buttonProps, onCategoriesFiltered } = useCategoriesTreeButtonProps({ viewport });\n * <TreeWithHeader\n * buttons={[\n * <CategoriesTreeComponent.ShowAllButton {...buttonProps} />,\n * <CategoriesTreeComponent.HideAllButton {...buttonProps} />,\n * ]}\n * >\n * <CategoriesTree {...treeProps} onCategoriesFiltered={onCategoriesFiltered} />\n * </TreeWithHeader>\n * ```\n *\n * @public\n */\nexport function useCategoriesTreeButtonProps({ viewport }: { viewport: Viewport }): {\n buttonProps: Pick<CategoriesTreeHeaderButtonProps, \"categories\" | \"viewport\">;\n onCategoriesFiltered: (categories: CategoryInfo[] | undefined) => void;\n} {\n const [filteredCategories, setFilteredCategories] = useState<CategoryInfo[] | undefined>();\n const categories = useCategories(viewport);\n return {\n buttonProps: {\n viewport,\n categories: filteredCategories ?? categories,\n },\n onCategoriesFiltered: setFilteredCategories,\n };\n}\n\n/** @public */\nexport type CategoriesTreeHeaderButtonType = (props: CategoriesTreeHeaderButtonProps) => JSX.Element | null;\n\n/** @public */\nexport function ShowAllButton(props: CategoriesTreeHeaderButtonProps) {\n return (\n <IconButton\n size={props.density === \"enlarged\" ? \"large\" : \"small\"}\n styleType=\"borderless\"\n label={TreeWidget.translate(\"categoriesTree.buttons.showAll.tooltip\")}\n onClick={() => {\n props.onFeatureUsed?.(`categories-tree-showall`);\n void showAllCategories(\n props.categories.map((category) => category.categoryId),\n props.viewport,\n );\n }}\n >\n <SvgVisibilityShow />\n </IconButton>\n );\n}\n\n/** @public */\nexport function HideAllButton(props: CategoriesTreeHeaderButtonProps) {\n return (\n <IconButton\n size={props.density === \"enlarged\" ? \"large\" : \"small\"}\n styleType=\"borderless\"\n label={TreeWidget.translate(\"categoriesTree.buttons.hideAll.tooltip\")}\n onClick={() => {\n props.onFeatureUsed?.(`categories-tree-hideall`);\n void hideAllCategories(\n props.categories.map((category) => category.categoryId),\n props.viewport,\n );\n }}\n >\n <SvgVisibilityHide />\n </IconButton>\n );\n}\n\n/** @public */\nexport function InvertAllButton(props: CategoriesTreeHeaderButtonProps) {\n return (\n <IconButton\n label={TreeWidget.translate(\"categoriesTree.buttons.invert.tooltip\")}\n size={props.density === \"enlarged\" ? \"large\" : \"small\"}\n styleType=\"borderless\"\n onClick={() => {\n props.onFeatureUsed?.(`categories-tree-invert`);\n void invertAllCategories(props.categories, props.viewport);\n }}\n >\n <SvgVisibilityHalf />\n </IconButton>\n );\n}\n\nconst EMPTY_CATEGORIES_ARRAY: CategoryInfo[] = [];\n\nexport function useCategories(viewport: Viewport) {\n const categoriesPromise = useMemo(async () => loadCategoriesFromViewport(viewport), [viewport]);\n return useAsyncValue(categoriesPromise) ?? EMPTY_CATEGORIES_ARRAY;\n}\n"]}
@@ -1,53 +0,0 @@
1
- /// <reference types="react" />
2
- import type { CategoriesTreeProps } from "./CategoriesTree.js";
3
- import type { CategoriesTreeHeaderButtonProps, CategoriesTreeHeaderButtonType } from "./CategoriesTreeButtons.js";
4
- /** @public */
5
- interface CategoriesTreeComponentProps extends Pick<CategoriesTreeProps, "getSchemaContext" | "selectionStorage" | "density" | "hierarchyLevelConfig" | "selectionMode"> {
6
- /**
7
- * Renderers of header buttons. Defaults to:
8
- * ```ts
9
- * [
10
- * CategoriesTreeComponent.ShowAllButton,
11
- * CategoriesTreeComponent.HideAllButton,
12
- * CategoriesTreeComponent.InvertAllButton,
13
- * ]
14
- * ```
15
- */
16
- headerButtons?: Array<(props: CategoriesTreeHeaderButtonProps) => React.ReactNode>;
17
- onPerformanceMeasured?: (featureId: string, duration: number) => void;
18
- onFeatureUsed?: (feature: string) => void;
19
- }
20
- /**
21
- * A component that renders `CategoriesTree` and a header with filtering capabilities and header buttons.
22
- * @public
23
- */
24
- export declare const CategoriesTreeComponent: {
25
- (props: CategoriesTreeComponentProps): JSX.Element | null;
26
- /**
27
- * Renders a "Show all" button that enables display of all categories and their subcategories.
28
- * @public
29
- */
30
- ShowAllButton: CategoriesTreeHeaderButtonType;
31
- /**
32
- * Renders a "Hide all" button that disables display of all categories.
33
- * @public
34
- */
35
- HideAllButton: CategoriesTreeHeaderButtonType;
36
- /**
37
- * Renders an "Invert all" button that inverts display of all categories.
38
- * @public
39
- */
40
- InvertAllButton: CategoriesTreeHeaderButtonType;
41
- /**
42
- * Id of the component. May be used when a creating a `TreeDefinition` for `SelectableTree`.
43
- * @public
44
- */
45
- id: string;
46
- /**
47
- * Label of the component. May be used when a creating a `TreeDefinition` for `SelectableTree`.
48
- * @public
49
- */
50
- getLabel(): string;
51
- };
52
- export {};
53
- //# sourceMappingURL=CategoriesTreeComponent.d.ts.map
@@ -1,73 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CategoriesTreeComponent = void 0;
4
- const react_1 = require("react");
5
- const jsx_runtime_1 = require("react/jsx-runtime");
6
- /*---------------------------------------------------------------------------------------------
7
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
8
- * See LICENSE.md in the project root for license terms and full copyright notice.
9
- *--------------------------------------------------------------------------------------------*/
10
- const react_2 = require("react");
11
- const appui_react_1 = require("@itwin/appui-react");
12
- const TreeWidget_js_1 = require("../../../TreeWidget.js");
13
- const TreeWithHeader_js_1 = require("../../tree-header/TreeWithHeader.js");
14
- const UseActiveViewport_js_1 = require("../common/UseActiveViewport.js");
15
- const UseFiltering_js_1 = require("../common/UseFiltering.js");
16
- const UseTelemetryContext_js_1 = require("../common/UseTelemetryContext.js");
17
- const CategoriesTree_js_1 = require("./CategoriesTree.js");
18
- const CategoriesTreeButtons_js_1 = require("./CategoriesTreeButtons.js");
19
- /**
20
- * A component that renders `CategoriesTree` and a header with filtering capabilities and header buttons.
21
- * @public
22
- */
23
- const CategoriesTreeComponent = (props) => {
24
- const iModel = (0, appui_react_1.useActiveIModelConnection)();
25
- const viewport = (0, UseActiveViewport_js_1.useActiveViewport)();
26
- if (!iModel || !viewport) {
27
- return null;
28
- }
29
- return (0, jsx_runtime_1.jsx)(CategoriesTreeComponentImpl, { ...props, iModel: iModel, viewport: viewport });
30
- };
31
- exports.CategoriesTreeComponent = CategoriesTreeComponent;
32
- /**
33
- * Renders a "Show all" button that enables display of all categories and their subcategories.
34
- * @public
35
- */
36
- exports.CategoriesTreeComponent.ShowAllButton = CategoriesTreeButtons_js_1.ShowAllButton;
37
- /**
38
- * Renders a "Hide all" button that disables display of all categories.
39
- * @public
40
- */
41
- exports.CategoriesTreeComponent.HideAllButton = CategoriesTreeButtons_js_1.HideAllButton;
42
- /**
43
- * Renders an "Invert all" button that inverts display of all categories.
44
- * @public
45
- */
46
- exports.CategoriesTreeComponent.InvertAllButton = CategoriesTreeButtons_js_1.InvertAllButton;
47
- /**
48
- * Id of the component. May be used when a creating a `TreeDefinition` for `SelectableTree`.
49
- * @public
50
- */
51
- exports.CategoriesTreeComponent.id = "categories-tree-v2";
52
- /**
53
- * Label of the component. May be used when a creating a `TreeDefinition` for `SelectableTree`.
54
- * @public
55
- */
56
- exports.CategoriesTreeComponent.getLabel = () => TreeWidget_js_1.TreeWidget.translate("categoriesTree.label");
57
- function CategoriesTreeComponentImpl({ iModel, viewport, headerButtons, onPerformanceMeasured, onFeatureUsed, ...treeProps }) {
58
- const { buttonProps, onCategoriesFiltered } = (0, CategoriesTreeButtons_js_1.useCategoriesTreeButtonProps)({ viewport });
59
- const { filter, applyFilter, clearFilter } = (0, UseFiltering_js_1.useFiltering)();
60
- const density = treeProps.density;
61
- const buttons = headerButtons
62
- ? headerButtons.map((btn, index) => (0, jsx_runtime_1.jsx)(react_2.Fragment, { children: btn({ ...buttonProps, onFeatureUsed }) }, index))
63
- : [
64
- (0, react_1.createElement)(CategoriesTreeButtons_js_1.ShowAllButton, { ...buttonProps, key: "show-all-btn", density: density, onFeatureUsed: onFeatureUsed }),
65
- (0, react_1.createElement)(CategoriesTreeButtons_js_1.HideAllButton, { ...buttonProps, key: "hide-all-btn", density: density, onFeatureUsed: onFeatureUsed }),
66
- (0, react_1.createElement)(CategoriesTreeButtons_js_1.InvertAllButton, { ...buttonProps, key: "invert-all-btn", density: density, onFeatureUsed: onFeatureUsed }),
67
- ];
68
- return ((0, jsx_runtime_1.jsx)(UseTelemetryContext_js_1.TelemetryContextProvider, { componentIdentifier: exports.CategoriesTreeComponent.id, onFeatureUsed: onFeatureUsed, onPerformanceMeasured: onPerformanceMeasured, children: (0, jsx_runtime_1.jsx)(TreeWithHeader_js_1.TreeWithHeader, { buttons: buttons, density: density, filteringProps: {
69
- onFilterStart: applyFilter,
70
- onFilterClear: clearFilter,
71
- }, children: (0, jsx_runtime_1.jsx)(CategoriesTree_js_1.CategoriesTree, { ...treeProps, imodel: iModel, activeView: viewport, filter: filter, onCategoriesFiltered: onCategoriesFiltered }) }) }));
72
- }
73
- //# sourceMappingURL=CategoriesTreeComponent.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CategoriesTreeComponent.js","sourceRoot":"","sources":["../../../../../../src/tree-widget-react/components/trees/categories-tree/CategoriesTreeComponent.tsx"],"names":[],"mappings":";;;;;AAAA;;;gGAGgG;AAEhG,iCAAiC;AACjC,oDAA+D;AAC/D,0DAAoD;AACpD,2EAAqE;AACrE,yEAAmE;AACnE,+DAAyD;AACzD,6EAA4E;AAC5E,2DAAqD;AACrD,yEAAyH;AAyBzH;;;GAGG;AACI,MAAM,uBAAuB,GAAG,CAAC,KAAmC,EAAE,EAAE;IAC7E,MAAM,MAAM,GAAG,IAAA,uCAAyB,GAAE,CAAC;IAC3C,MAAM,QAAQ,GAAG,IAAA,wCAAiB,GAAE,CAAC;IAErC,IAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE;QACxB,OAAO,IAAI,CAAC;KACb;IAED,OAAO,uBAAC,2BAA2B,OAAK,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAI,CAAC;AACxF,CAAC,CAAC;AATW,QAAA,uBAAuB,2BASlC;AAEF;;;GAGG;AACH,+BAAuB,CAAC,aAAa,GAAG,wCAA+C,CAAC;AAExF;;;GAGG;AACH,+BAAuB,CAAC,aAAa,GAAG,wCAA+C,CAAC;AAExF;;;GAGG;AACH,+BAAuB,CAAC,eAAe,GAAG,0CAAiD,CAAC;AAE5F;;;GAGG;AACH,+BAAuB,CAAC,EAAE,GAAG,oBAAoB,CAAC;AAElD;;;GAGG;AACH,+BAAuB,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,0BAAU,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;AAEtF,SAAS,2BAA2B,CAAC,EACnC,MAAM,EACN,QAAQ,EACR,aAAa,EACb,qBAAqB,EACrB,aAAa,EACb,GAAG,SAAS,EAC0E;IACtF,MAAM,EAAE,WAAW,EAAE,oBAAoB,EAAE,GAAG,IAAA,uDAA4B,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;IACzF,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,IAAA,8BAAY,GAAE,CAAC;IAC5D,MAAM,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IAElC,MAAM,OAAO,GAAc,aAAa;QACtC,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,uBAAC,gBAAQ,cAAc,GAAG,CAAC,EAAE,GAAG,WAAW,EAAE,aAAa,EAAE,CAAC,IAA9C,KAAK,CAAqD,CAAC;QAC9G,CAAC,CAAC;YACE,2BAAC,wCAAa,OAAK,WAAW,EAAE,GAAG,EAAC,cAAc,EAAC,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,GAAI;YACrG,2BAAC,wCAAa,OAAK,WAAW,EAAE,GAAG,EAAC,cAAc,EAAC,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,GAAI;YACrG,2BAAC,0CAAe,OAAK,WAAW,EAAE,GAAG,EAAC,gBAAgB,EAAC,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,GAAI;SAC1G,CAAC;IAEN,OAAO,CACL,uBAAC,iDAAwB,IAAC,mBAAmB,EAAE,+BAAuB,CAAC,EAAE,EAAE,aAAa,EAAE,aAAa,EAAE,qBAAqB,EAAE,qBAAqB,YACnJ,uBAAC,kCAAc,IACb,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,OAAO,EAChB,cAAc,EAAE;gBACd,aAAa,EAAE,WAAW;gBAC1B,aAAa,EAAE,WAAW;aAC3B,YAED,uBAAC,kCAAc,OAAK,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,oBAAoB,EAAE,oBAAoB,GAAI,GACpH,GACQ,CAC5B,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 { Fragment } from \"react\";\nimport { useActiveIModelConnection } from \"@itwin/appui-react\";\nimport { TreeWidget } from \"../../../TreeWidget.js\";\nimport { TreeWithHeader } from \"../../tree-header/TreeWithHeader.js\";\nimport { useActiveViewport } from \"../common/UseActiveViewport.js\";\nimport { useFiltering } from \"../common/UseFiltering.js\";\nimport { TelemetryContextProvider } from \"../common/UseTelemetryContext.js\";\nimport { CategoriesTree } from \"./CategoriesTree.js\";\nimport { HideAllButton, InvertAllButton, ShowAllButton, useCategoriesTreeButtonProps } from \"./CategoriesTreeButtons.js\";\n\nimport type { CategoriesTreeProps } from \"./CategoriesTree.js\";\nimport type { ReactNode } from \"react\";\nimport type { IModelConnection, ScreenViewport } from \"@itwin/core-frontend\";\nimport type { CategoriesTreeHeaderButtonProps, CategoriesTreeHeaderButtonType } from \"./CategoriesTreeButtons.js\";\n\n/** @public */\ninterface CategoriesTreeComponentProps\n extends Pick<CategoriesTreeProps, \"getSchemaContext\" | \"selectionStorage\" | \"density\" | \"hierarchyLevelConfig\" | \"selectionMode\"> {\n /**\n * Renderers of header buttons. Defaults to:\n * ```ts\n * [\n * CategoriesTreeComponent.ShowAllButton,\n * CategoriesTreeComponent.HideAllButton,\n * CategoriesTreeComponent.InvertAllButton,\n * ]\n * ```\n */\n headerButtons?: Array<(props: CategoriesTreeHeaderButtonProps) => React.ReactNode>;\n onPerformanceMeasured?: (featureId: string, duration: number) => void;\n onFeatureUsed?: (feature: string) => void;\n}\n\n/**\n * A component that renders `CategoriesTree` and a header with filtering capabilities and header buttons.\n * @public\n */\nexport const CategoriesTreeComponent = (props: CategoriesTreeComponentProps) => {\n const iModel = useActiveIModelConnection();\n const viewport = useActiveViewport();\n\n if (!iModel || !viewport) {\n return null;\n }\n\n return <CategoriesTreeComponentImpl {...props} iModel={iModel} viewport={viewport} />;\n};\n\n/**\n * Renders a \"Show all\" button that enables display of all categories and their subcategories.\n * @public\n */\nCategoriesTreeComponent.ShowAllButton = ShowAllButton as CategoriesTreeHeaderButtonType;\n\n/**\n * Renders a \"Hide all\" button that disables display of all categories.\n * @public\n */\nCategoriesTreeComponent.HideAllButton = HideAllButton as CategoriesTreeHeaderButtonType;\n\n/**\n * Renders an \"Invert all\" button that inverts display of all categories.\n * @public\n */\nCategoriesTreeComponent.InvertAllButton = InvertAllButton as CategoriesTreeHeaderButtonType;\n\n/**\n * Id of the component. May be used when a creating a `TreeDefinition` for `SelectableTree`.\n * @public\n */\nCategoriesTreeComponent.id = \"categories-tree-v2\";\n\n/**\n * Label of the component. May be used when a creating a `TreeDefinition` for `SelectableTree`.\n * @public\n */\nCategoriesTreeComponent.getLabel = () => TreeWidget.translate(\"categoriesTree.label\");\n\nfunction CategoriesTreeComponentImpl({\n iModel,\n viewport,\n headerButtons,\n onPerformanceMeasured,\n onFeatureUsed,\n ...treeProps\n}: CategoriesTreeComponentProps & { iModel: IModelConnection; viewport: ScreenViewport }) {\n const { buttonProps, onCategoriesFiltered } = useCategoriesTreeButtonProps({ viewport });\n const { filter, applyFilter, clearFilter } = useFiltering();\n const density = treeProps.density;\n\n const buttons: ReactNode = headerButtons\n ? headerButtons.map((btn, index) => <Fragment key={index}>{btn({ ...buttonProps, onFeatureUsed })}</Fragment>)\n : [\n <ShowAllButton {...buttonProps} key=\"show-all-btn\" density={density} onFeatureUsed={onFeatureUsed} />,\n <HideAllButton {...buttonProps} key=\"hide-all-btn\" density={density} onFeatureUsed={onFeatureUsed} />,\n <InvertAllButton {...buttonProps} key=\"invert-all-btn\" density={density} onFeatureUsed={onFeatureUsed} />,\n ];\n\n return (\n <TelemetryContextProvider componentIdentifier={CategoriesTreeComponent.id} onFeatureUsed={onFeatureUsed} onPerformanceMeasured={onPerformanceMeasured}>\n <TreeWithHeader\n buttons={buttons}\n density={density}\n filteringProps={{\n onFilterStart: applyFilter,\n onFilterClear: clearFilter,\n }}\n >\n <CategoriesTree {...treeProps} imodel={iModel} activeView={viewport} filter={filter} onCategoriesFiltered={onCategoriesFiltered} />\n </TreeWithHeader>\n </TelemetryContextProvider>\n );\n}\n"]}
@@ -1,23 +0,0 @@
1
- import type { ECClassHierarchyInspector, ECSchemaProvider } from "@itwin/presentation-shared";
2
- import type { DefineHierarchyLevelProps, HierarchyDefinition, HierarchyFilteringPath, HierarchyLevelDefinition, LimitingECSqlQueryExecutor } from "@itwin/presentation-hierarchies";
3
- interface CategoriesTreeDefinitionProps {
4
- imodelAccess: ECSchemaProvider & ECClassHierarchyInspector;
5
- viewType: "2d" | "3d";
6
- }
7
- interface CategoriesTreeInstanceKeyPathsFromInstanceLabelProps {
8
- imodelAccess: ECClassHierarchyInspector & LimitingECSqlQueryExecutor;
9
- label: string;
10
- viewType: "2d" | "3d";
11
- }
12
- export declare class CategoriesTreeDefinition implements HierarchyDefinition {
13
- private _impl;
14
- private _selectQueryFactory;
15
- private _nodeLabelSelectClauseFactory;
16
- constructor(props: CategoriesTreeDefinitionProps);
17
- defineHierarchyLevel(props: DefineHierarchyLevelProps): Promise<HierarchyLevelDefinition>;
18
- private createRootHierarchyLevelDefinition;
19
- private createSubcategoryQuery;
20
- static createInstanceKeyPaths(props: CategoriesTreeInstanceKeyPathsFromInstanceLabelProps): Promise<HierarchyFilteringPath[]>;
21
- }
22
- export {};
23
- //# sourceMappingURL=CategoriesTreeDefinition.d.ts.map
@@ -1,207 +0,0 @@
1
- "use strict";
2
- /*---------------------------------------------------------------------------------------------
3
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
- * See LICENSE.md in the project root for license terms and full copyright notice.
5
- *--------------------------------------------------------------------------------------------*/
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.CategoriesTreeDefinition = void 0;
8
- const presentation_hierarchies_1 = require("@itwin/presentation-hierarchies");
9
- const presentation_shared_1 = require("@itwin/presentation-shared");
10
- const TreeErrors_js_1 = require("../common/TreeErrors.js");
11
- const MAX_FILTERING_INSTANCE_KEY_COUNT = 100;
12
- class CategoriesTreeDefinition {
13
- constructor(props) {
14
- this._impl = (0, presentation_hierarchies_1.createPredicateBasedHierarchyDefinition)({
15
- classHierarchyInspector: props.imodelAccess,
16
- hierarchy: {
17
- rootNodes: async (requestProps) => this.createRootHierarchyLevelDefinition({ ...requestProps, viewType: props.viewType }),
18
- childNodes: [
19
- {
20
- parentInstancesNodePredicate: "BisCore.Category",
21
- definitions: async (requestProps) => this.createSubcategoryQuery(requestProps),
22
- },
23
- ],
24
- },
25
- });
26
- this._nodeLabelSelectClauseFactory = (0, presentation_shared_1.createBisInstanceLabelSelectClauseFactory)({ classHierarchyInspector: props.imodelAccess });
27
- this._selectQueryFactory = (0, presentation_hierarchies_1.createNodesQueryClauseFactory)({
28
- imodelAccess: props.imodelAccess,
29
- instanceLabelSelectClauseFactory: this._nodeLabelSelectClauseFactory,
30
- });
31
- }
32
- async defineHierarchyLevel(props) {
33
- return this._impl.defineHierarchyLevel(props);
34
- }
35
- async createRootHierarchyLevelDefinition(props) {
36
- const { categoryClass, categoryElementClass } = getClassesByView(props.viewType);
37
- const instanceFilterClauses = await this._selectQueryFactory.createFilterClauses({
38
- filter: props.instanceFilter,
39
- contentClass: { fullName: categoryClass, alias: "this" },
40
- });
41
- return [
42
- {
43
- fullClassName: categoryClass,
44
- query: {
45
- ecsql: `
46
- SELECT
47
- ${await this._selectQueryFactory.createSelectClause({
48
- ecClassId: { selector: presentation_shared_1.ECSql.createRawPropertyValueSelector("this", "ECClassId") },
49
- ecInstanceId: { selector: "this.ECInstanceId" },
50
- nodeLabel: {
51
- selector: await this._nodeLabelSelectClauseFactory.createSelectClause({
52
- classAlias: "this",
53
- className: categoryClass,
54
- }),
55
- },
56
- hasChildren: {
57
- selector: `
58
- IFNULL((
59
- SELECT 1
60
- FROM (
61
- SELECT COUNT(1) AS ChildCount
62
- FROM BisCore.SubCategory sc
63
- WHERE sc.Parent.Id = this.ECInstanceId
64
- )
65
- WHERE ChildCount > 1
66
- ), 0)
67
- `,
68
- },
69
- extendedData: {
70
- description: { selector: "this.Description" },
71
- },
72
- supportsFiltering: true,
73
- })}
74
- FROM ${instanceFilterClauses.from} this
75
- ${instanceFilterClauses.joins}
76
- JOIN BisCore.Model m ON m.ECInstanceId = this.Model.Id
77
- WHERE
78
- NOT this.IsPrivate
79
- AND (NOT m.IsPrivate OR m.ECClassId IS (BisCore.DictionaryModel))
80
- AND EXISTS (SELECT 1 FROM ${categoryElementClass} e WHERE e.Category.Id = this.ECInstanceId)
81
- ${instanceFilterClauses.where ? `AND ${instanceFilterClauses.where}` : ""}
82
- `,
83
- },
84
- },
85
- ];
86
- }
87
- async createSubcategoryQuery({ parentNodeInstanceIds: elementIds, instanceFilter, }) {
88
- const instanceFilterClauses = await this._selectQueryFactory.createFilterClauses({
89
- filter: instanceFilter,
90
- contentClass: { fullName: "BisCore.SubCategory", alias: "this" },
91
- });
92
- return [
93
- {
94
- fullClassName: "BisCore.SubCategory",
95
- query: {
96
- ecsql: `
97
- SELECT
98
- ${await this._selectQueryFactory.createSelectClause({
99
- ecClassId: { selector: "this.ECClassId" },
100
- ecInstanceId: { selector: "this.ECInstanceId" },
101
- nodeLabel: {
102
- selector: await this._nodeLabelSelectClauseFactory.createSelectClause({
103
- classAlias: "this",
104
- className: "BisCore.SubCategory",
105
- }),
106
- },
107
- extendedData: {
108
- categoryId: { selector: "printf('0x%x', this.Parent.Id)" },
109
- },
110
- supportsFiltering: false,
111
- })}
112
- FROM ${instanceFilterClauses.from} this
113
- ${instanceFilterClauses.joins}
114
- WHERE
115
- NOT this.IsPrivate AND this.Parent.Id IN (${elementIds.map(() => "?").join(",")})
116
- ${instanceFilterClauses.where ? `AND ${instanceFilterClauses.where}` : ""}
117
- `,
118
- bindings: elementIds.map((id) => ({ type: "id", value: id })),
119
- },
120
- },
121
- ];
122
- }
123
- static async createInstanceKeyPaths(props) {
124
- const labelsFactory = (0, presentation_shared_1.createBisInstanceLabelSelectClauseFactory)({ classHierarchyInspector: props.imodelAccess });
125
- return createInstanceKeyPathsFromInstanceLabel({ ...props, labelsFactory });
126
- }
127
- }
128
- exports.CategoriesTreeDefinition = CategoriesTreeDefinition;
129
- function getClassesByView(viewType) {
130
- return viewType === "2d"
131
- ? { categoryClass: "BisCore.DrawingCategory", categoryElementClass: "BisCore:GeometricElement2d" }
132
- : { categoryClass: "BisCore.SpatialCategory", categoryElementClass: "BisCore:GeometricElement3d" };
133
- }
134
- async function createInstanceKeyPathsFromInstanceLabel(props) {
135
- const { categoryClass, categoryElementClass } = getClassesByView(props.viewType);
136
- const adjustedLabel = props.label.replace(/[%_\\]/g, "\\$&");
137
- const reader = props.imodelAccess.createQueryReader({
138
- ctes: [
139
- `RootCategoriesWithLabels(ClassName, ECInstanceId, ChildCount, DisplayLabel) as (
140
- SELECT
141
- ec_classname(this.ECClassId, 's.c'),
142
- this.ECInstanceId,
143
- COUNT(sc.ECInstanceId),
144
- ${await props.labelsFactory.createSelectClause({
145
- classAlias: "this",
146
- className: categoryClass,
147
- })}
148
- FROM ${categoryClass} this
149
- JOIN BisCore.Model m ON m.ECInstanceId = this.Model.Id
150
- JOIN BisCore.SubCategory sc ON sc.Parent.Id = this.ECInstanceId
151
- WHERE
152
- NOT this.IsPrivate
153
- AND (NOT m.IsPrivate OR m.ECClassId IS (BisCore.DictionaryModel))
154
- AND EXISTS (SELECT 1 FROM ${categoryElementClass} e WHERE e.Category.Id = this.ECInstanceId)
155
- GROUP BY this.ECInstanceId
156
- )`,
157
- `SubCategoriesWithLabels(ClassName, ECInstanceId, ParentId, DisplayLabel) as (
158
- SELECT
159
- ec_classname(this.ECClassId, 's.c'),
160
- this.ECInstanceId,
161
- this.Parent.Id,
162
- ${await props.labelsFactory.createSelectClause({
163
- classAlias: "this",
164
- className: "BisCore.SubCategory",
165
- })}
166
- FROM BisCore.SubCategory this
167
- WHERE NOT this.IsPrivate
168
- )`,
169
- ],
170
- ecsql: `
171
- SELECT * FROM (
172
- SELECT
173
- c.ClassName AS CategoryClass,
174
- c.ECInstanceId AS CategoryId,
175
- sc.ClassName AS SubcategoryClass,
176
- sc.ECInstanceId AS SubcategoryId
177
- FROM RootCategoriesWithLabels c
178
- JOIN SubCategoriesWithLabels sc ON sc.ParentId = c.ECInstanceId
179
- WHERE c.ChildCount > 1 AND sc.DisplayLabel LIKE '%' || ? || '%' ESCAPE '\\'
180
- UNION ALL
181
- SELECT
182
- c.ClassName AS CategoryClass,
183
- c.ECInstanceId AS CategoryId,
184
- CAST(NULL AS TEXT) AS SubcategoryClass,
185
- CAST(NULL AS TEXT) AS SubcategoryId
186
- FROM RootCategoriesWithLabels c
187
- WHERE c.DisplayLabel LIKE '%' || ? || '%' ESCAPE '\\'
188
- )
189
- LIMIT ${MAX_FILTERING_INSTANCE_KEY_COUNT + 1}
190
- `,
191
- bindings: [
192
- { type: "string", value: adjustedLabel },
193
- { type: "string", value: adjustedLabel },
194
- ],
195
- }, { restartToken: "tree-widget/categories-tree/filter-by-label-query" });
196
- const paths = [];
197
- for await (const row of reader) {
198
- const path = { path: [{ className: row.CategoryClass, id: row.CategoryId }], options: { autoExpand: true } };
199
- row.SubcategoryId && path.path.push({ className: row.SubcategoryClass, id: row.SubcategoryId });
200
- paths.push(path);
201
- }
202
- if (paths.length > MAX_FILTERING_INSTANCE_KEY_COUNT) {
203
- throw new TreeErrors_js_1.FilterLimitExceededError(MAX_FILTERING_INSTANCE_KEY_COUNT);
204
- }
205
- return paths;
206
- }
207
- //# sourceMappingURL=CategoriesTreeDefinition.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CategoriesTreeDefinition.js","sourceRoot":"","sources":["../../../../../../src/tree-widget-react/components/trees/categories-tree/CategoriesTreeDefinition.ts"],"names":[],"mappings":"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","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 { createNodesQueryClauseFactory, createPredicateBasedHierarchyDefinition } from \"@itwin/presentation-hierarchies\";\nimport { createBisInstanceLabelSelectClauseFactory, ECSql } from \"@itwin/presentation-shared\";\nimport { FilterLimitExceededError } from \"../common/TreeErrors.js\";\n\nimport type { ECClassHierarchyInspector, ECSchemaProvider, IInstanceLabelSelectClauseFactory } from \"@itwin/presentation-shared\";\nimport type {\n DefineHierarchyLevelProps,\n DefineInstanceNodeChildHierarchyLevelProps,\n DefineRootHierarchyLevelProps,\n HierarchyDefinition,\n HierarchyFilteringPath,\n HierarchyLevelDefinition,\n LimitingECSqlQueryExecutor,\n NodesQueryClauseFactory,\n} from \"@itwin/presentation-hierarchies\";\n\nconst MAX_FILTERING_INSTANCE_KEY_COUNT = 100;\n\ninterface CategoriesTreeDefinitionProps {\n imodelAccess: ECSchemaProvider & ECClassHierarchyInspector;\n viewType: \"2d\" | \"3d\";\n}\n\ninterface CategoriesTreeInstanceKeyPathsFromInstanceLabelProps {\n imodelAccess: ECClassHierarchyInspector & LimitingECSqlQueryExecutor;\n label: string;\n viewType: \"2d\" | \"3d\";\n}\n\nexport class CategoriesTreeDefinition implements HierarchyDefinition {\n private _impl: HierarchyDefinition;\n private _selectQueryFactory: NodesQueryClauseFactory;\n private _nodeLabelSelectClauseFactory: IInstanceLabelSelectClauseFactory;\n\n public constructor(props: CategoriesTreeDefinitionProps) {\n this._impl = createPredicateBasedHierarchyDefinition({\n classHierarchyInspector: props.imodelAccess,\n hierarchy: {\n rootNodes: async (requestProps) => this.createRootHierarchyLevelDefinition({ ...requestProps, viewType: props.viewType }),\n childNodes: [\n {\n parentInstancesNodePredicate: \"BisCore.Category\",\n definitions: async (requestProps: DefineInstanceNodeChildHierarchyLevelProps) => this.createSubcategoryQuery(requestProps),\n },\n ],\n },\n });\n this._nodeLabelSelectClauseFactory = createBisInstanceLabelSelectClauseFactory({ classHierarchyInspector: props.imodelAccess });\n this._selectQueryFactory = createNodesQueryClauseFactory({\n imodelAccess: props.imodelAccess,\n instanceLabelSelectClauseFactory: this._nodeLabelSelectClauseFactory,\n });\n }\n\n public async defineHierarchyLevel(props: DefineHierarchyLevelProps) {\n return this._impl.defineHierarchyLevel(props);\n }\n\n private async createRootHierarchyLevelDefinition(props: DefineRootHierarchyLevelProps & { viewType: \"2d\" | \"3d\" }): Promise<HierarchyLevelDefinition> {\n const { categoryClass, categoryElementClass } = getClassesByView(props.viewType);\n const instanceFilterClauses = await this._selectQueryFactory.createFilterClauses({\n filter: props.instanceFilter,\n contentClass: { fullName: categoryClass, alias: \"this\" },\n });\n return [\n {\n fullClassName: categoryClass,\n query: {\n ecsql: `\n SELECT\n ${await this._selectQueryFactory.createSelectClause({\n ecClassId: { selector: ECSql.createRawPropertyValueSelector(\"this\", \"ECClassId\") },\n ecInstanceId: { selector: \"this.ECInstanceId\" },\n nodeLabel: {\n selector: await this._nodeLabelSelectClauseFactory.createSelectClause({\n classAlias: \"this\",\n className: categoryClass,\n }),\n },\n hasChildren: {\n selector: `\n IFNULL((\n SELECT 1\n FROM (\n SELECT COUNT(1) AS ChildCount\n FROM BisCore.SubCategory sc\n WHERE sc.Parent.Id = this.ECInstanceId\n )\n WHERE ChildCount > 1\n ), 0)\n `,\n },\n extendedData: {\n description: { selector: \"this.Description\" },\n },\n supportsFiltering: true,\n })}\n FROM ${instanceFilterClauses.from} this\n ${instanceFilterClauses.joins}\n JOIN BisCore.Model m ON m.ECInstanceId = this.Model.Id\n WHERE\n NOT this.IsPrivate\n AND (NOT m.IsPrivate OR m.ECClassId IS (BisCore.DictionaryModel))\n AND EXISTS (SELECT 1 FROM ${categoryElementClass} e WHERE e.Category.Id = this.ECInstanceId)\n ${instanceFilterClauses.where ? `AND ${instanceFilterClauses.where}` : \"\"}\n `,\n },\n },\n ];\n }\n\n private async createSubcategoryQuery({\n parentNodeInstanceIds: elementIds,\n instanceFilter,\n }: DefineInstanceNodeChildHierarchyLevelProps): Promise<HierarchyLevelDefinition> {\n const instanceFilterClauses = await this._selectQueryFactory.createFilterClauses({\n filter: instanceFilter,\n contentClass: { fullName: \"BisCore.SubCategory\", alias: \"this\" },\n });\n return [\n {\n fullClassName: \"BisCore.SubCategory\",\n query: {\n ecsql: `\n SELECT\n ${await this._selectQueryFactory.createSelectClause({\n ecClassId: { selector: \"this.ECClassId\" },\n ecInstanceId: { selector: \"this.ECInstanceId\" },\n nodeLabel: {\n selector: await this._nodeLabelSelectClauseFactory.createSelectClause({\n classAlias: \"this\",\n className: \"BisCore.SubCategory\",\n }),\n },\n extendedData: {\n categoryId: { selector: \"printf('0x%x', this.Parent.Id)\" },\n },\n supportsFiltering: false,\n })}\n FROM ${instanceFilterClauses.from} this\n ${instanceFilterClauses.joins}\n WHERE\n NOT this.IsPrivate AND this.Parent.Id IN (${elementIds.map(() => \"?\").join(\",\")})\n ${instanceFilterClauses.where ? `AND ${instanceFilterClauses.where}` : \"\"}\n `,\n bindings: elementIds.map((id) => ({ type: \"id\", value: id })),\n },\n },\n ];\n }\n\n public static async createInstanceKeyPaths(props: CategoriesTreeInstanceKeyPathsFromInstanceLabelProps) {\n const labelsFactory = createBisInstanceLabelSelectClauseFactory({ classHierarchyInspector: props.imodelAccess });\n return createInstanceKeyPathsFromInstanceLabel({ ...props, labelsFactory });\n }\n}\n\nfunction getClassesByView(viewType: \"2d\" | \"3d\") {\n return viewType === \"2d\"\n ? { categoryClass: \"BisCore.DrawingCategory\", categoryElementClass: \"BisCore:GeometricElement2d\" }\n : { categoryClass: \"BisCore.SpatialCategory\", categoryElementClass: \"BisCore:GeometricElement3d\" };\n}\n\nasync function createInstanceKeyPathsFromInstanceLabel(\n props: CategoriesTreeInstanceKeyPathsFromInstanceLabelProps & { labelsFactory: IInstanceLabelSelectClauseFactory },\n) {\n const { categoryClass, categoryElementClass } = getClassesByView(props.viewType);\n const adjustedLabel = props.label.replace(/[%_\\\\]/g, \"\\\\$&\");\n const reader = props.imodelAccess.createQueryReader(\n {\n ctes: [\n `RootCategoriesWithLabels(ClassName, ECInstanceId, ChildCount, DisplayLabel) as (\n SELECT\n ec_classname(this.ECClassId, 's.c'),\n this.ECInstanceId,\n COUNT(sc.ECInstanceId),\n ${await props.labelsFactory.createSelectClause({\n classAlias: \"this\",\n className: categoryClass,\n })}\n FROM ${categoryClass} this\n JOIN BisCore.Model m ON m.ECInstanceId = this.Model.Id\n JOIN BisCore.SubCategory sc ON sc.Parent.Id = this.ECInstanceId\n WHERE\n NOT this.IsPrivate\n AND (NOT m.IsPrivate OR m.ECClassId IS (BisCore.DictionaryModel))\n AND EXISTS (SELECT 1 FROM ${categoryElementClass} e WHERE e.Category.Id = this.ECInstanceId)\n GROUP BY this.ECInstanceId\n )`,\n `SubCategoriesWithLabels(ClassName, ECInstanceId, ParentId, DisplayLabel) as (\n SELECT\n ec_classname(this.ECClassId, 's.c'),\n this.ECInstanceId,\n this.Parent.Id,\n ${await props.labelsFactory.createSelectClause({\n classAlias: \"this\",\n className: \"BisCore.SubCategory\",\n })}\n FROM BisCore.SubCategory this\n WHERE NOT this.IsPrivate\n )`,\n ],\n ecsql: `\n SELECT * FROM (\n SELECT\n c.ClassName AS CategoryClass,\n c.ECInstanceId AS CategoryId,\n sc.ClassName AS SubcategoryClass,\n sc.ECInstanceId AS SubcategoryId\n FROM RootCategoriesWithLabels c\n JOIN SubCategoriesWithLabels sc ON sc.ParentId = c.ECInstanceId\n WHERE c.ChildCount > 1 AND sc.DisplayLabel LIKE '%' || ? || '%' ESCAPE '\\\\'\n UNION ALL\n SELECT\n c.ClassName AS CategoryClass,\n c.ECInstanceId AS CategoryId,\n CAST(NULL AS TEXT) AS SubcategoryClass,\n CAST(NULL AS TEXT) AS SubcategoryId\n FROM RootCategoriesWithLabels c\n WHERE c.DisplayLabel LIKE '%' || ? || '%' ESCAPE '\\\\'\n )\n LIMIT ${MAX_FILTERING_INSTANCE_KEY_COUNT + 1}\n `,\n bindings: [\n { type: \"string\", value: adjustedLabel },\n { type: \"string\", value: adjustedLabel },\n ],\n },\n { restartToken: \"tree-widget/categories-tree/filter-by-label-query\" },\n );\n const paths: HierarchyFilteringPath[] = [];\n for await (const row of reader) {\n const path = { path: [{ className: row.CategoryClass, id: row.CategoryId }], options: { autoExpand: true } };\n row.SubcategoryId && path.path.push({ className: row.SubcategoryClass, id: row.SubcategoryId });\n paths.push(path);\n }\n if (paths.length > MAX_FILTERING_INSTANCE_KEY_COUNT) {\n throw new FilterLimitExceededError(MAX_FILTERING_INSTANCE_KEY_COUNT);\n }\n return paths;\n}\n"]}