@itwin/frontend-devtools 5.0.0-dev.9 → 5.0.0-dev.92

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 (264) hide show
  1. package/CHANGELOG.md +51 -1
  2. package/README.md +1 -1
  3. package/lib/cjs/ClipboardUtilities.js.map +1 -1
  4. package/lib/cjs/FrontEndDevTools.js +1 -1
  5. package/lib/cjs/FrontEndDevTools.js.map +1 -1
  6. package/lib/cjs/effects/Convolution.js +23 -23
  7. package/lib/cjs/effects/Convolution.js.map +1 -1
  8. package/lib/cjs/effects/EffectTools.js +2 -2
  9. package/lib/cjs/effects/EffectTools.js.map +1 -1
  10. package/lib/cjs/effects/Explosion.js +37 -25
  11. package/lib/cjs/effects/Explosion.js.map +1 -1
  12. package/lib/cjs/effects/FlipImage.js +22 -22
  13. package/lib/cjs/effects/FlipImage.js.map +1 -1
  14. package/lib/cjs/effects/LensDistortion.js +25 -25
  15. package/lib/cjs/effects/LensDistortion.js.map +1 -1
  16. package/lib/cjs/effects/Random.js.map +1 -1
  17. package/lib/cjs/effects/Saturation.js +30 -30
  18. package/lib/cjs/effects/Saturation.js.map +1 -1
  19. package/lib/cjs/effects/Snow.d.ts +1 -1
  20. package/lib/cjs/effects/Snow.d.ts.map +1 -1
  21. package/lib/cjs/effects/Snow.js +19 -8
  22. package/lib/cjs/effects/Snow.js.map +1 -1
  23. package/lib/cjs/effects/Vignette.js +41 -41
  24. package/lib/cjs/effects/Vignette.js.map +1 -1
  25. package/lib/cjs/frontend-devtools.js.map +1 -1
  26. package/lib/cjs/tools/AnimationIntervalTool.js +1 -1
  27. package/lib/cjs/tools/AnimationIntervalTool.js.map +1 -1
  28. package/lib/cjs/tools/ChangeUnitsTool.js +1 -1
  29. package/lib/cjs/tools/ChangeUnitsTool.js.map +1 -1
  30. package/lib/cjs/tools/ClipTools.js +6 -8
  31. package/lib/cjs/tools/ClipTools.js.map +1 -1
  32. package/lib/cjs/tools/DisplayStyleTools.js +21 -25
  33. package/lib/cjs/tools/DisplayStyleTools.js.map +1 -1
  34. package/lib/cjs/tools/EmphasizeElementsTool.js +7 -13
  35. package/lib/cjs/tools/EmphasizeElementsTool.js.map +1 -1
  36. package/lib/cjs/tools/FrustumDecoration.js +28 -9
  37. package/lib/cjs/tools/FrustumDecoration.js.map +1 -1
  38. package/lib/cjs/tools/InspectElementTool.js +7 -6
  39. package/lib/cjs/tools/InspectElementTool.js.map +1 -1
  40. package/lib/cjs/tools/MapLayerTool.d.ts +1 -1
  41. package/lib/cjs/tools/MapLayerTool.d.ts.map +1 -1
  42. package/lib/cjs/tools/MapLayerTool.js +31 -25
  43. package/lib/cjs/tools/MapLayerTool.js.map +1 -1
  44. package/lib/cjs/tools/MeasureTileLoadTime.js +4 -1
  45. package/lib/cjs/tools/MeasureTileLoadTime.js.map +1 -1
  46. package/lib/cjs/tools/ModelAppearanceTools.js +9 -9
  47. package/lib/cjs/tools/ModelAppearanceTools.js.map +1 -1
  48. package/lib/cjs/tools/PlanProjectionTools.js +8 -15
  49. package/lib/cjs/tools/PlanProjectionTools.js.map +1 -1
  50. package/lib/cjs/tools/PlanarMaskTools.js +21 -26
  51. package/lib/cjs/tools/PlanarMaskTools.js.map +1 -1
  52. package/lib/cjs/tools/ProjectExtents.js +6 -3
  53. package/lib/cjs/tools/ProjectExtents.js.map +1 -1
  54. package/lib/cjs/tools/RealityModelTools.js +10 -10
  55. package/lib/cjs/tools/RealityModelTools.js.map +1 -1
  56. package/lib/cjs/tools/RealityTransitionTool.js +1 -1
  57. package/lib/cjs/tools/RealityTransitionTool.js.map +1 -1
  58. package/lib/cjs/tools/RenderSystemTools.js +4 -3
  59. package/lib/cjs/tools/RenderSystemTools.js.map +1 -1
  60. package/lib/cjs/tools/RenderTargetTools.d.ts +1 -1
  61. package/lib/cjs/tools/RenderTargetTools.d.ts.map +1 -1
  62. package/lib/cjs/tools/RenderTargetTools.js +15 -20
  63. package/lib/cjs/tools/RenderTargetTools.js.map +1 -1
  64. package/lib/cjs/tools/ReportWebGLCompatibilityTool.js +1 -1
  65. package/lib/cjs/tools/ReportWebGLCompatibilityTool.js.map +1 -1
  66. package/lib/cjs/tools/SavedViews.js +4 -7
  67. package/lib/cjs/tools/SavedViews.js.map +1 -1
  68. package/lib/cjs/tools/ScheduleScriptTools.d.ts.map +1 -1
  69. package/lib/cjs/tools/ScheduleScriptTools.js +11 -12
  70. package/lib/cjs/tools/ScheduleScriptTools.js.map +1 -1
  71. package/lib/cjs/tools/SelectionTools.js +4 -6
  72. package/lib/cjs/tools/SelectionTools.js.map +1 -1
  73. package/lib/cjs/tools/SetGpuMemoryLimitTool.js +1 -1
  74. package/lib/cjs/tools/SetGpuMemoryLimitTool.js.map +1 -1
  75. package/lib/cjs/tools/SourceAspectIdTools.js +2 -2
  76. package/lib/cjs/tools/SourceAspectIdTools.js.map +1 -1
  77. package/lib/cjs/tools/TileRequestDecoration.js +6 -3
  78. package/lib/cjs/tools/TileRequestDecoration.js.map +1 -1
  79. package/lib/cjs/tools/TileTreeBoundsDecoration.d.ts.map +1 -1
  80. package/lib/cjs/tools/TileTreeBoundsDecoration.js +8 -4
  81. package/lib/cjs/tools/TileTreeBoundsDecoration.js.map +1 -1
  82. package/lib/cjs/tools/ToolTipProvider.js +2 -1
  83. package/lib/cjs/tools/ToolTipProvider.js.map +1 -1
  84. package/lib/cjs/tools/ViewportTools.js +22 -19
  85. package/lib/cjs/tools/ViewportTools.js.map +1 -1
  86. package/lib/cjs/tools/parseArgs.js.map +1 -1
  87. package/lib/cjs/tools/parseBoolean.js.map +1 -1
  88. package/lib/cjs/tools/parseToggle.js.map +1 -1
  89. package/lib/cjs/ui/Button.js.map +1 -1
  90. package/lib/cjs/ui/CheckBox.js.map +1 -1
  91. package/lib/cjs/ui/ColorInput.js.map +1 -1
  92. package/lib/cjs/ui/ComboBox.js.map +1 -1
  93. package/lib/cjs/ui/DataList.js.map +1 -1
  94. package/lib/cjs/ui/NestedMenu.js.map +1 -1
  95. package/lib/cjs/ui/NumericInput.js.map +1 -1
  96. package/lib/cjs/ui/RadioBox.js.map +1 -1
  97. package/lib/cjs/ui/Slider.js.map +1 -1
  98. package/lib/cjs/ui/TextBox.js.map +1 -1
  99. package/lib/cjs/widgets/DiagnosticsPanel.d.ts +1 -1
  100. package/lib/cjs/widgets/DiagnosticsPanel.d.ts.map +1 -1
  101. package/lib/cjs/widgets/DiagnosticsPanel.js +11 -1
  102. package/lib/cjs/widgets/DiagnosticsPanel.js.map +1 -1
  103. package/lib/cjs/widgets/FpsTracker.d.ts +1 -1
  104. package/lib/cjs/widgets/FpsTracker.d.ts.map +1 -1
  105. package/lib/cjs/widgets/FpsTracker.js +5 -1
  106. package/lib/cjs/widgets/FpsTracker.js.map +1 -1
  107. package/lib/cjs/widgets/GpuProfiler.d.ts +1 -1
  108. package/lib/cjs/widgets/GpuProfiler.d.ts.map +1 -1
  109. package/lib/cjs/widgets/GpuProfiler.js +89 -82
  110. package/lib/cjs/widgets/GpuProfiler.js.map +1 -1
  111. package/lib/cjs/widgets/KeyinField.js +8 -1
  112. package/lib/cjs/widgets/KeyinField.js.map +1 -1
  113. package/lib/cjs/widgets/MemoryTracker.d.ts +1 -1
  114. package/lib/cjs/widgets/MemoryTracker.d.ts.map +1 -1
  115. package/lib/cjs/widgets/MemoryTracker.js +16 -4
  116. package/lib/cjs/widgets/MemoryTracker.js.map +1 -1
  117. package/lib/cjs/widgets/RenderCommandBreakdown.d.ts +1 -1
  118. package/lib/cjs/widgets/RenderCommandBreakdown.d.ts.map +1 -1
  119. package/lib/cjs/widgets/RenderCommandBreakdown.js +6 -2
  120. package/lib/cjs/widgets/RenderCommandBreakdown.js.map +1 -1
  121. package/lib/cjs/widgets/TileMemoryBreakdown.d.ts +1 -1
  122. package/lib/cjs/widgets/TileMemoryBreakdown.d.ts.map +1 -1
  123. package/lib/cjs/widgets/TileMemoryBreakdown.js +10 -8
  124. package/lib/cjs/widgets/TileMemoryBreakdown.js.map +1 -1
  125. package/lib/cjs/widgets/TileStatisticsTracker.d.ts +1 -1
  126. package/lib/cjs/widgets/TileStatisticsTracker.d.ts.map +1 -1
  127. package/lib/cjs/widgets/TileStatisticsTracker.js +5 -2
  128. package/lib/cjs/widgets/TileStatisticsTracker.js.map +1 -1
  129. package/lib/cjs/widgets/ToolSettingsTracker.d.ts +1 -1
  130. package/lib/cjs/widgets/ToolSettingsTracker.d.ts.map +1 -1
  131. package/lib/cjs/widgets/ToolSettingsTracker.js +2 -2
  132. package/lib/cjs/widgets/ToolSettingsTracker.js.map +1 -1
  133. package/lib/esm/ClipboardUtilities.js.map +1 -1
  134. package/lib/esm/FrontEndDevTools.js +1 -1
  135. package/lib/esm/FrontEndDevTools.js.map +1 -1
  136. package/lib/esm/effects/Convolution.js +23 -23
  137. package/lib/esm/effects/Convolution.js.map +1 -1
  138. package/lib/esm/effects/EffectTools.js +2 -2
  139. package/lib/esm/effects/EffectTools.js.map +1 -1
  140. package/lib/esm/effects/Explosion.js +37 -25
  141. package/lib/esm/effects/Explosion.js.map +1 -1
  142. package/lib/esm/effects/FlipImage.js +22 -22
  143. package/lib/esm/effects/FlipImage.js.map +1 -1
  144. package/lib/esm/effects/LensDistortion.js +25 -25
  145. package/lib/esm/effects/LensDistortion.js.map +1 -1
  146. package/lib/esm/effects/Random.js.map +1 -1
  147. package/lib/esm/effects/Saturation.js +30 -30
  148. package/lib/esm/effects/Saturation.js.map +1 -1
  149. package/lib/esm/effects/Snow.d.ts +1 -1
  150. package/lib/esm/effects/Snow.d.ts.map +1 -1
  151. package/lib/esm/effects/Snow.js +19 -8
  152. package/lib/esm/effects/Snow.js.map +1 -1
  153. package/lib/esm/effects/Vignette.js +41 -41
  154. package/lib/esm/effects/Vignette.js.map +1 -1
  155. package/lib/esm/frontend-devtools.js.map +1 -1
  156. package/lib/esm/tools/AnimationIntervalTool.js +1 -1
  157. package/lib/esm/tools/AnimationIntervalTool.js.map +1 -1
  158. package/lib/esm/tools/ChangeUnitsTool.js +1 -1
  159. package/lib/esm/tools/ChangeUnitsTool.js.map +1 -1
  160. package/lib/esm/tools/ClipTools.js +6 -8
  161. package/lib/esm/tools/ClipTools.js.map +1 -1
  162. package/lib/esm/tools/DisplayStyleTools.js +21 -25
  163. package/lib/esm/tools/DisplayStyleTools.js.map +1 -1
  164. package/lib/esm/tools/EmphasizeElementsTool.js +7 -13
  165. package/lib/esm/tools/EmphasizeElementsTool.js.map +1 -1
  166. package/lib/esm/tools/FrustumDecoration.js +28 -9
  167. package/lib/esm/tools/FrustumDecoration.js.map +1 -1
  168. package/lib/esm/tools/InspectElementTool.js +7 -6
  169. package/lib/esm/tools/InspectElementTool.js.map +1 -1
  170. package/lib/esm/tools/MapLayerTool.d.ts +1 -1
  171. package/lib/esm/tools/MapLayerTool.d.ts.map +1 -1
  172. package/lib/esm/tools/MapLayerTool.js +32 -26
  173. package/lib/esm/tools/MapLayerTool.js.map +1 -1
  174. package/lib/esm/tools/MeasureTileLoadTime.js +4 -1
  175. package/lib/esm/tools/MeasureTileLoadTime.js.map +1 -1
  176. package/lib/esm/tools/ModelAppearanceTools.js +9 -9
  177. package/lib/esm/tools/ModelAppearanceTools.js.map +1 -1
  178. package/lib/esm/tools/PlanProjectionTools.js +8 -15
  179. package/lib/esm/tools/PlanProjectionTools.js.map +1 -1
  180. package/lib/esm/tools/PlanarMaskTools.js +21 -26
  181. package/lib/esm/tools/PlanarMaskTools.js.map +1 -1
  182. package/lib/esm/tools/ProjectExtents.js +6 -3
  183. package/lib/esm/tools/ProjectExtents.js.map +1 -1
  184. package/lib/esm/tools/RealityModelTools.js +10 -10
  185. package/lib/esm/tools/RealityModelTools.js.map +1 -1
  186. package/lib/esm/tools/RealityTransitionTool.js +1 -1
  187. package/lib/esm/tools/RealityTransitionTool.js.map +1 -1
  188. package/lib/esm/tools/RenderSystemTools.js +4 -3
  189. package/lib/esm/tools/RenderSystemTools.js.map +1 -1
  190. package/lib/esm/tools/RenderTargetTools.d.ts +1 -1
  191. package/lib/esm/tools/RenderTargetTools.d.ts.map +1 -1
  192. package/lib/esm/tools/RenderTargetTools.js +15 -20
  193. package/lib/esm/tools/RenderTargetTools.js.map +1 -1
  194. package/lib/esm/tools/ReportWebGLCompatibilityTool.js +1 -1
  195. package/lib/esm/tools/ReportWebGLCompatibilityTool.js.map +1 -1
  196. package/lib/esm/tools/SavedViews.js +4 -7
  197. package/lib/esm/tools/SavedViews.js.map +1 -1
  198. package/lib/esm/tools/ScheduleScriptTools.d.ts.map +1 -1
  199. package/lib/esm/tools/ScheduleScriptTools.js +11 -12
  200. package/lib/esm/tools/ScheduleScriptTools.js.map +1 -1
  201. package/lib/esm/tools/SelectionTools.js +4 -6
  202. package/lib/esm/tools/SelectionTools.js.map +1 -1
  203. package/lib/esm/tools/SetGpuMemoryLimitTool.js +1 -1
  204. package/lib/esm/tools/SetGpuMemoryLimitTool.js.map +1 -1
  205. package/lib/esm/tools/SourceAspectIdTools.js +2 -2
  206. package/lib/esm/tools/SourceAspectIdTools.js.map +1 -1
  207. package/lib/esm/tools/TileRequestDecoration.js +6 -3
  208. package/lib/esm/tools/TileRequestDecoration.js.map +1 -1
  209. package/lib/esm/tools/TileTreeBoundsDecoration.d.ts.map +1 -1
  210. package/lib/esm/tools/TileTreeBoundsDecoration.js +8 -4
  211. package/lib/esm/tools/TileTreeBoundsDecoration.js.map +1 -1
  212. package/lib/esm/tools/ToolTipProvider.js +2 -1
  213. package/lib/esm/tools/ToolTipProvider.js.map +1 -1
  214. package/lib/esm/tools/ViewportTools.js +22 -19
  215. package/lib/esm/tools/ViewportTools.js.map +1 -1
  216. package/lib/esm/tools/parseArgs.js.map +1 -1
  217. package/lib/esm/tools/parseBoolean.js.map +1 -1
  218. package/lib/esm/tools/parseToggle.js.map +1 -1
  219. package/lib/esm/ui/Button.js.map +1 -1
  220. package/lib/esm/ui/CheckBox.js.map +1 -1
  221. package/lib/esm/ui/ColorInput.js.map +1 -1
  222. package/lib/esm/ui/ComboBox.js.map +1 -1
  223. package/lib/esm/ui/DataList.js.map +1 -1
  224. package/lib/esm/ui/NestedMenu.js.map +1 -1
  225. package/lib/esm/ui/NumericInput.js.map +1 -1
  226. package/lib/esm/ui/RadioBox.js.map +1 -1
  227. package/lib/esm/ui/Slider.js.map +1 -1
  228. package/lib/esm/ui/TextBox.js.map +1 -1
  229. package/lib/esm/widgets/DiagnosticsPanel.d.ts +1 -1
  230. package/lib/esm/widgets/DiagnosticsPanel.d.ts.map +1 -1
  231. package/lib/esm/widgets/DiagnosticsPanel.js +11 -1
  232. package/lib/esm/widgets/DiagnosticsPanel.js.map +1 -1
  233. package/lib/esm/widgets/FpsTracker.d.ts +1 -1
  234. package/lib/esm/widgets/FpsTracker.d.ts.map +1 -1
  235. package/lib/esm/widgets/FpsTracker.js +5 -1
  236. package/lib/esm/widgets/FpsTracker.js.map +1 -1
  237. package/lib/esm/widgets/GpuProfiler.d.ts +1 -1
  238. package/lib/esm/widgets/GpuProfiler.d.ts.map +1 -1
  239. package/lib/esm/widgets/GpuProfiler.js +89 -82
  240. package/lib/esm/widgets/GpuProfiler.js.map +1 -1
  241. package/lib/esm/widgets/KeyinField.js +8 -1
  242. package/lib/esm/widgets/KeyinField.js.map +1 -1
  243. package/lib/esm/widgets/MemoryTracker.d.ts +1 -1
  244. package/lib/esm/widgets/MemoryTracker.d.ts.map +1 -1
  245. package/lib/esm/widgets/MemoryTracker.js +16 -4
  246. package/lib/esm/widgets/MemoryTracker.js.map +1 -1
  247. package/lib/esm/widgets/RenderCommandBreakdown.d.ts +1 -1
  248. package/lib/esm/widgets/RenderCommandBreakdown.d.ts.map +1 -1
  249. package/lib/esm/widgets/RenderCommandBreakdown.js +6 -2
  250. package/lib/esm/widgets/RenderCommandBreakdown.js.map +1 -1
  251. package/lib/esm/widgets/TileMemoryBreakdown.d.ts +1 -1
  252. package/lib/esm/widgets/TileMemoryBreakdown.d.ts.map +1 -1
  253. package/lib/esm/widgets/TileMemoryBreakdown.js +10 -8
  254. package/lib/esm/widgets/TileMemoryBreakdown.js.map +1 -1
  255. package/lib/esm/widgets/TileStatisticsTracker.d.ts +1 -1
  256. package/lib/esm/widgets/TileStatisticsTracker.d.ts.map +1 -1
  257. package/lib/esm/widgets/TileStatisticsTracker.js +5 -2
  258. package/lib/esm/widgets/TileStatisticsTracker.js.map +1 -1
  259. package/lib/esm/widgets/ToolSettingsTracker.d.ts +1 -1
  260. package/lib/esm/widgets/ToolSettingsTracker.d.ts.map +1 -1
  261. package/lib/esm/widgets/ToolSettingsTracker.js +2 -2
  262. package/lib/esm/widgets/ToolSettingsTracker.js.map +1 -1
  263. package/lib/public/locales/en/FrontendDevTools.json +494 -494
  264. package/package.json +10 -10
