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

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 (134) hide show
  1. package/README.md +95 -6
  2. package/lib/cjs/components/tree-header/TreeHeader.d.ts +10 -8
  3. package/lib/cjs/components/tree-header/TreeHeader.js +4 -6
  4. package/lib/cjs/components/tree-header/TreeHeader.js.map +1 -1
  5. package/lib/cjs/components/tree-header/TreeWithHeader.d.ts +13 -0
  6. package/lib/cjs/components/tree-header/TreeWithHeader.js +20 -0
  7. package/lib/cjs/components/tree-header/TreeWithHeader.js.map +1 -0
  8. package/lib/cjs/components/trees/categories-tree/CategoriesTree.d.ts +3 -7
  9. package/lib/cjs/components/trees/categories-tree/CategoriesTree.js +7 -63
  10. package/lib/cjs/components/trees/categories-tree/CategoriesTree.js.map +1 -1
  11. package/lib/cjs/components/trees/categories-tree/CategoriesTreeButtons.d.ts +9 -2
  12. package/lib/cjs/components/trees/categories-tree/CategoriesTreeButtons.js +24 -4
  13. package/lib/cjs/components/trees/categories-tree/CategoriesTreeButtons.js.map +1 -1
  14. package/lib/cjs/components/trees/categories-tree/CategoriesTreeComponent.d.ts +0 -1
  15. package/lib/cjs/components/trees/categories-tree/CategoriesTreeComponent.js +15 -18
  16. package/lib/cjs/components/trees/categories-tree/CategoriesTreeComponent.js.map +1 -1
  17. package/lib/cjs/components/trees/categories-tree/CategoriesVisibilityHandler.d.ts +1 -9
  18. package/lib/cjs/components/trees/categories-tree/CategoriesVisibilityHandler.js +2 -6
  19. package/lib/cjs/components/trees/categories-tree/CategoriesVisibilityHandler.js.map +1 -1
  20. package/lib/cjs/components/trees/categories-tree/UseCategoriesTree.d.ts +25 -0
  21. package/lib/cjs/components/trees/categories-tree/UseCategoriesTree.js +89 -0
  22. package/lib/cjs/components/trees/categories-tree/UseCategoriesTree.js.map +1 -0
  23. package/lib/cjs/components/trees/common/CategoriesVisibilityUtils.d.ts +6 -6
  24. package/lib/cjs/components/trees/common/CategoriesVisibilityUtils.js +32 -78
  25. package/lib/cjs/components/trees/common/CategoriesVisibilityUtils.js.map +1 -1
  26. package/lib/cjs/components/trees/common/UseTelemetryContext.d.ts +1 -1
  27. package/lib/cjs/components/trees/common/UseTelemetryContext.js.map +1 -1
  28. package/lib/cjs/components/trees/common/components/Tree.d.ts +0 -2
  29. package/lib/cjs/components/trees/common/components/Tree.js +5 -4
  30. package/lib/cjs/components/trees/common/components/Tree.js.map +1 -1
  31. package/lib/cjs/components/trees/common/components/VisibilityTree.d.ts +2 -3
  32. package/lib/cjs/components/trees/common/components/VisibilityTree.js.map +1 -1
  33. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTree.d.ts +1 -1
  34. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTree.js.map +1 -1
  35. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js +1 -2
  36. package/lib/cjs/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js.map +1 -1
  37. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTree.d.ts +1 -1
  38. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTree.js.map +1 -1
  39. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTreeComponent.js +1 -2
  40. package/lib/cjs/components/trees/imodel-content-tree/IModelContentTreeComponent.js.map +1 -1
  41. package/lib/cjs/components/trees/index.d.ts +4 -0
  42. package/lib/cjs/components/trees/index.js +9 -1
  43. package/lib/cjs/components/trees/index.js.map +1 -1
  44. package/lib/cjs/components/trees/models-tree/ModelsTree.d.ts +4 -4
  45. package/lib/cjs/components/trees/models-tree/ModelsTree.js +4 -203
  46. package/lib/cjs/components/trees/models-tree/ModelsTree.js.map +1 -1
  47. package/lib/cjs/components/trees/models-tree/ModelsTreeButtons.d.ts +9 -3
  48. package/lib/cjs/components/trees/models-tree/ModelsTreeButtons.js +13 -3
  49. package/lib/cjs/components/trees/models-tree/ModelsTreeButtons.js.map +1 -1
  50. package/lib/cjs/components/trees/models-tree/ModelsTreeComponent.d.ts +0 -1
  51. package/lib/cjs/components/trees/models-tree/ModelsTreeComponent.js +27 -20
  52. package/lib/cjs/components/trees/models-tree/ModelsTreeComponent.js.map +1 -1
  53. package/lib/cjs/components/trees/models-tree/UseModelsTree.d.ts +29 -0
  54. package/lib/cjs/components/trees/models-tree/UseModelsTree.js +233 -0
  55. package/lib/cjs/components/trees/models-tree/UseModelsTree.js.map +1 -0
  56. package/lib/cjs/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js +1 -1
  57. package/lib/cjs/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js.map +1 -1
  58. package/lib/cjs/tree-widget-react.d.ts +1 -0
  59. package/lib/cjs/tree-widget-react.js +3 -1
  60. package/lib/cjs/tree-widget-react.js.map +1 -1
  61. package/lib/esm/components/tree-header/TreeHeader.d.ts +10 -8
  62. package/lib/esm/components/tree-header/TreeHeader.js +4 -6
  63. package/lib/esm/components/tree-header/TreeHeader.js.map +1 -1
  64. package/lib/esm/components/tree-header/TreeWithHeader.d.ts +13 -0
  65. package/lib/esm/components/tree-header/TreeWithHeader.js +13 -0
  66. package/lib/esm/components/tree-header/TreeWithHeader.js.map +1 -0
  67. package/lib/esm/components/trees/categories-tree/CategoriesTree.d.ts +3 -7
  68. package/lib/esm/components/trees/categories-tree/CategoriesTree.js +7 -63
  69. package/lib/esm/components/trees/categories-tree/CategoriesTree.js.map +1 -1
  70. package/lib/esm/components/trees/categories-tree/CategoriesTreeButtons.d.ts +9 -2
  71. package/lib/esm/components/trees/categories-tree/CategoriesTreeButtons.js +22 -4
  72. package/lib/esm/components/trees/categories-tree/CategoriesTreeButtons.js.map +1 -1
  73. package/lib/esm/components/trees/categories-tree/CategoriesTreeComponent.d.ts +0 -1
  74. package/lib/esm/components/trees/categories-tree/CategoriesTreeComponent.js +16 -16
  75. package/lib/esm/components/trees/categories-tree/CategoriesTreeComponent.js.map +1 -1
  76. package/lib/esm/components/trees/categories-tree/CategoriesVisibilityHandler.d.ts +1 -9
  77. package/lib/esm/components/trees/categories-tree/CategoriesVisibilityHandler.js +2 -6
  78. package/lib/esm/components/trees/categories-tree/CategoriesVisibilityHandler.js.map +1 -1
  79. package/lib/esm/components/trees/categories-tree/UseCategoriesTree.d.ts +25 -0
  80. package/lib/esm/components/trees/categories-tree/UseCategoriesTree.js +85 -0
  81. package/lib/esm/components/trees/categories-tree/UseCategoriesTree.js.map +1 -0
  82. package/lib/esm/components/trees/common/CategoriesVisibilityUtils.d.ts +6 -6
  83. package/lib/esm/components/trees/common/CategoriesVisibilityUtils.js +33 -79
  84. package/lib/esm/components/trees/common/CategoriesVisibilityUtils.js.map +1 -1
  85. package/lib/esm/components/trees/common/UseTelemetryContext.d.ts +1 -1
  86. package/lib/esm/components/trees/common/UseTelemetryContext.js.map +1 -1
  87. package/lib/esm/components/trees/common/components/Tree.d.ts +0 -2
  88. package/lib/esm/components/trees/common/components/Tree.js +5 -4
  89. package/lib/esm/components/trees/common/components/Tree.js.map +1 -1
  90. package/lib/esm/components/trees/common/components/VisibilityTree.d.ts +2 -3
  91. package/lib/esm/components/trees/common/components/VisibilityTree.js.map +1 -1
  92. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTree.d.ts +1 -1
  93. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTree.js.map +1 -1
  94. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js +1 -2
  95. package/lib/esm/components/trees/external-sources-tree/ExternalSourcesTreeComponent.js.map +1 -1
  96. package/lib/esm/components/trees/imodel-content-tree/IModelContentTree.d.ts +1 -1
  97. package/lib/esm/components/trees/imodel-content-tree/IModelContentTree.js.map +1 -1
  98. package/lib/esm/components/trees/imodel-content-tree/IModelContentTreeComponent.js +1 -2
  99. package/lib/esm/components/trees/imodel-content-tree/IModelContentTreeComponent.js.map +1 -1
  100. package/lib/esm/components/trees/index.d.ts +4 -0
  101. package/lib/esm/components/trees/index.js +4 -0
  102. package/lib/esm/components/trees/index.js.map +1 -1
  103. package/lib/esm/components/trees/models-tree/ModelsTree.d.ts +4 -4
  104. package/lib/esm/components/trees/models-tree/ModelsTree.js +5 -204
  105. package/lib/esm/components/trees/models-tree/ModelsTree.js.map +1 -1
  106. package/lib/esm/components/trees/models-tree/ModelsTreeButtons.d.ts +9 -3
  107. package/lib/esm/components/trees/models-tree/ModelsTreeButtons.js +12 -2
  108. package/lib/esm/components/trees/models-tree/ModelsTreeButtons.js.map +1 -1
  109. package/lib/esm/components/trees/models-tree/ModelsTreeComponent.d.ts +0 -1
  110. package/lib/esm/components/trees/models-tree/ModelsTreeComponent.js +29 -19
  111. package/lib/esm/components/trees/models-tree/ModelsTreeComponent.js.map +1 -1
  112. package/lib/esm/components/trees/models-tree/UseModelsTree.d.ts +29 -0
  113. package/lib/esm/components/trees/models-tree/UseModelsTree.js +229 -0
  114. package/lib/esm/components/trees/models-tree/UseModelsTree.js.map +1 -0
  115. package/lib/esm/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js +2 -2
  116. package/lib/esm/components/trees/models-tree/internal/ModelsTreeVisibilityHandler.js.map +1 -1
  117. package/lib/esm/tree-widget-react.d.ts +1 -0
  118. package/lib/esm/tree-widget-react.js +1 -0
  119. package/lib/esm/tree-widget-react.js.map +1 -1
  120. package/package.json +11 -15
  121. package/lib/cjs/components/trees/categories-tree/UseCategories.d.ts +0 -8
  122. package/lib/cjs/components/trees/categories-tree/UseCategories.js +0 -22
  123. package/lib/cjs/components/trees/categories-tree/UseCategories.js.map +0 -1
  124. package/lib/cjs/components/utils/AutoSizer.d.ts +0 -13
  125. package/lib/cjs/components/utils/AutoSizer.js +0 -21
  126. package/lib/cjs/components/utils/AutoSizer.js.map +0 -1
  127. package/lib/esm/components/trees/categories-tree/UseCategories.d.ts +0 -8
  128. package/lib/esm/components/trees/categories-tree/UseCategories.js +0 -18
  129. package/lib/esm/components/trees/categories-tree/UseCategories.js.map +0 -1
  130. package/lib/esm/components/utils/AutoSizer.d.ts +0 -13
  131. package/lib/esm/components/utils/AutoSizer.js +0 -17
  132. package/lib/esm/components/utils/AutoSizer.js.map +0 -1
  133. /package/lib/cjs/components/{trees/Tree.scss → tree-header/TreeWithHeader.scss} +0 -0
  134. /package/lib/esm/components/{trees/Tree.scss → tree-header/TreeWithHeader.scss} +0 -0