@@ -61,12 +61,12 @@ exports.SourceAspectIdTool = SourceAspectIdTool;
61
61
  * @beta
62
62
  */
63
63
  class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {
64
+ static toolId = "SourceAspectIdFromElementId";
64
65
  getECSql(queryId) {
65
66
  return `SELECT Identifier as resultId FROM BisCore.ExternalSourceAspect WHERE Element.Id=${queryId} AND [Kind]='Element'`;
66
67
  }
67
68
  }
68
69
  exports.SourceAspectIdFromElementIdTool = SourceAspectIdFromElementIdTool;
69
- SourceAspectIdFromElementIdTool.toolId = "SourceAspectIdFromElementId";
70
70
  /** Given the Id of an element in the iModel, output the source aspect Id of the object in the source document from which the element originated.
71
71
  * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
72
72
  * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
@@ -77,10 +77,10 @@ SourceAspectIdFromElementIdTool.toolId = "SourceAspectIdFromElementId";
77
77
  * @beta
78
78
  */
79
79
  class ElementIdFromSourceAspectIdTool extends SourceAspectIdTool {
80
+ static toolId = "ElementIdFromSourceAspectId";
80
81
  getECSql(queryId) {
81
82
  return `SELECT Element.Id as resultId FROM BisCore.ExternalSourceAspect WHERE Identifier='${queryId}' AND [Kind]='Element'`;
82
83
  }
83
84
  }