@@ -0,0 +1,229 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
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
+ import { useCallback, useEffect, useMemo, useRef, useState } from "react";
7
+ import { IModelApp } from "@itwin/core-frontend";
8
+ import { SvgFolder, SvgImodelHollow, SvgItem, SvgLayers, SvgModel } from "@itwin/itwinui-icons-react";
9
+ import { Anchor, Icon, Text } from "@itwin/itwinui-react";
10
+ import { createECSqlQueryExecutor } from "@itwin/presentation-core-interop";
11
+ import { HierarchyNode, HierarchyNodeKey } from "@itwin/presentation-hierarchies";
12
+ import { TreeWidget } from "../../../TreeWidget";
13
+ import { useFocusedInstancesContext } from "../common/FocusedInstancesContext";
14
+ import { useIModelChangeListener } from "../common/UseIModelChangeListener";
15
+ import { useTelemetryContext } from "../common/UseTelemetryContext";
16
+ import { ModelsTreeIdsCache } from "./internal/ModelsTreeIdsCache";
17
+ import { createModelsTreeVisibilityHandler } from "./internal/ModelsTreeVisibilityHandler";
18
+ import { defaultHierarchyConfiguration, ModelsTreeDefinition } from "./ModelsTreeDefinition";
19
+ /**
20
+ * Custom hook to create and manage state for the models tree.
21
+ * @beta
22
+ */
23
+ export function useModelsTree({ activeView, filter, hierarchyConfig, visibilityHandlerOverrides }) {
24
+ const [filteringError, setFilteringError] = useState(undefined);
25
+ const hierarchyConfiguration = useMemo(() => ({
26
+ ...defaultHierarchyConfiguration,
27
+ ...hierarchyConfig,
28
+ }),
29
+ // eslint-disable-next-line react-hooks/exhaustive-deps
30
+ Object.values(hierarchyConfig ?? {}));
31
+ const { onFeatureUsed } = useTelemetryContext();
32
+ const { getModelsTreeIdsCache, visibilityHandlerFactory } = useCachedVisibility(activeView, hierarchyConfiguration, visibilityHandlerOverrides);
33
+ const { loadInstanceKeys: loadFocusedInstancesKeys } = useFocusedInstancesContext();
34
+ const getHierarchyDefinition = useCallback(({ imodelAccess }) => new ModelsTreeDefinition({ imodelAccess, idsCache: getModelsTreeIdsCache(), hierarchyConfig: hierarchyConfiguration }), [getModelsTreeIdsCache, hierarchyConfiguration]);
35
+ const onNodeDoubleClick = useCallback(async ({ nodeData, extendedData }) => {
36
+ if (!HierarchyNode.isInstancesNode(nodeData) || (extendedData && (extendedData.isSubject || extendedData.isModel || extendedData.isCategory))) {
37
+ return;
38
+ }
39
+ const instanceIds = nodeData.key.instanceKeys.map((instanceKey) => instanceKey.id);
40
+ await IModelApp.viewManager.selectedView?.zoomToElements(instanceIds);
41
+ onFeatureUsed({ featureId: "zoom-to-node", reportInteraction: false });
42
+ }, [onFeatureUsed]);
43
+ const getFilteredPaths = useMemo(() => {
44
+ setFilteringError(undefined);
45
+ if (loadFocusedInstancesKeys) {
46
+ return async ({ imodelAccess }) => {
47
+ try {
48
+ const targetKeys = await collectTargetKeys(loadFocusedInstancesKeys);
49
+ return await ModelsTreeDefinition.createInstanceKeyPaths({
50
+ imodelAccess,
51
+ idsCache: getModelsTreeIdsCache(),
52
+ keys: targetKeys,
53
+ hierarchyConfig: hierarchyConfiguration,
54
+ });
55
+ }
56
+ catch (e) {
57
+ const newError = e instanceof Error && e.message.match(/Filter matches more than \d+ items/) ? "tooManyInstancesFocused" : "unknownInstanceFocusError";
58
+ if (newError !== "tooManyInstancesFocused") {
59
+ const feature = e instanceof Error && e.message.includes("query too long to execute or server is too busy") ? "error-timeout" : "error-unknown";
60
+ onFeatureUsed({ featureId: feature, reportInteraction: false });
61
+ }
62
+ setFilteringError(newError);
63
+ return [];
64
+ }
65
+ };
66
+ }
67
+ if (filter) {
68
+ return async ({ imodelAccess }) => {
69
+ onFeatureUsed({ featureId: "filtering", reportInteraction: true });
70
+ try {
71
+ return await ModelsTreeDefinition.createInstanceKeyPaths({
72
+ imodelAccess,
73
+ label: filter,
74
+ idsCache: getModelsTreeIdsCache(),
75
+ hierarchyConfig: hierarchyConfiguration,
76
+ });
77
+ }
78
+ catch (e) {
79
+ const newError = e instanceof Error && e.message.match(/Filter matches more than \d+ items/) ? "tooManyFilterMatches" : "unknownFilterError";
80
+ if (newError !== "tooManyFilterMatches") {
81
+ const feature = e instanceof Error && e.message.includes("query too long to execute or server is too busy") ? "error-timeout" : "error-unknown";
82
+ onFeatureUsed({ featureId: feature, reportInteraction: false });
83
+ }
84
+ setFilteringError(newError);
85
+ return [];
86
+ }
87
+ };
88
+ }
89
+ return undefined;
90
+ }, [filter, loadFocusedInstancesKeys, getModelsTreeIdsCache, onFeatureUsed, hierarchyConfiguration]);
91
+ return {
92
+ modelsTreeProps: {
93
+ treeName: "models-tree-v2",
94
+ visibilityHandlerFactory,
95
+ getHierarchyDefinition,
96
+ getFilteredPaths,
97
+ noDataMessage: getNoDataMessage(filter, filteringError),
98
+ highlight: filter ? { text: filter } : undefined,
99
+ },
100
+ rendererProps: {
101
+ onNodeDoubleClick,
102
+ getIcon,
103
+ },
104
+ };
105
+ }
106
+ function getNoDataMessage(filter, error) {
107
+ if (isInstanceFocusError(error)) {
108
+ return _jsx(InstanceFocusError, { error: error });
109
+ }
110
+ if (isFilterError(error)) {
111
+ return _jsx(Text, { children: TreeWidget.translate(`modelsTree.filtering.${error}`) });
112
+ }
113
+ if (filter) {
114
+ return _jsx(Text, { children: TreeWidget.translate("modelsTree.filtering.noMatches", { filter }) });
115
+ }
116
+ return undefined;
117
+ }
118
+ function isFilterError(error) {
119
+ return error === "tooManyFilterMatches" || error === "unknownFilterError";
120
+ }
121
+ function isInstanceFocusError(error) {
122
+ return error === "tooManyInstancesFocused" || error === "unknownInstanceFocusError";
123
+ }
124
+ function InstanceFocusError({ error }) {
125
+ const { toggle } = useFocusedInstancesContext();
126
+ const localizedMessage = createLocalizedMessage(TreeWidget.translate(`modelsTree.filtering.${error}`), () => toggle());
127
+ return _jsx(Text, { children: localizedMessage });
128
+ }
129
+ function getIcon(node) {
130
+ if (node.extendedData?.imageId === undefined) {
131
+ return undefined;
132
+ }
133
+ switch (node.extendedData.imageId) {
134
+ case "icon-layers":
135
+ return _jsx(SvgLayers, {});
136
+ case "icon-item":
137
+ return _jsx(SvgItem, {});
138
+ case "icon-ec-class":
139
+ return _jsx(SvgClassGrouping, {});
140
+ case "icon-imodel-hollow-2":
141
+ return _jsx(SvgImodelHollow, {});
142
+ case "icon-folder":
143
+ return _jsx(SvgFolder, {});
144
+ case "icon-model":
145
+ return _jsx(SvgModel, {});
146
+ }
147
+ return undefined;
148
+ }
149
+ function createVisibilityHandlerFactory(activeView, idsCacheGetter, overrides) {
150
+ return ({ imodelAccess }) => createModelsTreeVisibilityHandler({ viewport: activeView, idsCache: idsCacheGetter(), imodelAccess, overrides });
151
+ }
152
+ function useCachedVisibility(activeView, hierarchyConfig, overrides) {
153
+ const cacheRef = useRef();
154
+ const currentIModelRef = useRef(activeView.iModel);
155
+ const getModelsTreeIdsCache = useCallback(() => {
156
+ if (!cacheRef.current) {
157
+ cacheRef.current = new ModelsTreeIdsCache(createECSqlQueryExecutor(currentIModelRef.current), hierarchyConfig);
158
+ }
159
+ return cacheRef.current;
160
+ }, [hierarchyConfig]);
161
+ const [visibilityHandlerFactory, setVisibilityHandlerFactory] = useState(() => createVisibilityHandlerFactory(activeView, getModelsTreeIdsCache, overrides));
162
+ useIModelChangeListener({
163
+ imodel: activeView.iModel,
164
+ action: useCallback(() => {
165
+ cacheRef.current = undefined;
166
+ setVisibilityHandlerFactory(() => createVisibilityHandlerFactory(activeView, getModelsTreeIdsCache, overrides));
167
+ }, [activeView, getModelsTreeIdsCache, overrides]),
168
+ });
169
+ useEffect(() => {
170
+ currentIModelRef.current = activeView.iModel;
171
+ cacheRef.current = undefined;
172
+ setVisibilityHandlerFactory(() => createVisibilityHandlerFactory(activeView, getModelsTreeIdsCache, overrides));
173
+ }, [activeView, getModelsTreeIdsCache, overrides]);
174
+ return {
175
+ getModelsTreeIdsCache,
176
+ visibilityHandlerFactory,
177
+ };
178
+ }
179
+ function SvgClassGrouping() {
180
+ return (_jsx(Icon, { children: _jsx("svg", { id: "Calque_1", "data-name": "Calque 1", xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 16 16", children: _jsx("path", { d: "M8.00933,0,0,3.97672V11.986L8.00933,16,16,11.93V3.97651ZM1.66173,11.27642c-.26155.03734-.59754-.26154-.76553-.69085-.168-.41066-.09334-.784.168-.82152.26154-.03734.59754.26154.76553.67219C1.99772,10.86577,1.92306,11.23909,1.66173,11.27642Zm0-3.32319c-.26155.03733-.59754-.28-.76553-.69086-.168-.42932-.09334-.80285.168-.84.26133-.03733.59754.28.76532.69086C1.99772,7.54236,1.92306,7.89723,1.66173,7.95323Zm4.31276,5.52621a.18186.18186,0,0,1-.16821-.01866L3.41657,12.15394a.94275.94275,0,0,1-.29887-.80285c.03754-.33621.22421-.52265.41108-.41066L5.9185,12.24727a.88656.88656,0,0,1,.28.80285A.5057.5057,0,0,1,5.97449,13.47944Zm0-3.37919a.18184.18184,0,0,1-.16821-.01867L3.41657,8.77475a.943.943,0,0,1-.29887-.80286c.03754-.3362.22421-.52286.41108-.42953L5.9185,8.86786a.83112.83112,0,0,1,.28.78419A.51684.51684,0,0,1,5.97449,10.10025Z" }) }) }));
181
+ }
182
+ async function collectTargetKeys(loadFocusedInstancesKeys) {
183
+ const targetKeys = [];
184
+ const groupingNodeInfos = [];
185
+ for await (const key of loadFocusedInstancesKeys()) {
186
+ if ("id" in key) {
187
+ targetKeys.push(key);
188
+ continue;
189
+ }
190
+ if (!HierarchyNodeKey.isClassGrouping(key.key)) {
191
+ targetKeys.push(...key.groupedInstanceKeys);
192
+ continue;
193
+ }
194
+ if (!key.nonGroupingAncestor || !HierarchyNodeKey.isInstances(key.nonGroupingAncestor.key)) {
195
+ continue;
196
+ }
197
+ const parentKey = key.nonGroupingAncestor.key;
198
+ const type = key.nonGroupingAncestor.extendedData?.isCategory ? "category" : "element";
199
+ const modelIds = (key.nonGroupingAncestor.extendedData?.modelIds ?? []).flatMap((ids) => ids);
200
+ const groupInfo = groupingNodeInfos.find((group) => HierarchyNodeKey.equals(group.parentKey, parentKey));
201
+ if (groupInfo) {
202
+ groupInfo.classes.push(key.key.className);
203
+ }
204
+ else {
205
+ groupingNodeInfos.push({ classes: [key.key.className], parentType: type, parentKey, modelIds });
206
+ }
207
+ }
208
+ targetKeys.push(...groupingNodeInfos.map(({ parentKey, parentType, classes, modelIds }) => ({
209
+ parent: parentType === "element"
210
+ ? { type: "element", ids: parentKey.instanceKeys.map((key) => key.id) }
211
+ : { type: "category", ids: parentKey.instanceKeys.map((key) => key.id), modelIds },
212
+ classes,
213
+ })));
214
+ return targetKeys;
215
+ }
216
+ function createLocalizedMessage(message, onClick) {
217
+ const exp = new RegExp("<link>(.*)</link>");
218
+ const match = message.match(exp);
219
+ if (!match) {
220
+ return message;
221
+ }
222
+ const [fullText, innerText] = match;
223
+ const [textBefore, textAfter] = message.split(fullText);
224
+ return (_jsxs(_Fragment, { children: [textBefore ? textBefore : null, _jsx(Anchor, { underline: true, onClick: (e) => {
225
+ e.stopPropagation();
226
+ onClick?.();
227
+ }, children: innerText }), textAfter ? textAfter : null] }));
228
+ }
229
+ //# sourceMappingURL=UseModelsTree.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UseModelsTree.js","sourceRoot":"","sources":["../../../../../src/components/trees/models-tree/UseModelsTree.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 { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { IModelApp } from \"@itwin/core-frontend\";\nimport { SvgFolder, SvgImodelHollow, SvgItem, SvgLayers, SvgModel } from \"@itwin/itwinui-icons-react\";\nimport { Anchor, Icon, Text } from \"@itwin/itwinui-react\";\nimport { createECSqlQueryExecutor } from \"@itwin/presentation-core-interop\";\nimport { HierarchyNode, HierarchyNodeKey } from \"@itwin/presentation-hierarchies\";\nimport { TreeWidget } from \"../../../TreeWidget\";\nimport { useFocusedInstancesContext } from \"../common/FocusedInstancesContext\";\nimport { useIModelChangeListener } from \"../common/UseIModelChangeListener\";\nimport { useTelemetryContext } from \"../common/UseTelemetryContext\";\nimport { ModelsTreeIdsCache } from \"./internal/ModelsTreeIdsCache\";\nimport { createModelsTreeVisibilityHandler } from \"./internal/ModelsTreeVisibilityHandler\";\nimport { defaultHierarchyConfiguration, ModelsTreeDefinition } from \"./ModelsTreeDefinition\";\n\nimport type { Id64String } from \"@itwin/core-bentley\";\nimport type { GroupingHierarchyNode, InstancesNodeKey } from \"@itwin/presentation-hierarchies\";\nimport type { InstanceKey } from \"@itwin/presentation-shared\";\nimport type { ComponentPropsWithoutRef, ReactElement } from \"react\";\nimport type { Viewport } from \"@itwin/core-frontend\";\nimport type { PresentationHierarchyNode } from \"@itwin/presentation-hierarchies-react\";\nimport type { ElementsGroupInfo, ModelsTreeHierarchyConfiguration } from \"./ModelsTreeDefinition\";\nimport type { ModelsTreeVisibilityHandlerOverrides } from \"./internal/ModelsTreeVisibilityHandler\";\nimport type { VisibilityTree } from \"../common/components/VisibilityTree\";\nimport type { VisibilityTreeRenderer } from \"../common/components/VisibilityTreeRenderer\";\n\ntype ModelsTreeFilteringError = \"tooManyFilterMatches\" | \"tooManyInstancesFocused\" | \"unknownFilterError\" | \"unknownInstanceFocusError\";\n\n/** @beta */\ntype VisibilityTreeRendererProps = ComponentPropsWithoutRef<typeof VisibilityTreeRenderer>;\n\n/** @beta */\ntype VisibilityTreeProps = ComponentPropsWithoutRef<typeof VisibilityTree>;\n\n/** @beta */\ninterface UseModelsTreeProps {\n filter?: string;\n activeView: Viewport;\n hierarchyConfig?: Partial<ModelsTreeHierarchyConfiguration>;\n visibilityHandlerOverrides?: ModelsTreeVisibilityHandlerOverrides;\n}\n\n/** @beta */\ninterface UseModelsTreeResult {\n modelsTreeProps: Pick<\n VisibilityTreeProps,\n \"treeName\" | \"getHierarchyDefinition\" | \"getFilteredPaths\" | \"visibilityHandlerFactory\" | \"highlight\" | \"noDataMessage\"\n >;\n rendererProps: Pick<Required<VisibilityTreeRendererProps>, \"getIcon\" | \"onNodeDoubleClick\">;\n}\n\n/**\n * Custom hook to create and manage state for the models tree.\n * @beta\n */\nexport function useModelsTree({ activeView, filter, hierarchyConfig, visibilityHandlerOverrides }: UseModelsTreeProps): UseModelsTreeResult {\n const [filteringError, setFilteringError] = useState<ModelsTreeFilteringError | undefined>(undefined);\n const hierarchyConfiguration = useMemo<ModelsTreeHierarchyConfiguration>(\n () => ({\n ...defaultHierarchyConfiguration,\n ...hierarchyConfig,\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n Object.values(hierarchyConfig ?? {}),\n );\n const { onFeatureUsed } = useTelemetryContext();\n\n const { getModelsTreeIdsCache, visibilityHandlerFactory } = useCachedVisibility(activeView, hierarchyConfiguration, visibilityHandlerOverrides);\n const { loadInstanceKeys: loadFocusedInstancesKeys } = useFocusedInstancesContext();\n\n const getHierarchyDefinition = useCallback<VisibilityTreeProps[\"getHierarchyDefinition\"]>(\n ({ imodelAccess }) => new ModelsTreeDefinition({ imodelAccess, idsCache: getModelsTreeIdsCache(), hierarchyConfig: hierarchyConfiguration }),\n [getModelsTreeIdsCache, hierarchyConfiguration],\n );\n\n const onNodeDoubleClick = useCallback(\n async ({ nodeData, extendedData }: PresentationHierarchyNode) => {\n if (!HierarchyNode.isInstancesNode(nodeData) || (extendedData && (extendedData.isSubject || extendedData.isModel || extendedData.isCategory))) {\n return;\n }\n const instanceIds = nodeData.key.instanceKeys.map((instanceKey) => instanceKey.id);\n await IModelApp.viewManager.selectedView?.zoomToElements(instanceIds);\n onFeatureUsed({ featureId: \"zoom-to-node\", reportInteraction: false });\n },\n [onFeatureUsed],\n );\n\n const getFilteredPaths = useMemo<VisibilityTreeProps[\"getFilteredPaths\"] | undefined>(() => {\n setFilteringError(undefined);\n if (loadFocusedInstancesKeys) {\n return async ({ imodelAccess }) => {\n try {\n const targetKeys = await collectTargetKeys(loadFocusedInstancesKeys);\n return await ModelsTreeDefinition.createInstanceKeyPaths({\n imodelAccess,\n idsCache: getModelsTreeIdsCache(),\n keys: targetKeys,\n hierarchyConfig: hierarchyConfiguration,\n });\n } catch (e) {\n const newError =\n e instanceof Error && e.message.match(/Filter matches more than \\d+ items/) ? \"tooManyInstancesFocused\" : \"unknownInstanceFocusError\";\n if (newError !== \"tooManyInstancesFocused\") {\n const feature = e instanceof Error && e.message.includes(\"query too long to execute or server is too busy\") ? \"error-timeout\" : \"error-unknown\";\n onFeatureUsed({ featureId: feature, reportInteraction: false });\n }\n setFilteringError(newError);\n return [];\n }\n };\n }\n\n if (filter) {\n return async ({ imodelAccess }) => {\n onFeatureUsed({ featureId: \"filtering\", reportInteraction: true });\n try {\n return await ModelsTreeDefinition.createInstanceKeyPaths({\n imodelAccess,\n label: filter,\n idsCache: getModelsTreeIdsCache(),\n hierarchyConfig: hierarchyConfiguration,\n });\n } catch (e) {\n const newError = e instanceof Error && e.message.match(/Filter matches more than \\d+ items/) ? \"tooManyFilterMatches\" : \"unknownFilterError\";\n if (newError !== \"tooManyFilterMatches\") {\n const feature = e instanceof Error && e.message.includes(\"query too long to execute or server is too busy\") ? \"error-timeout\" : \"error-unknown\";\n onFeatureUsed({ featureId: feature, reportInteraction: false });\n }\n setFilteringError(newError);\n return [];\n }\n };\n }\n return undefined;\n }, [filter, loadFocusedInstancesKeys, getModelsTreeIdsCache, onFeatureUsed, hierarchyConfiguration]);\n\n return {\n modelsTreeProps: {\n treeName: \"models-tree-v2\",\n visibilityHandlerFactory,\n getHierarchyDefinition,\n getFilteredPaths,\n noDataMessage: getNoDataMessage(filter, filteringError),\n highlight: filter ? { text: filter } : undefined,\n },\n rendererProps: {\n onNodeDoubleClick,\n getIcon,\n },\n };\n}\n\nfunction getNoDataMessage(filter?: string, error?: ModelsTreeFilteringError) {\n if (isInstanceFocusError(error)) {\n return <InstanceFocusError error={error!} />;\n }\n if (isFilterError(error)) {\n return <Text>{TreeWidget.translate(`modelsTree.filtering.${error}`)}</Text>;\n }\n if (filter) {\n return <Text>{TreeWidget.translate(\"modelsTree.filtering.noMatches\", { filter })}</Text>;\n }\n return undefined;\n}\n\nfunction isFilterError(error: ModelsTreeFilteringError | undefined) {\n return error === \"tooManyFilterMatches\" || error === \"unknownFilterError\";\n}\n\nfunction isInstanceFocusError(error: ModelsTreeFilteringError | undefined) {\n return error === \"tooManyInstancesFocused\" || error === \"unknownInstanceFocusError\";\n}\n\nfunction InstanceFocusError({ error }: { error: ModelsTreeFilteringError }) {\n const { toggle } = useFocusedInstancesContext();\n const localizedMessage = createLocalizedMessage(TreeWidget.translate(`modelsTree.filtering.${error}`), () => toggle());\n return <Text>{localizedMessage}</Text>;\n}\n\nfunction getIcon(node: PresentationHierarchyNode): ReactElement | undefined {\n if (node.extendedData?.imageId === undefined) {\n return undefined;\n }\n\n switch (node.extendedData.imageId) {\n case \"icon-layers\":\n return <SvgLayers />;\n case \"icon-item\":\n return <SvgItem />;\n case \"icon-ec-class\":\n return <SvgClassGrouping />;\n case \"icon-imodel-hollow-2\":\n return <SvgImodelHollow />;\n case \"icon-folder\":\n return <SvgFolder />;\n case \"icon-model\":\n return <SvgModel />;\n }\n\n return undefined;\n}\n\nfunction createVisibilityHandlerFactory(\n activeView: Viewport,\n idsCacheGetter: () => ModelsTreeIdsCache,\n overrides?: ModelsTreeVisibilityHandlerOverrides,\n): VisibilityTreeProps[\"visibilityHandlerFactory\"] {\n return ({ imodelAccess }) => createModelsTreeVisibilityHandler({ viewport: activeView, idsCache: idsCacheGetter(), imodelAccess, overrides });\n}\n\nfunction useCachedVisibility(activeView: Viewport, hierarchyConfig: ModelsTreeHierarchyConfiguration, overrides?: ModelsTreeVisibilityHandlerOverrides) {\n const cacheRef = useRef<ModelsTreeIdsCache>();\n const currentIModelRef = useRef(activeView.iModel);\n\n const getModelsTreeIdsCache = useCallback(() => {\n if (!cacheRef.current) {\n cacheRef.current = new ModelsTreeIdsCache(createECSqlQueryExecutor(currentIModelRef.current), hierarchyConfig);\n }\n return cacheRef.current;\n }, [hierarchyConfig]);\n\n const [visibilityHandlerFactory, setVisibilityHandlerFactory] = useState(() => createVisibilityHandlerFactory(activeView, getModelsTreeIdsCache, overrides));\n\n useIModelChangeListener({\n imodel: activeView.iModel,\n action: useCallback(() => {\n cacheRef.current = undefined;\n setVisibilityHandlerFactory(() => createVisibilityHandlerFactory(activeView, getModelsTreeIdsCache, overrides));\n }, [activeView, getModelsTreeIdsCache, overrides]),\n });\n\n useEffect(() => {\n currentIModelRef.current = activeView.iModel;\n cacheRef.current = undefined;\n setVisibilityHandlerFactory(() => createVisibilityHandlerFactory(activeView, getModelsTreeIdsCache, overrides));\n }, [activeView, getModelsTreeIdsCache, overrides]);\n\n return {\n getModelsTreeIdsCache,\n visibilityHandlerFactory,\n };\n}\n\nfunction SvgClassGrouping() {\n return (\n <Icon>\n <svg id=\"Calque_1\" data-name=\"Calque 1\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 16 16\">\n <path d=\"M8.00933,0,0,3.97672V11.986L8.00933,16,16,11.93V3.97651ZM1.66173,11.27642c-.26155.03734-.59754-.26154-.76553-.69085-.168-.41066-.09334-.784.168-.82152.26154-.03734.59754.26154.76553.67219C1.99772,10.86577,1.92306,11.23909,1.66173,11.27642Zm0-3.32319c-.26155.03733-.59754-.28-.76553-.69086-.168-.42932-.09334-.80285.168-.84.26133-.03733.59754.28.76532.69086C1.99772,7.54236,1.92306,7.89723,1.66173,7.95323Zm4.31276,5.52621a.18186.18186,0,0,1-.16821-.01866L3.41657,12.15394a.94275.94275,0,0,1-.29887-.80285c.03754-.33621.22421-.52265.41108-.41066L5.9185,12.24727a.88656.88656,0,0,1,.28.80285A.5057.5057,0,0,1,5.97449,13.47944Zm0-3.37919a.18184.18184,0,0,1-.16821-.01867L3.41657,8.77475a.943.943,0,0,1-.29887-.80286c.03754-.3362.22421-.52286.41108-.42953L5.9185,8.86786a.83112.83112,0,0,1,.28.78419A.51684.51684,0,0,1,5.97449,10.10025Z\" />\n </svg>\n </Icon>\n );\n}\n\nasync function collectTargetKeys(loadFocusedInstancesKeys: () => AsyncIterableIterator<InstanceKey | GroupingHierarchyNode>) {\n const targetKeys: Array<InstanceKey | ElementsGroupInfo> = [];\n const groupingNodeInfos: Array<{ parentKey: InstancesNodeKey; parentType: \"element\" | \"category\"; classes: string[]; modelIds: Id64String[] }> = [];\n for await (const key of loadFocusedInstancesKeys()) {\n if (\"id\" in key) {\n targetKeys.push(key);\n continue;\n }\n\n if (!HierarchyNodeKey.isClassGrouping(key.key)) {\n targetKeys.push(...key.groupedInstanceKeys);\n continue;\n }\n\n if (!key.nonGroupingAncestor || !HierarchyNodeKey.isInstances(key.nonGroupingAncestor.key)) {\n continue;\n }\n\n const parentKey = key.nonGroupingAncestor.key;\n const type = key.nonGroupingAncestor.extendedData?.isCategory ? \"category\" : \"element\";\n const modelIds = ((key.nonGroupingAncestor.extendedData?.modelIds as Id64String[][]) ?? []).flatMap((ids) => ids);\n const groupInfo = groupingNodeInfos.find((group) => HierarchyNodeKey.equals(group.parentKey, parentKey));\n if (groupInfo) {\n groupInfo.classes.push(key.key.className);\n } else {\n groupingNodeInfos.push({ classes: [key.key.className], parentType: type, parentKey, modelIds });\n }\n }\n targetKeys.push(\n ...groupingNodeInfos.map(({ parentKey, parentType, classes, modelIds }) => ({\n parent:\n parentType === \"element\"\n ? { type: \"element\" as const, ids: parentKey.instanceKeys.map((key) => key.id) }\n : { type: \"category\" as const, ids: parentKey.instanceKeys.map((key) => key.id), modelIds },\n classes,\n })),\n );\n return targetKeys;\n}\n\nfunction createLocalizedMessage(message: string, onClick?: () => void) {\n const exp = new RegExp(\"<link>(.*)</link>\");\n const match = message.match(exp);\n if (!match) {\n return message;\n }\n\n const [fullText, innerText] = match;\n const [textBefore, textAfter] = message.split(fullText);\n\n return (\n <>\n {textBefore ? textBefore : null}\n <Anchor\n underline\n onClick={(e) => {\n e.stopPropagation();\n onClick?.();\n }}\n >\n {innerText}\n </Anchor>\n {textAfter ? textAfter : null}\n </>\n );\n}\n"]}
@@ -4,7 +4,7 @@
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import { concat, concatAll, defer, distinct, EMPTY, firstValueFrom, forkJoin, from, map, merge, mergeMap, of, reduce } from "rxjs";
6
6
  import { assert } from "@itwin/core-bentley";
7
- import { IModelApp, PerModelCategoryVisibility } from "@itwin/core-frontend";
7
+ import { PerModelCategoryVisibility } from "@itwin/core-frontend";
8
8
  import { HierarchyNode, HierarchyNodeIdentifier, HierarchyNodeKey } from "@itwin/presentation-hierarchies";
9
9
  import { toggleAllCategories } from "../../common/CategoriesVisibilityUtils";
10
10
  import { reduceWhile, toVoidPromise } from "../../common/Rxjs";
@@ -695,7 +695,7 @@ export async function showAllModels(models, viewport) {
695
695
  await viewport.addViewedModels(models);
696
696
  viewport.clearNeverDrawn();
697
697
  viewport.clearAlwaysDrawn();
698
- await toggleAllCategories(IModelApp.viewManager, viewport.iModel, true, viewport, false);
698
+ await toggleAllCategories(viewport, true);
699
699
  }
700
700
  /**
701
701
  * Disables display of all given models.