84
85
  exports.ElementIdFromSourceAspectIdTool = ElementIdFromSourceAspectIdTool;
85
- ElementIdFromSourceAspectIdTool.toolId = "ElementIdFromSourceAspectId";
86
86
  //# sourceMappingURL=SourceAspectIdTools.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SourceAspectIdTools.js","sourceRoot":"","sources":["../../../src/tools/SourceAspectIdTools.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F;;GAEG;AAEH,sDAAmD;AACnD,oDAAoD;AACpD,wDAAoG;AACpG,8DAA8D;AAC9D,2CAAwC;AAExC;;;;GAIG;AACH,MAAsB,kBAAmB,SAAQ,oBAAI;IAC5C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAIlC,KAAK,CAAC,GAAG,CAAC,SAAkB,EAAE,eAAyB;QACrE,IAAI,OAAO,SAAS,KAAK,QAAQ;YAC/B,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,KAAK,eAAe,CAAC,CAAC;QAE1D,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,WAAW,CAAC,GAAG,SAAmB;QACtD,MAAM,IAAI,GAAG,IAAA,qBAAS,EAAC,SAAS,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;IACvD,CAAC;IAEO,KAAK,CAAC,OAAO,CAAC,OAAe,EAAE,eAAwB;QAC7D,MAAM,MAAM,GAAG,yBAAS,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM,CAAC;QAC1D,IAAI,SAAS,KAAK,MAAM;YACtB,OAAO;QAET,IAAI,QAAQ,CAAC;QACb,IAAI,CAAC;YACH,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,4BAAc,CAAC,kBAAkB,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;gBACxJ,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;QAC5B,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,QAAQ,GAAG,2BAAY,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,OAAO,QAAQ,KAAK,QAAQ;YAC9B,QAAQ,GAAG,WAAW,CAAC;QAEzB,IAAI,eAAe;YACjB,IAAA,0CAAqB,EAAC,QAAQ,CAAC,CAAC;QAElC,MAAM,OAAO,GAAG,GAAG,OAAO,OAAO,QAAQ,EAAE,CAAC;QAC5C,yBAAS,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,oCAAoB,CAAC,qCAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IACvG,CAAC;CACF;AAxCD,gDAwCC;AAED;;;;;;;;GAQG;AACH,MAAa,+BAAgC,SAAQ,kBAAkB;IAG3D,QAAQ,CAAC,OAAe;QAChC,OAAO,oFAAoF,OAAO,uBAAuB,CAAC;IAC5H,CAAC;;AALH,0EAMC;AALwB,sCAAM,GAAG,6BAA6B,CAAC;AAOhE;;;;;;;;GAQG;AACH,MAAa,+BAAgC,SAAQ,kBAAkB;IAG3D,QAAQ,CAAC,OAAe;QAChC,OAAO,qFAAqF,OAAO,wBAAwB,CAAC;IAC9H,CAAC;;AALH,0EAMC;AALwB,sCAAM,GAAG,6BAA6B,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module Tools\r\n */\r\n\r\nimport { BentleyError } from \"@itwin/core-bentley\";\r\nimport { QueryRowFormat } from \"@itwin/core-common\";\r\nimport { IModelApp, NotifyMessageDetails, OutputMessagePriority, Tool } from \"@itwin/core-frontend\";\r\nimport { copyStringToClipboard } from \"../ClipboardUtilities\";\r\nimport { parseArgs } from \"./parseArgs\";\r\n\r\n/** Base class for a tool that can convert between source aspect Ids and element Ids.\r\n * A \"source aspect Id\" is a string that identifies an object (such as an element) in the source document from which the iModel originated.\r\n * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.\r\n * @beta\r\n */\r\nexport abstract class SourceAspectIdTool extends Tool {\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return 2; }\r\n\r\n protected abstract getECSql(queryId: string): string;\r\n\r\n public override async run(idToQuery?: string, copyToClipboard?: boolean): Promise<boolean> {\r\n if (typeof idToQuery === \"string\")\r\n await this.doQuery(idToQuery, true === copyToClipboard);\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...keyinArgs: string[]): Promise<boolean> {\r\n const args = parseArgs(keyinArgs);\r\n return this.run(args.get(\"i\"), args.getBoolean(\"c\"));\r\n }\r\n\r\n private async doQuery(queryId: string, copyToClipboard: boolean): Promise<void> {\r\n const imodel = IModelApp.viewManager.selectedView?.iModel;\r\n if (undefined === imodel)\r\n return;\r\n\r\n let resultId;\r\n try {\r\n for await (const row of imodel.createQueryReader(this.getECSql(queryId), undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames, limit: { count: 1 } }))\r\n resultId = row.resultId;\r\n } catch (ex) {\r\n resultId = BentleyError.getErrorMessage(ex);\r\n }\r\n\r\n if (typeof resultId !== \"string\")\r\n resultId = \"NOT FOUND\";\r\n\r\n if (copyToClipboard)\r\n copyStringToClipboard(resultId);\r\n\r\n const message = `${queryId} => ${resultId}`;\r\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Info, message));\r\n }\r\n}\r\n\r\n/** Given a source aspect Id, output the Id of the corresponding element in the iModel.\r\n * A \"source aspect Id\" is a string that identifies an object (such as an element) in the source document from which the iModel originated.\r\n * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.\r\n * Arguments:\r\n * - `id=elementId` where `elementId` is the numeric Id of the element of interest (e.g., `0x13a6c`; decimal notation is also permitted).\r\n * - `copy=0|1` where `1` indicates the source aspect Id should be copied to the clipboard.\r\n * The command outputs to the IModelApp.notifications the corresponding source aspect Id, or \"NOT FOUND\".\r\n * @beta\r\n */\r\nexport class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {\r\n public static override toolId = \"SourceAspectIdFromElementId\";\r\n\r\n protected getECSql(queryId: string): string {\r\n return `SELECT Identifier as resultId FROM BisCore.ExternalSourceAspect WHERE Element.Id=${queryId} AND [Kind]='Element'`;\r\n }\r\n}\r\n\r\n/** Given the Id of an element in the iModel, output the source aspect Id of the object in the source document from which the element originated.\r\n * A \"source aspect Id\" is a string that identifies an object (such as an element) in the source document from which the iModel originated.\r\n * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.\r\n * Arguments:\r\n * - `id=sourceAspectId` where `sourceAspectId` is the string identifier of the object of interest.\r\n * - `copy=0|1` where `1` indicates the element Id should be copied to the clipboard.\r\n * The command outputs to the IModelApp.notifications the corresponding element Id, or \"NOT FOUND\".\r\n * @beta\r\n */\r\nexport class ElementIdFromSourceAspectIdTool extends SourceAspectIdTool {\r\n public static override toolId = \"ElementIdFromSourceAspectId\";\r\n\r\n protected getECSql(queryId: string): string {\r\n return `SELECT Element.Id as resultId FROM BisCore.ExternalSourceAspect WHERE Identifier='${queryId}' AND [Kind]='Element'`;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"SourceAspectIdTools.js","sourceRoot":"","sources":["../../../src/tools/SourceAspectIdTools.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F;;GAEG;AAEH,sDAAmD;AACnD,oDAAoD;AACpD,wDAAoG;AACpG,8DAA8D;AAC9D,2CAAwC;AAExC;;;;GAIG;AACH,MAAsB,kBAAmB,SAAQ,oBAAI;IAC5C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAIlC,KAAK,CAAC,GAAG,CAAC,SAAkB,EAAE,eAAyB;QACrE,IAAI,OAAO,SAAS,KAAK,QAAQ;YAC/B,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,KAAK,eAAe,CAAC,CAAC;QAE1D,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,WAAW,CAAC,GAAG,SAAmB;QACtD,MAAM,IAAI,GAAG,IAAA,qBAAS,EAAC,SAAS,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;IACvD,CAAC;IAEO,KAAK,CAAC,OAAO,CAAC,OAAe,EAAE,eAAwB;QAC7D,MAAM,MAAM,GAAG,yBAAS,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM,CAAC;QAC1D,IAAI,SAAS,KAAK,MAAM;YACtB,OAAO;QAET,IAAI,QAAQ,CAAC;QACb,IAAI,CAAC;YACH,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,4BAAc,CAAC,kBAAkB,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;gBACxJ,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;QAC5B,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,QAAQ,GAAG,2BAAY,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,OAAO,QAAQ,KAAK,QAAQ;YAC9B,QAAQ,GAAG,WAAW,CAAC;QAEzB,IAAI,eAAe;YACjB,IAAA,0CAAqB,EAAC,QAAQ,CAAC,CAAC;QAElC,MAAM,OAAO,GAAG,GAAG,OAAO,OAAO,QAAQ,EAAE,CAAC;QAC5C,yBAAS,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,oCAAoB,CAAC,qCAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IACvG,CAAC;CACF;AAxCD,gDAwCC;AAED;;;;;;;;GAQG;AACH,MAAa,+BAAgC,SAAQ,kBAAkB;IAC9D,MAAM,CAAU,MAAM,GAAG,6BAA6B,CAAC;IAEpD,QAAQ,CAAC,OAAe;QAChC,OAAO,oFAAoF,OAAO,uBAAuB,CAAC;IAC5H,CAAC;;AALH,0EAMC;AAED;;;;;;;;GAQG;AACH,MAAa,+BAAgC,SAAQ,kBAAkB;IAC9D,MAAM,CAAU,MAAM,GAAG,6BAA6B,CAAC;IAEpD,QAAQ,CAAC,OAAe;QAChC,OAAO,qFAAqF,OAAO,wBAAwB,CAAC;IAC9H,CAAC;;AALH,0EAMC","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\n/** @packageDocumentation\n * @module Tools\n */\n\nimport { BentleyError } from \"@itwin/core-bentley\";\nimport { QueryRowFormat } from \"@itwin/core-common\";\nimport { IModelApp, NotifyMessageDetails, OutputMessagePriority, Tool } from \"@itwin/core-frontend\";\nimport { copyStringToClipboard } from \"../ClipboardUtilities\";\nimport { parseArgs } from \"./parseArgs\";\n\n/** Base class for a tool that can convert between source aspect Ids and element Ids.\n * A \"source aspect Id\" is a string that identifies an object (such as an element) in the source document from which the iModel originated.\n * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.\n * @beta\n */\nexport abstract class SourceAspectIdTool extends Tool {\n public static override get minArgs() { return 1; }\n public static override get maxArgs() { return 2; }\n\n protected abstract getECSql(queryId: string): string;\n\n public override async run(idToQuery?: string, copyToClipboard?: boolean): Promise<boolean> {\n if (typeof idToQuery === \"string\")\n await this.doQuery(idToQuery, true === copyToClipboard);\n\n return true;\n }\n\n public override async parseAndRun(...keyinArgs: string[]): Promise<boolean> {\n const args = parseArgs(keyinArgs);\n return this.run(args.get(\"i\"), args.getBoolean(\"c\"));\n }\n\n private async doQuery(queryId: string, copyToClipboard: boolean): Promise<void> {\n const imodel = IModelApp.viewManager.selectedView?.iModel;\n if (undefined === imodel)\n return;\n\n let resultId;\n try {\n for await (const row of imodel.createQueryReader(this.getECSql(queryId), undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames, limit: { count: 1 } }))\n resultId = row.resultId;\n } catch (ex) {\n resultId = BentleyError.getErrorMessage(ex);\n }\n\n if (typeof resultId !== \"string\")\n resultId = \"NOT FOUND\";\n\n if (copyToClipboard)\n copyStringToClipboard(resultId);\n\n const message = `${queryId} => ${resultId}`;\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Info, message));\n }\n}\n\n/** Given a source aspect Id, output the Id of the corresponding element in the iModel.\n * A \"source aspect Id\" is a string that identifies an object (such as an element) in the source document from which the iModel originated.\n * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.\n * Arguments:\n * - `id=elementId` where `elementId` is the numeric Id of the element of interest (e.g., `0x13a6c`; decimal notation is also permitted).\n * - `copy=0|1` where `1` indicates the source aspect Id should be copied to the clipboard.\n * The command outputs to the IModelApp.notifications the corresponding source aspect Id, or \"NOT FOUND\".\n * @beta\n */\nexport class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {\n public static override toolId = \"SourceAspectIdFromElementId\";\n\n protected getECSql(queryId: string): string {\n return `SELECT Identifier as resultId FROM BisCore.ExternalSourceAspect WHERE Element.Id=${queryId} AND [Kind]='Element'`;\n }\n}\n\n/** Given the Id of an element in the iModel, output the source aspect Id of the object in the source document from which the element originated.\n * A \"source aspect Id\" is a string that identifies an object (such as an element) in the source document from which the iModel originated.\n * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.\n * Arguments:\n * - `id=sourceAspectId` where `sourceAspectId` is the string identifier of the object of interest.\n * - `copy=0|1` where `1` indicates the element Id should be copied to the clipboard.\n * The command outputs to the IModelApp.notifications the corresponding element Id, or \"NOT FOUND\".\n * @beta\n */\nexport class ElementIdFromSourceAspectIdTool extends SourceAspectIdTool {\n public static override toolId = \"ElementIdFromSourceAspectId\";\n\n protected getECSql(queryId: string): string {\n return `SELECT Element.Id as resultId FROM BisCore.ExternalSourceAspect WHERE Identifier='${queryId}' AND [Kind]='Element'`;\n }\n}\n"]}
@@ -12,9 +12,10 @@ const core_common_1 = require("@itwin/core-common");
12
12
  const core_frontend_1 = require("@itwin/core-frontend");
13
13
  const parseToggle_1 = require("./parseToggle");
14
14
  class TileRequestDecoration {
15
+ static _instance;
16
+ _removeDecorator;
17
+ _targetVp;
15
18
  constructor(vp) {
16
- /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */
17
- this.useCachedDecorations = true;
18
19
  this._targetVp = vp;
19
20
  this._removeDecorator = core_frontend_1.IModelApp.viewManager.addDecorator(this);
20
21
  }
@@ -24,6 +25,8 @@ class TileRequestDecoration {
24
25
  this._removeDecorator = undefined;
25
26
  }
26
27
  }
28
+ /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */
29
+ useCachedDecorations = true;
27
30
  decorate(context) {
28
31
  const tiles = core_frontend_1.IModelApp.tileAdmin.getRequestsForUser(this._targetVp);
29
32
  if (undefined === tiles)
@@ -64,6 +67,7 @@ class TileRequestDecoration {
64
67
  * @beta
65
68
  */
66
69
  class ToggleTileRequestDecorationTool extends core_frontend_1.Tool {
70
+ static toolId = "ToggleTileRequestDecoration";
67
71
  static get minArgs() { return 0; }
68
72
  static get maxArgs() { return 1; }
69
73
  async run(enable) {
@@ -80,5 +84,4 @@ class ToggleTileRequestDecorationTool extends core_frontend_1.Tool {
80
84
  }
81
85
  }
82
86
  exports.ToggleTileRequestDecorationTool = ToggleTileRequestDecorationTool;
83
- ToggleTileRequestDecorationTool.toolId = "ToggleTileRequestDecoration";
84
87
  //# sourceMappingURL=TileRequestDecoration.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TileRequestDecoration.js","sourceRoot":"","sources":["../../../src/tools/TileRequestDecoration.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module Tools\r\n */\r\n\r\nimport { ColorDef, LinePixels } from \"@itwin/core-common\";\r\nimport { DecorateContext, GraphicBuilder, GraphicType, IModelApp, TileTree, Tool, Viewport } from \"@itwin/core-frontend\";\r\nimport { parseToggle } from \"./parseToggle\";\r\n\r\nclass TileRequestDecoration {\r\n private static _instance?: TileRequestDecoration;\r\n private _removeDecorator?: () => void;\r\n private readonly _targetVp: Viewport;\r\n\r\n private constructor(vp: Viewport) {\r\n this._targetVp = vp;\r\n this._removeDecorator = IModelApp.viewManager.addDecorator(this);\r\n }\r\n\r\n private stop(): void {\r\n if (this._removeDecorator) {\r\n this._removeDecorator();\r\n this._removeDecorator = undefined;\r\n }\r\n }\r\n\r\n /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */\r\n public readonly useCachedDecorations = true;\r\n\r\n public decorate(context: DecorateContext): void {\r\n const tiles = IModelApp.tileAdmin.getRequestsForUser(this._targetVp);\r\n if (undefined === tiles)\r\n return;\r\n\r\n const map = new Map<TileTree, GraphicBuilder>();\r\n for (const tile of tiles) {\r\n let builder = map.get(tile.tree);\r\n if (undefined === builder) {\r\n builder = context.createGraphicBuilder(GraphicType.WorldDecoration, tile.tree.iModelTransform);\r\n map.set(tile.tree, builder);\r\n }\r\n\r\n let color = ColorDef.white;\r\n if (undefined !== tile.request)\r\n color = tile.request.isQueued ? ColorDef.green : ColorDef.red;\r\n\r\n builder.setSymbology(color, color, 1, LinePixels.Solid);\r\n builder.addRangeBox(tile.range);\r\n }\r\n\r\n for (const builder of map.values())\r\n context.addDecorationFromBuilder(builder);\r\n }\r\n\r\n public static toggle(vp: Viewport, enabled?: boolean): void {\r\n const instance = TileRequestDecoration._instance;\r\n if (undefined !== enabled) {\r\n if ((undefined !== instance) === enabled)\r\n return;\r\n }\r\n\r\n if (undefined === instance) {\r\n TileRequestDecoration._instance = new TileRequestDecoration(vp);\r\n } else {\r\n instance.stop();\r\n TileRequestDecoration._instance = undefined;\r\n }\r\n }\r\n}\r\n\r\n/** Display in every viewport a range graphic for every tile currently being requested for the viewport that was initially selected when the decorator was installed.\r\n * Green indicates queued (http request not yet sent), red indicates active (http request sent). White indicates unexpected state.\r\n * @beta\r\n */\r\nexport class ToggleTileRequestDecorationTool extends Tool {\r\n public static override toolId = \"ToggleTileRequestDecoration\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n public override async run(enable?: boolean): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp)\r\n TileRequestDecoration.toggle(vp, enable);\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n const enable = parseToggle(args[0]);\r\n if (typeof enable !== \"string\")\r\n await this.run(enable);\r\n\r\n return true;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"TileRequestDecoration.js","sourceRoot":"","sources":["../../../src/tools/TileRequestDecoration.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\n/** @packageDocumentation\n * @module Tools\n */\n\nimport { ColorDef, LinePixels } from \"@itwin/core-common\";\nimport { DecorateContext, GraphicBuilder, GraphicType, IModelApp, TileTree, Tool, Viewport } from \"@itwin/core-frontend\";\nimport { parseToggle } from \"./parseToggle\";\n\nclass TileRequestDecoration {\n private static _instance?: TileRequestDecoration;\n private _removeDecorator?: () => void;\n private readonly _targetVp: Viewport;\n\n private constructor(vp: Viewport) {\n this._targetVp = vp;\n this._removeDecorator = IModelApp.viewManager.addDecorator(this);\n }\n\n private stop(): void {\n if (this._removeDecorator) {\n this._removeDecorator();\n this._removeDecorator = undefined;\n }\n }\n\n /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */\n public readonly useCachedDecorations = true;\n\n public decorate(context: DecorateContext): void {\n const tiles = IModelApp.tileAdmin.getRequestsForUser(this._targetVp);\n if (undefined === tiles)\n return;\n\n const map = new Map<TileTree, GraphicBuilder>();\n for (const tile of tiles) {\n let builder = map.get(tile.tree);\n if (undefined === builder) {\n builder = context.createGraphicBuilder(GraphicType.WorldDecoration, tile.tree.iModelTransform);\n map.set(tile.tree, builder);\n }\n\n let color = ColorDef.white;\n if (undefined !== tile.request)\n color = tile.request.isQueued ? ColorDef.green : ColorDef.red;\n\n builder.setSymbology(color, color, 1, LinePixels.Solid);\n builder.addRangeBox(tile.range);\n }\n\n for (const builder of map.values())\n context.addDecorationFromBuilder(builder);\n }\n\n public static toggle(vp: Viewport, enabled?: boolean): void {\n const instance = TileRequestDecoration._instance;\n if (undefined !== enabled) {\n if ((undefined !== instance) === enabled)\n return;\n }\n\n if (undefined === instance) {\n TileRequestDecoration._instance = new TileRequestDecoration(vp);\n } else {\n instance.stop();\n TileRequestDecoration._instance = undefined;\n }\n }\n}\n\n/** Display in every viewport a range graphic for every tile currently being requested for the viewport that was initially selected when the decorator was installed.\n * Green indicates queued (http request not yet sent), red indicates active (http request sent). White indicates unexpected state.\n * @beta\n */\nexport class ToggleTileRequestDecorationTool extends Tool {\n public static override toolId = \"ToggleTileRequestDecoration\";\n public static override get minArgs() { return 0; }\n public static override get maxArgs() { return 1; }\n\n public override async run(enable?: boolean): Promise<boolean> {\n const vp = IModelApp.viewManager.selectedView;\n if (undefined !== vp)\n TileRequestDecoration.toggle(vp, enable);\n\n return true;\n }\n\n public override async parseAndRun(...args: string[]): Promise<boolean> {\n const enable = parseToggle(args[0]);\n if (typeof enable !== \"string\")\n await this.run(enable);\n\n return true;\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"TileTreeBoundsDecoration.d.ts","sourceRoot":"","sources":["../../../src/tools/TileTreeBoundsDecoration.ts"],"names":[],"mappings":"AAUA,OAAO,EAA8D,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAyDxG;;GAEG;AACH,qBAAa,kCAAmC,SAAQ,IAAI;IAC1D,OAAuB,MAAM,SAAoC;IACjE,WAA2B,OAAO,WAAgB;IAClD,WAA2B,OAAO,WAAgB;IAE5B,GAAG,CAAC,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAKvC,WAAW,CAAC,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;CAOvE"}
1
+ {"version":3,"file":"TileTreeBoundsDecoration.d.ts","sourceRoot":"","sources":["../../../src/tools/TileTreeBoundsDecoration.ts"],"names":[],"mappings":"AAUA,OAAO,EAA8D,IAAI,EAAE,MAAM,sBAAsB,CAAC;AA2DxG;;GAEG;AACH,qBAAa,kCAAmC,SAAQ,IAAI;IAC1D,OAAuB,MAAM,SAAoC;IACjE,WAA2B,OAAO,WAAgB;IAClD,WAA2B,OAAO,WAAgB;IAE5B,GAAG,CAAC,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAKvC,WAAW,CAAC,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;CAOvE"}
@@ -12,9 +12,9 @@ const core_common_1 = require("@itwin/core-common");
12
12
  const core_frontend_1 = require("@itwin/core-frontend");
13
13
  const parseToggle_1 = require("./parseToggle");
14
14
  class TreeDecoration {
15
+ static _instance;
16
+ _removeMe;
15
17
  constructor() {
16
- /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */
17
- this.useCachedDecorations = true;
18
18
  this._removeMe = core_frontend_1.IModelApp.viewManager.addDecorator(this);
19
19
  }
20
20
  stop() {
@@ -23,8 +23,12 @@ class TreeDecoration {
23
23
  this._removeMe = undefined;
24
24
  }
25
25
  }
26
+ /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */
27
+ useCachedDecorations = true;
26
28
  decorate(context) {
27
- context.viewport.forEachTileTreeRef((ref) => this.drawBoundingBox(ref, context));
29
+ for (const ref of context.viewport.getTileTreeRefs()) {
30
+ this.drawBoundingBox(ref, context);
31
+ }
28
32
  }
29
33
  drawBoundingBox(ref, context) {
30
34
  const tree = ref.treeOwner.tileTree;
@@ -57,6 +61,7 @@ class TreeDecoration {
57
61
  * @beta
58
62
  */
59
63
  class ToggleTileTreeBoundsDecorationTool extends core_frontend_1.Tool {
64
+ static toolId = "ToggleTileTreeBoundsDecoration";
60
65
  static get minArgs() { return 0; }
61
66
  static get maxArgs() { return 1; }
62
67
  async run(enable) {
@@ -71,5 +76,4 @@ class ToggleTileTreeBoundsDecorationTool extends core_frontend_1.Tool {
71
76
  }
72
77
  }
73
78
  exports.ToggleTileTreeBoundsDecorationTool = ToggleTileTreeBoundsDecorationTool;
74
- ToggleTileTreeBoundsDecorationTool.toolId = "ToggleTileTreeBoundsDecoration";
75
79
  //# sourceMappingURL=TileTreeBoundsDecoration.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TileTreeBoundsDecoration.js","sourceRoot":"","sources":["../../../src/tools/TileTreeBoundsDecoration.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F;;GAEG;AAEH,oDAA0D;AAC1D,wDAAwG;AACxG,+CAA4C;AAE5C,MAAM,cAAc;IAIlB;QAWA,0HAA0H;QAC1G,yBAAoB,GAAG,IAAI,CAAC;QAX1C,IAAI,CAAC,SAAS,GAAG,yBAAS,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC5D,CAAC;IAEO,IAAI;QACV,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC7B,CAAC;IACH,CAAC;IAKM,QAAQ,CAAC,OAAwB;QACtC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC;IACnF,CAAC;IAEO,eAAe,CAAC,GAAsB,EAAE,OAAwB;QACtE,MAAM,IAAI,GAAG,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC;QACpC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;QACnC,IAAI,SAAS,KAAK,QAAQ,IAAI,SAAS,KAAK,IAAI,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM;YAC9F,OAAO;QAET,MAAM,OAAO,GAAG,OAAO,CAAC,oBAAoB,CAAC,2BAAW,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;QACpF,OAAO,CAAC,YAAY,CAAC,sBAAQ,CAAC,KAAK,EAAE,sBAAQ,CAAC,KAAK,EAAE,CAAC,EAAE,wBAAU,CAAC,KAAK,CAAC,CAAC;QAC1E,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEhC,IAAI,SAAS,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;YACpC,OAAO,CAAC,YAAY,CAAC,sBAAQ,CAAC,GAAG,EAAE,sBAAQ,CAAC,GAAG,EAAE,CAAC,EAAE,wBAAU,CAAC,KAAK,CAAC,CAAC;YACtE,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACzC,CAAC;QAED,OAAO,CAAC,wBAAwB,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC;IAEM,MAAM,CAAC,MAAM,CAAC,OAAiB;QACpC,MAAM,QAAQ,GAAG,cAAc,CAAC,SAAS,CAAC;QAC1C,IAAI,SAAS,KAAK,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ,CAAC,KAAK,OAAO;YAC/D,OAAO;QAET,IAAI,SAAS,KAAK,QAAQ,EAAE,CAAC;YAC3B,cAAc,CAAC,SAAS,GAAG,IAAI,cAAc,EAAE,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,QAAQ,CAAC,IAAI,EAAE,CAAC;YAChB,cAAc,CAAC,SAAS,GAAG,SAAS,CAAC;QACvC,CAAC;IACH,CAAC;CACF;AAED;;GAEG;AACH,MAAa,kCAAmC,SAAQ,oBAAI;IAEnD,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAElC,KAAK,CAAC,GAAG,CAAC,MAAgB;QACxC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,WAAW,CAAC,GAAG,IAAc;QACjD,MAAM,MAAM,GAAG,IAAA,yBAAW,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,OAAO,MAAM,KAAK,QAAQ;YAC5B,MAAM,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAEzB,OAAO,IAAI,CAAC;IACd,CAAC;;AAhBH,gFAiBC;AAhBwB,yCAAM,GAAG,gCAAgC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module Tools\r\n */\r\n\r\nimport { ColorDef, LinePixels } from \"@itwin/core-common\";\r\nimport { DecorateContext, GraphicType, IModelApp, TileTreeReference, Tool } from \"@itwin/core-frontend\";\r\nimport { parseToggle } from \"./parseToggle\";\r\n\r\nclass TreeDecoration {\r\n private static _instance?: TreeDecoration;\r\n private _removeMe?: () => void;\r\n\r\n private constructor() {\r\n this._removeMe = IModelApp.viewManager.addDecorator(this);\r\n }\r\n\r\n private stop() {\r\n if (this._removeMe) {\r\n this._removeMe();\r\n this._removeMe = undefined;\r\n }\r\n }\r\n\r\n /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */\r\n public readonly useCachedDecorations = true;\r\n\r\n public decorate(context: DecorateContext): void {\r\n context.viewport.forEachTileTreeRef((ref) => this.drawBoundingBox(ref, context));\r\n }\r\n\r\n private drawBoundingBox(ref: TileTreeReference, context: DecorateContext): void {\r\n const tree = ref.treeOwner.tileTree;\r\n const location = ref.getLocation();\r\n if (undefined === location || undefined === tree || tree.isContentUnbounded || tree.range.isNull)\r\n return;\r\n\r\n const builder = context.createGraphicBuilder(GraphicType.WorldDecoration, location);\r\n builder.setSymbology(ColorDef.green, ColorDef.green, 1, LinePixels.Solid);\r\n builder.addRangeBox(tree.range);\r\n\r\n if (undefined !== tree.contentRange) {\r\n builder.setSymbology(ColorDef.red, ColorDef.red, 1, LinePixels.Solid);\r\n builder.addRangeBox(tree.contentRange);\r\n }\r\n\r\n context.addDecorationFromBuilder(builder);\r\n }\r\n\r\n public static toggle(enabled?: boolean): void {\r\n const instance = TreeDecoration._instance;\r\n if (undefined !== enabled && (undefined !== instance) === enabled)\r\n return;\r\n\r\n if (undefined === instance) {\r\n TreeDecoration._instance = new TreeDecoration();\r\n } else {\r\n instance.stop();\r\n TreeDecoration._instance = undefined;\r\n }\r\n }\r\n}\r\n\r\n/** Display in every viewport a green range graphic for each displayed tile tree, plus a red range graphic for each tile tree's content range if defined.\r\n * @beta\r\n */\r\nexport class ToggleTileTreeBoundsDecorationTool extends Tool {\r\n public static override toolId = \"ToggleTileTreeBoundsDecoration\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n public override async run(enable?: boolean): Promise<boolean> {\r\n TreeDecoration.toggle(enable);\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n const enable = parseToggle(args[0]);\r\n if (typeof enable !== \"string\")\r\n await this.run(enable);\r\n\r\n return true;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"TileTreeBoundsDecoration.js","sourceRoot":"","sources":["../../../src/tools/TileTreeBoundsDecoration.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\n/** @packageDocumentation\n * @module Tools\n */\n\nimport { ColorDef, LinePixels } from \"@itwin/core-common\";\nimport { DecorateContext, GraphicType, IModelApp, TileTreeReference, Tool } from \"@itwin/core-frontend\";\nimport { parseToggle } from \"./parseToggle\";\n\nclass TreeDecoration {\n private static _instance?: TreeDecoration;\n private _removeMe?: () => void;\n\n private constructor() {\n this._removeMe = IModelApp.viewManager.addDecorator(this);\n }\n\n private stop() {\n if (this._removeMe) {\n this._removeMe();\n this._removeMe = undefined;\n }\n }\n\n /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */\n public readonly useCachedDecorations = true;\n\n public decorate(context: DecorateContext): void {\n for (const ref of context.viewport.getTileTreeRefs()) {\n this.drawBoundingBox(ref, context);\n }\n }\n\n private drawBoundingBox(ref: TileTreeReference, context: DecorateContext): void {\n const tree = ref.treeOwner.tileTree;\n const location = ref.getLocation();\n if (undefined === location || undefined === tree || tree.isContentUnbounded || tree.range.isNull)\n return;\n\n const builder = context.createGraphicBuilder(GraphicType.WorldDecoration, location);\n builder.setSymbology(ColorDef.green, ColorDef.green, 1, LinePixels.Solid);\n builder.addRangeBox(tree.range);\n\n if (undefined !== tree.contentRange) {\n builder.setSymbology(ColorDef.red, ColorDef.red, 1, LinePixels.Solid);\n builder.addRangeBox(tree.contentRange);\n }\n\n context.addDecorationFromBuilder(builder);\n }\n\n public static toggle(enabled?: boolean): void {\n const instance = TreeDecoration._instance;\n if (undefined !== enabled && (undefined !== instance) === enabled)\n return;\n\n if (undefined === instance) {\n TreeDecoration._instance = new TreeDecoration();\n } else {\n instance.stop();\n TreeDecoration._instance = undefined;\n }\n }\n}\n\n/** Display in every viewport a green range graphic for each displayed tile tree, plus a red range graphic for each tile tree's content range if defined.\n * @beta\n */\nexport class ToggleTileTreeBoundsDecorationTool extends Tool {\n public static override toolId = \"ToggleTileTreeBoundsDecoration\";\n public static override get minArgs() { return 0; }\n public static override get maxArgs() { return 1; }\n\n public override async run(enable?: boolean): Promise<boolean> {\n TreeDecoration.toggle(enable);\n return true;\n }\n\n public override async parseAndRun(...args: string[]): Promise<boolean> {\n const enable = parseToggle(args[0]);\n if (typeof enable !== \"string\")\n await this.run(enable);\n\n return true;\n }\n}\n"]}
@@ -14,6 +14,7 @@ const parseToggle_1 = require("./parseToggle");
14
14
  * @internal
15
15
  */
16
16
  class DebugToolTipProvider {
17
+ static _instance;
17
18
  async augmentToolTip(hit, tooltipPromise) {
18
19
  // discard and overwrite
19
20
  await tooltipPromise;
@@ -49,6 +50,7 @@ class DebugToolTipProvider {
49
50
  * @beta
50
51
  */
51
52
  class ToggleToolTipsTool extends core_frontend_1.Tool {
53
+ static toolId = "ToggleToolTips";
52
54
  static get minArgs() { return 0; }
53
55
  static get maxArgs() { return 1; }
54
56
  async run(enable) {
@@ -63,5 +65,4 @@ class ToggleToolTipsTool extends core_frontend_1.Tool {
63
65
  }
64
66
  }
65
67
  exports.ToggleToolTipsTool = ToggleToolTipsTool;
66
- ToggleToolTipsTool.toolId = "ToggleToolTips";
67
68
  //# sourceMappingURL=ToolTipProvider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ToolTipProvider.js","sourceRoot":"","sources":["../../../src/tools/ToolTipProvider.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F;;GAEG;AAEH,wDAAmF;AACnF,+CAA4C;AAE5C;;GAEG;AACH,MAAM,oBAAoB;IAGjB,KAAK,CAAC,cAAc,CAAC,GAAc,EAAE,cAA6C;QACvF,wBAAwB;QACxB,MAAM,cAAc,CAAC;QAErB,MAAM,IAAI,GAAG,CAAC,UAAU,EAAE,SAAS,EAAE,eAAe,EAAE,QAAQ,EAAE,eAAe,CAAkC,CAAC;QAClH,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;YACvB,IAAI,SAAS,KAAK,KAAK;gBACrB,SAAS;YAEX,IAAI,GAAG,GAAG,IAAI,GAAG,GAAG,KAAK,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC;QAClD,CAAC;QAED,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;QACrB,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,MAAM,CAAC,UAAU,CAAC,OAA4B;QACnD,IAAI,SAAS,KAAK,OAAO;YACvB,OAAO,GAAG,SAAS,KAAK,IAAI,CAAC,SAAS,CAAC;QAEzC,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,SAAS,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjC,IAAI,CAAC,SAAS,GAAG,IAAI,oBAAoB,EAAE,CAAC;gBAC5C,yBAAS,CAAC,WAAW,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;aAAM,IAAI,SAAS,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;YACxC,yBAAS,CAAC,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC1D,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC7B,CAAC;IACH,CAAC;CACF;AAED;;;GAGG;AACH,MAAa,kBAAmB,SAAQ,oBAAI;IAEnC,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAElC,KAAK,CAAC,GAAG,CAAC,MAAgB;QACxC,oBAAoB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxC,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,WAAW,CAAC,GAAG,IAAc;QACjD,MAAM,MAAM,GAAG,IAAA,yBAAW,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,OAAO,MAAM,KAAK,QAAQ;YAC5B,MAAM,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAEzB,OAAO,IAAI,CAAC;IACd,CAAC;;AAhBH,gDAiBC;AAhBwB,yBAAM,GAAG,gBAAgB,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module Tools\r\n */\r\n\r\nimport { HitDetail, IModelApp, Tool, ToolTipProvider } from \"@itwin/core-frontend\";\r\nimport { parseToggle } from \"./parseToggle\";\r\n\r\n/** Augments tooltips with detailed information useful for debugging.\r\n * @internal\r\n */\r\nclass DebugToolTipProvider implements ToolTipProvider {\r\n private static _instance?: DebugToolTipProvider;\r\n\r\n public async augmentToolTip(hit: HitDetail, tooltipPromise: Promise<HTMLElement | string>): Promise<HTMLElement | string> {\r\n // discard and overwrite\r\n await tooltipPromise;\r\n\r\n const keys = [\"sourceId\", \"modelId\", \"subCategoryId\", \"tileId\", \"geometryClass\"] satisfies Array<keyof HitDetail>;\r\n let html = \"\";\r\n for (const key of keys) {\r\n const value = hit[key];\r\n if (undefined === value)\r\n continue;\r\n\r\n html = `${html + key}: ${value.toString()}<br>`;\r\n }\r\n\r\n const div = document.createElement(\"div\");\r\n div.innerHTML = html;\r\n return div;\r\n }\r\n\r\n public static setEnabled(enabled: boolean | undefined): void {\r\n if (undefined === enabled)\r\n enabled = undefined === this._instance;\r\n\r\n if (enabled) {\r\n if (undefined === this._instance) {\r\n this._instance = new DebugToolTipProvider();\r\n IModelApp.viewManager.addToolTipProvider(this._instance);\r\n }\r\n } else if (undefined !== this._instance) {\r\n IModelApp.viewManager.dropToolTipProvider(this._instance);\r\n this._instance = undefined;\r\n }\r\n }\r\n}\r\n\r\n/** Replaces the default tooltips displayed when mousing over elements to instead display information useful for debugging, including\r\n * element, model, subcategory, and tile Ids as well as geometry class.\r\n * @beta\r\n */\r\nexport class ToggleToolTipsTool extends Tool {\r\n public static override toolId = \"ToggleToolTips\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n public override async run(enable?: boolean): Promise<boolean> {\r\n DebugToolTipProvider.setEnabled(enable);\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n const enable = parseToggle(args[0]);\r\n if (typeof enable !== \"string\")\r\n await this.run(enable);\r\n\r\n return true;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"ToolTipProvider.js","sourceRoot":"","sources":["../../../src/tools/ToolTipProvider.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F;;GAEG;AAEH,wDAAmF;AACnF,+CAA4C;AAE5C;;GAEG;AACH,MAAM,oBAAoB;IAChB,MAAM,CAAC,SAAS,CAAwB;IAEzC,KAAK,CAAC,cAAc,CAAC,GAAc,EAAE,cAA6C;QACvF,wBAAwB;QACxB,MAAM,cAAc,CAAC;QAErB,MAAM,IAAI,GAAG,CAAC,UAAU,EAAE,SAAS,EAAE,eAAe,EAAE,QAAQ,EAAE,eAAe,CAAkC,CAAC;QAClH,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;YACvB,IAAI,SAAS,KAAK,KAAK;gBACrB,SAAS;YAEX,IAAI,GAAG,GAAG,IAAI,GAAG,GAAG,KAAK,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC;QAClD,CAAC;QAED,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;QACrB,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,MAAM,CAAC,UAAU,CAAC,OAA4B;QACnD,IAAI,SAAS,KAAK,OAAO;YACvB,OAAO,GAAG,SAAS,KAAK,IAAI,CAAC,SAAS,CAAC;QAEzC,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,SAAS,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjC,IAAI,CAAC,SAAS,GAAG,IAAI,oBAAoB,EAAE,CAAC;gBAC5C,yBAAS,CAAC,WAAW,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;aAAM,IAAI,SAAS,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;YACxC,yBAAS,CAAC,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC1D,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC7B,CAAC;IACH,CAAC;CACF;AAED;;;GAGG;AACH,MAAa,kBAAmB,SAAQ,oBAAI;IACnC,MAAM,CAAU,MAAM,GAAG,gBAAgB,CAAC;IAC1C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAElC,KAAK,CAAC,GAAG,CAAC,MAAgB;QACxC,oBAAoB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxC,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,WAAW,CAAC,GAAG,IAAc;QACjD,MAAM,MAAM,GAAG,IAAA,yBAAW,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,OAAO,MAAM,KAAK,QAAQ;YAC5B,MAAM,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAEzB,OAAO,IAAI,CAAC;IACd,CAAC;;AAhBH,gDAiBC","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\n/** @packageDocumentation\n * @module Tools\n */\n\nimport { HitDetail, IModelApp, Tool, ToolTipProvider } from \"@itwin/core-frontend\";\nimport { parseToggle } from \"./parseToggle\";\n\n/** Augments tooltips with detailed information useful for debugging.\n * @internal\n */\nclass DebugToolTipProvider implements ToolTipProvider {\n private static _instance?: DebugToolTipProvider;\n\n public async augmentToolTip(hit: HitDetail, tooltipPromise: Promise<HTMLElement | string>): Promise<HTMLElement | string> {\n // discard and overwrite\n await tooltipPromise;\n\n const keys = [\"sourceId\", \"modelId\", \"subCategoryId\", \"tileId\", \"geometryClass\"] satisfies Array<keyof HitDetail>;\n let html = \"\";\n for (const key of keys) {\n const value = hit[key];\n if (undefined === value)\n continue;\n\n html = `${html + key}: ${value.toString()}<br>`;\n }\n\n const div = document.createElement(\"div\");\n div.innerHTML = html;\n return div;\n }\n\n public static setEnabled(enabled: boolean | undefined): void {\n if (undefined === enabled)\n enabled = undefined === this._instance;\n\n if (enabled) {\n if (undefined === this._instance) {\n this._instance = new DebugToolTipProvider();\n IModelApp.viewManager.addToolTipProvider(this._instance);\n }\n } else if (undefined !== this._instance) {\n IModelApp.viewManager.dropToolTipProvider(this._instance);\n this._instance = undefined;\n }\n }\n}\n\n/** Replaces the default tooltips displayed when mousing over elements to instead display information useful for debugging, including\n * element, model, subcategory, and tile Ids as well as geometry class.\n * @beta\n */\nexport class ToggleToolTipsTool extends Tool {\n public static override toolId = \"ToggleToolTips\";\n public static override get minArgs() { return 0; }\n public static override get maxArgs() { return 1; }\n\n public override async run(enable?: boolean): Promise<boolean> {\n DebugToolTipProvider.setEnabled(enable);\n return true;\n }\n\n public override async parseAndRun(...args: string[]): Promise<boolean> {\n const enable = parseToggle(args[0]);\n if (typeof enable !== \"string\")\n await this.run(enable);\n\n return true;\n }\n}\n"]}
@@ -37,6 +37,7 @@ exports.ViewportToggleTool = ViewportToggleTool;
37
37
  * @beta
38
38
  */
39
39
  class FreezeSceneTool extends ViewportToggleTool {
40
+ static toolId = "FreezeScene";
40
41
  async toggle(vp, enable) {
41
42
  if (undefined === enable || enable !== vp.freezeScene)
42
43
  vp.freezeScene = !vp.freezeScene;
@@ -44,7 +45,6 @@ class FreezeSceneTool extends ViewportToggleTool {
44
45
  }
45
46
  }
46
47
  exports.FreezeSceneTool = FreezeSceneTool;
47
- FreezeSceneTool.toolId = "FreezeScene";
48
48
  const boundingVolumeNames = [
49
49
  "none",
50
50
  "volume",
@@ -60,6 +60,7 @@ const boundingVolumeNames = [
60
60
  * @beta
61
61
  */
62
62
  class ShowTileVolumesTool extends core_frontend_1.Tool {
63
+ static toolId = "ShowTileVolumes";
63
64
  static get minArgs() { return 0; }
64
65
  static get maxArgs() { return 1; }
65
66
  async run(boxes) {
@@ -88,15 +89,18 @@ class ShowTileVolumesTool extends core_frontend_1.Tool {
88
89
  }
89
90
  }
90
91
  exports.ShowTileVolumesTool = ShowTileVolumesTool;
91
- ShowTileVolumesTool.toolId = "ShowTileVolumes";
92
92
  /** Sets or unsets or flips the deactivated state of one or more tile tree references within the selected viewport.
93
93
  * Deactivated tile tree references are omitted from the scene.
94
94
  * This is useful for isolating particular tile trees or tiles for debugging.
95
95
  * @beta
96
96
  */
97
97
  class ToggleTileTreeReferencesTool extends core_frontend_1.Tool {
98
+ static toolId = "ToggleTileTreeReferences";
98
99
  static get minArgs() { return 1; }
99
100
  static get maxArgs() { return 3; }
101
+ _modelIds;
102
+ _which;
103
+ _deactivate;
100
104
  async parseAndRun(...args) {
101
105
  const which = args[0].toLowerCase();
102
106
  switch (which) {
@@ -133,11 +137,11 @@ class ToggleTileTreeReferencesTool extends core_frontend_1.Tool {
133
137
  }
134
138
  }
135
139
  exports.ToggleTileTreeReferencesTool = ToggleTileTreeReferencesTool;
136
- ToggleTileTreeReferencesTool.toolId = "ToggleTileTreeReferences";
137
140
  /** This tool sets the aspect ratio skew for the selected viewport.
138
141
  * @beta
139
142
  */
140
143
  class SetAspectRatioSkewTool extends core_frontend_1.Tool {
144
+ static toolId = "SetAspectRatioSkew";
141
145
  static get minArgs() { return 0; }
142
146
  static get maxArgs() { return 1; }
143
147
  /** This method runs the tool, setting the aspect ratio skew for the selected viewport.
@@ -163,13 +167,13 @@ class SetAspectRatioSkewTool extends core_frontend_1.Tool {
163
167
  }
164
168
  }
165
169
  exports.SetAspectRatioSkewTool = SetAspectRatioSkewTool;
166
- SetAspectRatioSkewTool.toolId = "SetAspectRatioSkew";
167
170
  /** Changes the [ModelSubCategoryHiliteMode]($frontend) for the [HiliteSet]($frontend) associated with the selected Viewport.
168
171
  * @beta
169
172
  */
170
173
  class ChangeHiliteModeTool extends core_frontend_1.Tool {
171
174
  static get minArgs() { return 1; }
172
175
  static get maxArgs() { return 1; }
176
+ static toolId = "ChangeHiliteMode";
173
177
  async run(mode) {
174
178
  const hilites = core_frontend_1.IModelApp.viewManager.selectedView?.iModel.hilited;
175
179
  if (!hilites)
@@ -183,7 +187,6 @@ class ChangeHiliteModeTool extends core_frontend_1.Tool {
183
187
  }
184
188
  }
185
189
  exports.ChangeHiliteModeTool = ChangeHiliteModeTool;
186
- ChangeHiliteModeTool.toolId = "ChangeHiliteMode";
187
190
  /** Changes the selected viewport's hilite or emphasis settings.
188
191
  * @beta
189
192
  */
@@ -245,17 +248,18 @@ exports.ChangeHiliteTool = ChangeHiliteTool;
245
248
  * @beta
246
249
  */
247
250
  class ChangeHiliteSettingsTool extends ChangeHiliteTool {
251
+ static toolId = "ChangeHiliteSettings";
248
252
  getCurrentSettings(vp) { return vp.hilite; }
249
253
  apply(vp, settings) {
250
254
  vp.hilite = undefined !== settings ? settings : new core_common_1.Hilite.Settings();
251
255
  }
252
256
  }
253
257
  exports.ChangeHiliteSettingsTool = ChangeHiliteSettingsTool;
254
- ChangeHiliteSettingsTool.toolId = "ChangeHiliteSettings";
255
258
  /** Changes the selected viewport's emphasis settings.
256
259
  * @beta
257
260
  */
258
261
  class ChangeEmphasisSettingsTool extends ChangeHiliteTool {
262
+ static toolId = "ChangeEmphasisSettings";
259
263
  getCurrentSettings(vp) { return vp.emphasisSettings; }
260
264
  apply(vp, settings) {
261
265
  if (undefined !== settings)
@@ -263,11 +267,11 @@ class ChangeEmphasisSettingsTool extends ChangeHiliteTool {
263
267
  }
264
268
  }
265
269
  exports.ChangeEmphasisSettingsTool = ChangeEmphasisSettingsTool;
266
- ChangeEmphasisSettingsTool.toolId = "ChangeEmphasisSettings";
267
270
  /** Changes the [FlashSettings]($frontend) for the selected [Viewport]($frontend).
268
271
  * @beta
269
272
  */
270
273
  class ChangeFlashSettingsTool extends core_frontend_1.Tool {
274
+ static toolId = "ChangeFlashSettings";
271
275
  static get minArgs() { return 0; }
272
276
  static get maxArgs() { return 3; }
273
277
  async run(settings) {
@@ -307,11 +311,11 @@ class ChangeFlashSettingsTool extends core_frontend_1.Tool {
307
311
  }
308
312
  }
309
313
  exports.ChangeFlashSettingsTool = ChangeFlashSettingsTool;
310
- ChangeFlashSettingsTool.toolId = "ChangeFlashSettings";
311
314
  /** Enables or disables fade-out transparency mode for the selected viewport.
312
315
  * @beta
313
316
  */
314
317
  class FadeOutTool extends ViewportToggleTool {
318
+ static toolId = "FadeOut";
315
319
  async toggle(vp, enable) {
316
320
  if (undefined === enable || enable !== vp.isFadeOutActive)
317
321
  vp.isFadeOutActive = !vp.isFadeOutActive;
@@ -319,11 +323,11 @@ class FadeOutTool extends ViewportToggleTool {
319
323
  }
320
324
  }
321
325
  exports.FadeOutTool = FadeOutTool;
322
- FadeOutTool.toolId = "FadeOut";
323
326
  /** Sets the default tile size modifier used for all viewports that don't explicitly override it.
324
327
  * @beta
325
328
  */
326
329
  class DefaultTileSizeModifierTool extends core_frontend_1.Tool {
330
+ static toolId = "DefaultTileSizeMod";
327
331
  static get minArgs() { return 1; }
328
332
  static get maxArgs() { return 1; }
329
333
  /** This method runs the tool, setting the default tile size modifier used for all viewports that don't explicitly override it.
@@ -342,11 +346,11 @@ class DefaultTileSizeModifierTool extends core_frontend_1.Tool {
342
346
  }
343
347
  }
344
348
  exports.DefaultTileSizeModifierTool = DefaultTileSizeModifierTool;
345
- DefaultTileSizeModifierTool.toolId = "DefaultTileSizeMod";
346
349
  /** Sets or clears the tile size modifier override for the selected viewport.
347
350
  * @beta
348
351
  */
349
352
  class ViewportTileSizeModifierTool extends core_frontend_1.Tool {
353
+ static toolId = "ViewportTileSizeMod";
350
354
  static get minArgs() { return 1; }
351
355
  static get maxArgs() { return 1; }
352
356
  /** This method runs the tool, setting the tile size modifier used for the selected viewport.
@@ -368,11 +372,11 @@ class ViewportTileSizeModifierTool extends core_frontend_1.Tool {
368
372
  }
369
373
  }
370
374
  exports.ViewportTileSizeModifierTool = ViewportTileSizeModifierTool;
371
- ViewportTileSizeModifierTool.toolId = "ViewportTileSizeMod";
372
375
  /** This tool adds a reality model to the viewport.
373
376
  * @beta
374
377
  */
375
378
  class ViewportAddRealityModel extends core_frontend_1.Tool {
379
+ static toolId = "ViewportAddRealityModel";
376
380
  static get minArgs() { return 1; }
377
381
  static get maxArgs() { return 1; }
378
382
  /** This method runs the tool, adding a reality model to the viewport
@@ -392,11 +396,11 @@ class ViewportAddRealityModel extends core_frontend_1.Tool {
392
396
  }
393
397
  }
394
398
  exports.ViewportAddRealityModel = ViewportAddRealityModel;
395
- ViewportAddRealityModel.toolId = "ViewportAddRealityModel";
396
399
  /** Changes the `allow3dManipulations` flag for the selected viewport if the viewport is displaying a `ViewState3d`.
397
400
  * @beta
398
401
  */
399
402
  class Toggle3dManipulationsTool extends ViewportToggleTool {
403
+ static toolId = "Toggle3dManipulations";
400
404
  async toggle(vp, allow) {
401
405
  if (!vp.view.is3d())
402
406
  return Promise.resolve();
@@ -411,11 +415,11 @@ class Toggle3dManipulationsTool extends ViewportToggleTool {
411
415
  }
412
416
  }
413
417
  exports.Toggle3dManipulationsTool = Toggle3dManipulationsTool;
414
- Toggle3dManipulationsTool.toolId = "Toggle3dManipulations";
415
418
  /** Toggles display of view attachments in sheet views.
416
419
  * @beta
417
420
  */
418
421
  class ToggleViewAttachmentsTool extends ViewportToggleTool {
422
+ static toolId = "ToggleViewAttachments";
419
423
  async toggle(vp, enable) {
420
424
  if (undefined === enable || enable !== vp.wantViewAttachments)
421
425
  vp.wantViewAttachments = !vp.wantViewAttachments;
@@ -423,11 +427,11 @@ class ToggleViewAttachmentsTool extends ViewportToggleTool {
423
427
  }
424
428
  }
425
429
  exports.ToggleViewAttachmentsTool = ToggleViewAttachmentsTool;
426
- ToggleViewAttachmentsTool.toolId = "ToggleViewAttachments";
427
430
  /** Toggle display of view attachment boundaries in sheet views.
428
431
  * @beta
429
432
  */
430
433
  class ToggleViewAttachmentBoundariesTool extends ViewportToggleTool {
434
+ static toolId = "ToggleViewAttachmentBoundaries";
431
435
  async toggle(vp, enable) {
432
436
  if (undefined === enable || enable !== vp.wantViewAttachmentBoundaries)
433
437
  vp.wantViewAttachmentBoundaries = !vp.wantViewAttachmentBoundaries;
@@ -435,11 +439,11 @@ class ToggleViewAttachmentBoundariesTool extends ViewportToggleTool {
435
439
  }
436
440
  }
437
441
  exports.ToggleViewAttachmentBoundariesTool = ToggleViewAttachmentBoundariesTool;
438
- ToggleViewAttachmentBoundariesTool.toolId = "ToggleViewAttachmentBoundaries";
439
442
  /** Toggle display of view attachment clip shapes in sheet views.
440
443
  * @beta
441
444
  */
442
445
  class ToggleViewAttachmentClipShapesTool extends ViewportToggleTool {
446
+ static toolId = "ToggleViewAttachmentClipShapes";
443
447
  async toggle(vp, enable) {
444
448
  if (undefined === enable || enable !== vp.wantViewAttachmentClipShapes)
445
449
  vp.wantViewAttachmentClipShapes = !vp.wantViewAttachmentClipShapes;
@@ -447,11 +451,11 @@ class ToggleViewAttachmentClipShapesTool extends ViewportToggleTool {
447
451
  }
448
452
  }
449
453
  exports.ToggleViewAttachmentClipShapesTool = ToggleViewAttachmentClipShapesTool;
450
- ToggleViewAttachmentClipShapesTool.toolId = "ToggleViewAttachmentClipShapes";
451
454
  /** Toggles display of 2d graphics in a [DrawingViewState]($frontend). This setting affects all drawing views until it is reset.
452
455
  * @beta
453
456
  */
454
457
  class ToggleDrawingGraphicsTool extends ViewportToggleTool {
458
+ static toolId = "ToggleDrawingGraphics";
455
459
  async toggle(vp, enable) {
456
460
  if (undefined === enable || enable !== core_frontend_1.DrawingViewState.hideDrawingGraphics) {
457
461
  core_frontend_1.DrawingViewState.hideDrawingGraphics = !core_frontend_1.DrawingViewState.hideDrawingGraphics;
@@ -461,12 +465,12 @@ class ToggleDrawingGraphicsTool extends ViewportToggleTool {
461
465
  }
462
466
  }
463
467
  exports.ToggleDrawingGraphicsTool = ToggleDrawingGraphicsTool;
464
- ToggleDrawingGraphicsTool.toolId = "ToggleDrawingGraphics";
465
468
  /** Toggles whether a [SectionDrawing]($backend)'s spatial view is always displayed along with the 2d graphics by a [DrawingViewState]($frontend), even
466
469
  * if it otherwise would not be. This setting affects all section drawing views until it is reset.
467
470
  * @beta
468
471
  */
469
472
  class ToggleSectionDrawingSpatialViewTool extends ViewportToggleTool {
473
+ static toolId = "ToggleSectionDrawingSpatialView";
470
474
  async toggle(vp, enable) {
471
475
  if (undefined === enable || enable !== core_frontend_1.DrawingViewState.alwaysDisplaySpatialView) {
472
476
  core_frontend_1.DrawingViewState.alwaysDisplaySpatialView = !core_frontend_1.DrawingViewState.alwaysDisplaySpatialView;
@@ -481,13 +485,13 @@ class ToggleSectionDrawingSpatialViewTool extends ViewportToggleTool {
481
485
  }
482
486
  }
483
487
  exports.ToggleSectionDrawingSpatialViewTool = ToggleSectionDrawingSpatialViewTool;
484
- ToggleSectionDrawingSpatialViewTool.toolId = "ToggleSectionDrawingSpatialView";
485
488
  /** Change the camera settings of the selected viewport.
486
489
  * @beta
487
490
  */
488
491
  class ChangeCameraTool extends core_frontend_1.Tool {
489
492
  static get minArgs() { return 1; }
490
493
  static get maxArgs() { return 2; }
494
+ static toolId = "ChangeCamera";
491
495
  async run(camera) {
492
496
  const vp = core_frontend_1.IModelApp.viewManager.selectedView;
493
497
  if (camera && vp && vp.view.is3d()) {
@@ -513,5 +517,4 @@ class ChangeCameraTool extends core_frontend_1.Tool {
513
517
  }
514
518
  }
515
519
  exports.ChangeCameraTool = ChangeCameraTool;
516
- ChangeCameraTool.toolId = "ChangeCamera";
517
520
  //# sourceMappingURL=ViewportTools.js.map