@itwin/frontend-devtools 5.0.0-dev.3 → 5.0.0-dev.34

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 (199) hide show
  1. package/CHANGELOG.md +16 -1
  2. package/lib/cjs/ClipboardUtilities.js.map +1 -1
  3. package/lib/cjs/FrontEndDevTools.js +1 -1
  4. package/lib/cjs/FrontEndDevTools.js.map +1 -1
  5. package/lib/cjs/effects/Convolution.js +23 -23
  6. package/lib/cjs/effects/Convolution.js.map +1 -1
  7. package/lib/cjs/effects/EffectTools.js +2 -2
  8. package/lib/cjs/effects/EffectTools.js.map +1 -1
  9. package/lib/cjs/effects/Explosion.js +2 -2
  10. package/lib/cjs/effects/Explosion.js.map +1 -1
  11. package/lib/cjs/effects/FlipImage.js +22 -22
  12. package/lib/cjs/effects/FlipImage.js.map +1 -1
  13. package/lib/cjs/effects/LensDistortion.js +25 -25
  14. package/lib/cjs/effects/LensDistortion.js.map +1 -1
  15. package/lib/cjs/effects/Random.js.map +1 -1
  16. package/lib/cjs/effects/Saturation.js +30 -30
  17. package/lib/cjs/effects/Saturation.js.map +1 -1
  18. package/lib/cjs/effects/Snow.js +2 -2
  19. package/lib/cjs/effects/Snow.js.map +1 -1
  20. package/lib/cjs/effects/Vignette.js +41 -41
  21. package/lib/cjs/effects/Vignette.js.map +1 -1
  22. package/lib/cjs/frontend-devtools.js.map +1 -1
  23. package/lib/cjs/tools/AnimationIntervalTool.js +1 -1
  24. package/lib/cjs/tools/AnimationIntervalTool.js.map +1 -1
  25. package/lib/cjs/tools/ChangeUnitsTool.js +1 -1
  26. package/lib/cjs/tools/ChangeUnitsTool.js.map +1 -1
  27. package/lib/cjs/tools/ClipTools.js +4 -4
  28. package/lib/cjs/tools/ClipTools.js.map +1 -1
  29. package/lib/cjs/tools/DisplayStyleTools.js +10 -10
  30. package/lib/cjs/tools/DisplayStyleTools.js.map +1 -1
  31. package/lib/cjs/tools/EmphasizeElementsTool.js +5 -5
  32. package/lib/cjs/tools/EmphasizeElementsTool.js.map +1 -1
  33. package/lib/cjs/tools/FrustumDecoration.js +3 -3
  34. package/lib/cjs/tools/FrustumDecoration.js.map +1 -1
  35. package/lib/cjs/tools/InspectElementTool.js +1 -1
  36. package/lib/cjs/tools/InspectElementTool.js.map +1 -1
  37. package/lib/cjs/tools/MapLayerTool.js +20 -20
  38. package/lib/cjs/tools/MapLayerTool.js.map +1 -1
  39. package/lib/cjs/tools/MeasureTileLoadTime.js +1 -1
  40. package/lib/cjs/tools/MeasureTileLoadTime.js.map +1 -1
  41. package/lib/cjs/tools/ModelAppearanceTools.js +9 -9
  42. package/lib/cjs/tools/ModelAppearanceTools.js.map +1 -1
  43. package/lib/cjs/tools/PlanProjectionTools.js +3 -3
  44. package/lib/cjs/tools/PlanProjectionTools.js.map +1 -1
  45. package/lib/cjs/tools/PlanarMaskTools.js +13 -13
  46. package/lib/cjs/tools/PlanarMaskTools.js.map +1 -1
  47. package/lib/cjs/tools/ProjectExtents.js +1 -1
  48. package/lib/cjs/tools/ProjectExtents.js.map +1 -1
  49. package/lib/cjs/tools/RealityModelTools.js +10 -10
  50. package/lib/cjs/tools/RealityModelTools.js.map +1 -1
  51. package/lib/cjs/tools/RealityTransitionTool.js +1 -1
  52. package/lib/cjs/tools/RealityTransitionTool.js.map +1 -1
  53. package/lib/cjs/tools/RenderSystemTools.js +3 -3
  54. package/lib/cjs/tools/RenderSystemTools.js.map +1 -1
  55. package/lib/cjs/tools/RenderTargetTools.js +11 -11
  56. package/lib/cjs/tools/RenderTargetTools.js.map +1 -1
  57. package/lib/cjs/tools/ReportWebGLCompatibilityTool.js +1 -1
  58. package/lib/cjs/tools/ReportWebGLCompatibilityTool.js.map +1 -1
  59. package/lib/cjs/tools/SavedViews.js +3 -3
  60. package/lib/cjs/tools/SavedViews.js.map +1 -1
  61. package/lib/cjs/tools/ScheduleScriptTools.js +3 -3
  62. package/lib/cjs/tools/ScheduleScriptTools.js.map +1 -1
  63. package/lib/cjs/tools/SelectionTools.js +2 -2
  64. package/lib/cjs/tools/SelectionTools.js.map +1 -1
  65. package/lib/cjs/tools/SetGpuMemoryLimitTool.js +1 -1
  66. package/lib/cjs/tools/SetGpuMemoryLimitTool.js.map +1 -1
  67. package/lib/cjs/tools/SourceAspectIdTools.js +2 -2
  68. package/lib/cjs/tools/SourceAspectIdTools.js.map +1 -1
  69. package/lib/cjs/tools/TileRequestDecoration.js +1 -1
  70. package/lib/cjs/tools/TileRequestDecoration.js.map +1 -1
  71. package/lib/cjs/tools/TileTreeBoundsDecoration.js +1 -1
  72. package/lib/cjs/tools/TileTreeBoundsDecoration.js.map +1 -1
  73. package/lib/cjs/tools/ToolTipProvider.js +1 -1
  74. package/lib/cjs/tools/ToolTipProvider.js.map +1 -1
  75. package/lib/cjs/tools/ViewportTools.js +19 -19
  76. package/lib/cjs/tools/ViewportTools.js.map +1 -1
  77. package/lib/cjs/tools/parseArgs.js.map +1 -1
  78. package/lib/cjs/tools/parseBoolean.js.map +1 -1
  79. package/lib/cjs/tools/parseToggle.js.map +1 -1
  80. package/lib/cjs/ui/Button.js.map +1 -1
  81. package/lib/cjs/ui/CheckBox.js.map +1 -1
  82. package/lib/cjs/ui/ColorInput.js.map +1 -1
  83. package/lib/cjs/ui/ComboBox.js.map +1 -1
  84. package/lib/cjs/ui/DataList.js.map +1 -1
  85. package/lib/cjs/ui/NestedMenu.js.map +1 -1
  86. package/lib/cjs/ui/NumericInput.js.map +1 -1
  87. package/lib/cjs/ui/RadioBox.js.map +1 -1
  88. package/lib/cjs/ui/Slider.js.map +1 -1
  89. package/lib/cjs/ui/TextBox.js.map +1 -1
  90. package/lib/cjs/widgets/DiagnosticsPanel.js.map +1 -1
  91. package/lib/cjs/widgets/FpsTracker.js.map +1 -1
  92. package/lib/cjs/widgets/GpuProfiler.js.map +1 -1
  93. package/lib/cjs/widgets/KeyinField.js.map +1 -1
  94. package/lib/cjs/widgets/MemoryTracker.js.map +1 -1
  95. package/lib/cjs/widgets/RenderCommandBreakdown.js.map +1 -1
  96. package/lib/cjs/widgets/TileMemoryBreakdown.js.map +1 -1
  97. package/lib/cjs/widgets/TileStatisticsTracker.js.map +1 -1
  98. package/lib/cjs/widgets/ToolSettingsTracker.js +1 -1
  99. package/lib/cjs/widgets/ToolSettingsTracker.js.map +1 -1
  100. package/lib/esm/ClipboardUtilities.js.map +1 -1
  101. package/lib/esm/FrontEndDevTools.js +1 -1
  102. package/lib/esm/FrontEndDevTools.js.map +1 -1
  103. package/lib/esm/effects/Convolution.js +23 -23
  104. package/lib/esm/effects/Convolution.js.map +1 -1
  105. package/lib/esm/effects/EffectTools.js +2 -2
  106. package/lib/esm/effects/EffectTools.js.map +1 -1
  107. package/lib/esm/effects/Explosion.js +2 -2
  108. package/lib/esm/effects/Explosion.js.map +1 -1
  109. package/lib/esm/effects/FlipImage.js +22 -22
  110. package/lib/esm/effects/FlipImage.js.map +1 -1
  111. package/lib/esm/effects/LensDistortion.js +25 -25
  112. package/lib/esm/effects/LensDistortion.js.map +1 -1
  113. package/lib/esm/effects/Random.js.map +1 -1
  114. package/lib/esm/effects/Saturation.js +30 -30
  115. package/lib/esm/effects/Saturation.js.map +1 -1
  116. package/lib/esm/effects/Snow.js +2 -2
  117. package/lib/esm/effects/Snow.js.map +1 -1
  118. package/lib/esm/effects/Vignette.js +41 -41
  119. package/lib/esm/effects/Vignette.js.map +1 -1
  120. package/lib/esm/frontend-devtools.js.map +1 -1
  121. package/lib/esm/tools/AnimationIntervalTool.js +1 -1
  122. package/lib/esm/tools/AnimationIntervalTool.js.map +1 -1
  123. package/lib/esm/tools/ChangeUnitsTool.js +1 -1
  124. package/lib/esm/tools/ChangeUnitsTool.js.map +1 -1
  125. package/lib/esm/tools/ClipTools.js +4 -4
  126. package/lib/esm/tools/ClipTools.js.map +1 -1
  127. package/lib/esm/tools/DisplayStyleTools.js +10 -10
  128. package/lib/esm/tools/DisplayStyleTools.js.map +1 -1
  129. package/lib/esm/tools/EmphasizeElementsTool.js +5 -5
  130. package/lib/esm/tools/EmphasizeElementsTool.js.map +1 -1
  131. package/lib/esm/tools/FrustumDecoration.js +3 -3
  132. package/lib/esm/tools/FrustumDecoration.js.map +1 -1
  133. package/lib/esm/tools/InspectElementTool.js +1 -1
  134. package/lib/esm/tools/InspectElementTool.js.map +1 -1
  135. package/lib/esm/tools/MapLayerTool.js +20 -20
  136. package/lib/esm/tools/MapLayerTool.js.map +1 -1
  137. package/lib/esm/tools/MeasureTileLoadTime.js +1 -1
  138. package/lib/esm/tools/MeasureTileLoadTime.js.map +1 -1
  139. package/lib/esm/tools/ModelAppearanceTools.js +9 -9
  140. package/lib/esm/tools/ModelAppearanceTools.js.map +1 -1
  141. package/lib/esm/tools/PlanProjectionTools.js +3 -3
  142. package/lib/esm/tools/PlanProjectionTools.js.map +1 -1
  143. package/lib/esm/tools/PlanarMaskTools.js +13 -13
  144. package/lib/esm/tools/PlanarMaskTools.js.map +1 -1
  145. package/lib/esm/tools/ProjectExtents.js +1 -1
  146. package/lib/esm/tools/ProjectExtents.js.map +1 -1
  147. package/lib/esm/tools/RealityModelTools.js +10 -10
  148. package/lib/esm/tools/RealityModelTools.js.map +1 -1
  149. package/lib/esm/tools/RealityTransitionTool.js +1 -1
  150. package/lib/esm/tools/RealityTransitionTool.js.map +1 -1
  151. package/lib/esm/tools/RenderSystemTools.js +3 -3
  152. package/lib/esm/tools/RenderSystemTools.js.map +1 -1
  153. package/lib/esm/tools/RenderTargetTools.js +11 -11
  154. package/lib/esm/tools/RenderTargetTools.js.map +1 -1
  155. package/lib/esm/tools/ReportWebGLCompatibilityTool.js +1 -1
  156. package/lib/esm/tools/ReportWebGLCompatibilityTool.js.map +1 -1
  157. package/lib/esm/tools/SavedViews.js +3 -3
  158. package/lib/esm/tools/SavedViews.js.map +1 -1
  159. package/lib/esm/tools/ScheduleScriptTools.js +3 -3
  160. package/lib/esm/tools/ScheduleScriptTools.js.map +1 -1
  161. package/lib/esm/tools/SelectionTools.js +2 -2
  162. package/lib/esm/tools/SelectionTools.js.map +1 -1
  163. package/lib/esm/tools/SetGpuMemoryLimitTool.js +1 -1
  164. package/lib/esm/tools/SetGpuMemoryLimitTool.js.map +1 -1
  165. package/lib/esm/tools/SourceAspectIdTools.js +2 -2
  166. package/lib/esm/tools/SourceAspectIdTools.js.map +1 -1
  167. package/lib/esm/tools/TileRequestDecoration.js +1 -1
  168. package/lib/esm/tools/TileRequestDecoration.js.map +1 -1
  169. package/lib/esm/tools/TileTreeBoundsDecoration.js +1 -1
  170. package/lib/esm/tools/TileTreeBoundsDecoration.js.map +1 -1
  171. package/lib/esm/tools/ToolTipProvider.js +1 -1
  172. package/lib/esm/tools/ToolTipProvider.js.map +1 -1
  173. package/lib/esm/tools/ViewportTools.js +19 -19
  174. package/lib/esm/tools/ViewportTools.js.map +1 -1
  175. package/lib/esm/tools/parseArgs.js.map +1 -1
  176. package/lib/esm/tools/parseBoolean.js.map +1 -1
  177. package/lib/esm/tools/parseToggle.js.map +1 -1
  178. package/lib/esm/ui/Button.js.map +1 -1
  179. package/lib/esm/ui/CheckBox.js.map +1 -1
  180. package/lib/esm/ui/ColorInput.js.map +1 -1
  181. package/lib/esm/ui/ComboBox.js.map +1 -1
  182. package/lib/esm/ui/DataList.js.map +1 -1
  183. package/lib/esm/ui/NestedMenu.js.map +1 -1
  184. package/lib/esm/ui/NumericInput.js.map +1 -1
  185. package/lib/esm/ui/RadioBox.js.map +1 -1
  186. package/lib/esm/ui/Slider.js.map +1 -1
  187. package/lib/esm/ui/TextBox.js.map +1 -1
  188. package/lib/esm/widgets/DiagnosticsPanel.js.map +1 -1
  189. package/lib/esm/widgets/FpsTracker.js.map +1 -1
  190. package/lib/esm/widgets/GpuProfiler.js.map +1 -1
  191. package/lib/esm/widgets/KeyinField.js.map +1 -1
  192. package/lib/esm/widgets/MemoryTracker.js.map +1 -1
  193. package/lib/esm/widgets/RenderCommandBreakdown.js.map +1 -1
  194. package/lib/esm/widgets/TileMemoryBreakdown.js.map +1 -1
  195. package/lib/esm/widgets/TileStatisticsTracker.js.map +1 -1
  196. package/lib/esm/widgets/ToolSettingsTracker.js +1 -1
  197. package/lib/esm/widgets/ToolSettingsTracker.js.map +1 -1
  198. package/lib/public/locales/en/FrontendDevTools.json +494 -494
  199. package/package.json +8 -8
@@ -1 +1 @@
1
- {"version":3,"file":"SetGpuMemoryLimitTool.js","sourceRoot":"","sources":["../../../src/tools/SetGpuMemoryLimitTool.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F;;GAEG;;;AAEH,wDAAuE;AAEvE;;;GAGG;AACH,MAAa,qBAAsB,SAAQ,oBAAI;IAEtC,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAElC,KAAK,CAAC,GAAG,CAAC,KAAsB;QAC9C,IAAI,SAAS,KAAK,KAAK,EAAE,CAAC;YACxB,yBAAS,CAAC,SAAS,CAAC,cAAc,GAAG,KAAK,CAAC;YAC3C,yBAAS,CAAC,oBAAoB,EAAE,CAAC;QACnC,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,WAAW,CAAC,GAAG,IAAc;QACjD,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9C,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAmB,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC5E,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;;AAlBH,sDAmBC;AAlBwB,4BAAM,GAAG,mBAAmB,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/** @packageDocumentation\r\n * @module Tools\r\n */\r\n\r\nimport { GpuMemoryLimit, IModelApp, Tool } from \"@itwin/core-frontend\";\r\n\r\n/** Adjust the value of [TileAdmin.gpuMemoryLimit]($frontend). This controls how much GPU memory is allowed to be consumed\r\n * by tile graphics before the system starts discarding the graphics for the least recently drawn tiles.\r\n * @beta\r\n */\r\nexport class SetGpuMemoryLimitTool extends Tool {\r\n public static override toolId = \"SetGpuMemoryLimit\";\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n public override async run(limit?: GpuMemoryLimit): Promise<boolean> {\r\n if (undefined !== limit) {\r\n IModelApp.tileAdmin.gpuMemoryLimit = limit;\r\n IModelApp.requestNextAnimation();\r\n }\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n const maxBytes = Number.parseInt(args[0], 10);\r\n const limit = Number.isNaN(maxBytes) ? args[0] as GpuMemoryLimit : maxBytes;\r\n return this.run(limit);\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"SetGpuMemoryLimitTool.js","sourceRoot":"","sources":["../../../src/tools/SetGpuMemoryLimitTool.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F;;GAEG;;;AAEH,wDAAuE;AAEvE;;;GAGG;AACH,MAAa,qBAAsB,SAAQ,oBAAI;aACtB,WAAM,GAAG,mBAAmB,CAAC;IAC7C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,MAAM,KAAc,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAElC,KAAK,CAAC,GAAG,CAAC,KAAsB;QAC9C,IAAI,SAAS,KAAK,KAAK,EAAE,CAAC;YACxB,yBAAS,CAAC,SAAS,CAAC,cAAc,GAAG,KAAK,CAAC;YAC3C,yBAAS,CAAC,oBAAoB,EAAE,CAAC;QACnC,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,WAAW,CAAC,GAAG,IAAc;QACjD,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9C,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAmB,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC5E,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;;AAlBH,sDAmBC","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/** @packageDocumentation\n * @module Tools\n */\n\nimport { GpuMemoryLimit, IModelApp, Tool } from \"@itwin/core-frontend\";\n\n/** Adjust the value of [TileAdmin.gpuMemoryLimit]($frontend). This controls how much GPU memory is allowed to be consumed\n * by tile graphics before the system starts discarding the graphics for the least recently drawn tiles.\n * @beta\n */\nexport class SetGpuMemoryLimitTool extends Tool {\n public static override toolId = \"SetGpuMemoryLimit\";\n public static override get minArgs() { return 1; }\n public static override get maxArgs() { return 1; }\n\n public override async run(limit?: GpuMemoryLimit): Promise<boolean> {\n if (undefined !== limit) {\n IModelApp.tileAdmin.gpuMemoryLimit = limit;\n IModelApp.requestNextAnimation();\n }\n\n return true;\n }\n\n public override async parseAndRun(...args: string[]): Promise<boolean> {\n const maxBytes = Number.parseInt(args[0], 10);\n const limit = Number.isNaN(maxBytes) ? args[0] as GpuMemoryLimit : maxBytes;\n return this.run(limit);\n }\n}\n"]}
@@ -61,12 +61,12 @@ exports.SourceAspectIdTool = SourceAspectIdTool;
61
61
  * @beta
62
62
  */
63
63
  class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {
64
+ static { this.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 { this.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;aAC9C,WAAM,GAAG,6BAA6B,CAAC;IAEpD,QAAQ,CAAC,OAAe;QAChC,OAAO,oFAAoF,OAAO,uBAAuB,CAAC;IAC5H,CAAC;;AALH,0EAMC;AAED;;;;;;;;GAQG;AACH,MAAa,+BAAgC,SAAQ,kBAAkB;aAC9C,WAAM,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"]}
@@ -64,6 +64,7 @@ class TileRequestDecoration {
64
64
  * @beta
65
65
  */
66
66
  class ToggleTileRequestDecorationTool extends core_frontend_1.Tool {
67
+ static { this.toolId = "ToggleTileRequestDecoration"; }
67
68
  static get minArgs() { return 0; }
68
69
  static get maxArgs() { return 1; }
69
70
  async run(enable) {
@@ -80,5 +81,4 @@ class ToggleTileRequestDecorationTool extends core_frontend_1.Tool {
80
81
  }
81
82
  }
82
83
  exports.ToggleTileRequestDecorationTool = ToggleTileRequestDecorationTool;
83
- ToggleTileRequestDecorationTool.toolId = "ToggleTileRequestDecoration";
84
84
  //# 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"]}
@@ -57,6 +57,7 @@ class TreeDecoration {
57
57
  * @beta
58
58
  */
59
59
  class ToggleTileTreeBoundsDecorationTool extends core_frontend_1.Tool {
60
+ static { this.toolId = "ToggleTileTreeBoundsDecoration"; }
60
61
  static get minArgs() { return 0; }
61
62
  static get maxArgs() { return 1; }
62
63
  async run(enable) {
@@ -71,5 +72,4 @@ class ToggleTileTreeBoundsDecorationTool extends core_frontend_1.Tool {
71
72
  }
72
73
  }
73
74
  exports.ToggleTileTreeBoundsDecorationTool = ToggleTileTreeBoundsDecorationTool;
74
- ToggleTileTreeBoundsDecorationTool.toolId = "ToggleTileTreeBoundsDecoration";
75
75
  //# 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 context.viewport.forEachTileTreeRef((ref) => this.drawBoundingBox(ref, context));\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"]}
@@ -49,6 +49,7 @@ class DebugToolTipProvider {
49
49
  * @beta
50
50
  */
51
51
  class ToggleToolTipsTool extends core_frontend_1.Tool {
52
+ static { this.toolId = "ToggleToolTips"; }
52
53
  static get minArgs() { return 0; }
53
54
  static get maxArgs() { return 1; }
54
55
  async run(enable) {
@@ -63,5 +64,4 @@ class ToggleToolTipsTool extends core_frontend_1.Tool {
63
64
  }
64
65
  }
65
66
  exports.ToggleToolTipsTool = ToggleToolTipsTool;
66
- ToggleToolTipsTool.toolId = "ToggleToolTips";
67
67
  //# 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;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;aACnB,WAAM,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 { this.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 { this.toolId = "ShowTileVolumes"; }
63
64
  static get minArgs() { return 0; }
64
65
  static get maxArgs() { return 1; }
65
66
  async run(boxes) {
@@ -88,13 +89,13 @@ 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 { this.toolId = "ToggleTileTreeReferences"; }
98
99
  static get minArgs() { return 1; }
99
100
  static get maxArgs() { return 3; }
100
101
  async parseAndRun(...args) {
@@ -133,11 +134,11 @@ class ToggleTileTreeReferencesTool extends core_frontend_1.Tool {
133
134
  }
134
135
  }
135
136
  exports.ToggleTileTreeReferencesTool = ToggleTileTreeReferencesTool;
136
- ToggleTileTreeReferencesTool.toolId = "ToggleTileTreeReferences";
137
137
  /** This tool sets the aspect ratio skew for the selected viewport.
138
138
  * @beta
139
139
  */
140
140
  class SetAspectRatioSkewTool extends core_frontend_1.Tool {
141
+ static { this.toolId = "SetAspectRatioSkew"; }
141
142
  static get minArgs() { return 0; }
142
143
  static get maxArgs() { return 1; }
143
144
  /** This method runs the tool, setting the aspect ratio skew for the selected viewport.
@@ -163,13 +164,13 @@ class SetAspectRatioSkewTool extends core_frontend_1.Tool {
163
164
  }
164
165
  }
165
166
  exports.SetAspectRatioSkewTool = SetAspectRatioSkewTool;
166
- SetAspectRatioSkewTool.toolId = "SetAspectRatioSkew";
167
167
  /** Changes the [ModelSubCategoryHiliteMode]($frontend) for the [HiliteSet]($frontend) associated with the selected Viewport.
168
168
  * @beta
169
169
  */
170
170
  class ChangeHiliteModeTool extends core_frontend_1.Tool {
171
171
  static get minArgs() { return 1; }
172
172
  static get maxArgs() { return 1; }
173
+ static { this.toolId = "ChangeHiliteMode"; }
173
174
  async run(mode) {
174
175
  const hilites = core_frontend_1.IModelApp.viewManager.selectedView?.iModel.hilited;
175
176
  if (!hilites)
@@ -183,7 +184,6 @@ class ChangeHiliteModeTool extends core_frontend_1.Tool {
183
184
  }
184
185
  }
185
186
  exports.ChangeHiliteModeTool = ChangeHiliteModeTool;
186
- ChangeHiliteModeTool.toolId = "ChangeHiliteMode";
187
187
  /** Changes the selected viewport's hilite or emphasis settings.
188
188
  * @beta
189
189
  */
@@ -245,17 +245,18 @@ exports.ChangeHiliteTool = ChangeHiliteTool;
245
245
  * @beta
246
246
  */
247
247
  class ChangeHiliteSettingsTool extends ChangeHiliteTool {
248
+ static { this.toolId = "ChangeHiliteSettings"; }
248
249
  getCurrentSettings(vp) { return vp.hilite; }
249
250
  apply(vp, settings) {
250
251
  vp.hilite = undefined !== settings ? settings : new core_common_1.Hilite.Settings();
251
252
  }
252
253
  }
253
254
  exports.ChangeHiliteSettingsTool = ChangeHiliteSettingsTool;
254
- ChangeHiliteSettingsTool.toolId = "ChangeHiliteSettings";
255
255
  /** Changes the selected viewport's emphasis settings.
256
256
  * @beta
257
257
  */
258
258
  class ChangeEmphasisSettingsTool extends ChangeHiliteTool {
259
+ static { this.toolId = "ChangeEmphasisSettings"; }
259
260
  getCurrentSettings(vp) { return vp.emphasisSettings; }
260
261
  apply(vp, settings) {
261
262
  if (undefined !== settings)
@@ -263,11 +264,11 @@ class ChangeEmphasisSettingsTool extends ChangeHiliteTool {
263
264
  }
264
265
  }
265
266
  exports.ChangeEmphasisSettingsTool = ChangeEmphasisSettingsTool;
266
- ChangeEmphasisSettingsTool.toolId = "ChangeEmphasisSettings";
267
267
  /** Changes the [FlashSettings]($frontend) for the selected [Viewport]($frontend).
268
268
  * @beta
269
269
  */
270
270
  class ChangeFlashSettingsTool extends core_frontend_1.Tool {
271
+ static { this.toolId = "ChangeFlashSettings"; }
271
272
  static get minArgs() { return 0; }
272
273
  static get maxArgs() { return 3; }
273
274
  async run(settings) {
@@ -307,11 +308,11 @@ class ChangeFlashSettingsTool extends core_frontend_1.Tool {
307
308
  }
308
309
  }
309
310
  exports.ChangeFlashSettingsTool = ChangeFlashSettingsTool;
310
- ChangeFlashSettingsTool.toolId = "ChangeFlashSettings";
311
311
  /** Enables or disables fade-out transparency mode for the selected viewport.
312
312
  * @beta
313
313
  */
314
314
  class FadeOutTool extends ViewportToggleTool {
315
+ static { this.toolId = "FadeOut"; }
315
316
  async toggle(vp, enable) {
316
317
  if (undefined === enable || enable !== vp.isFadeOutActive)
317
318
  vp.isFadeOutActive = !vp.isFadeOutActive;
@@ -319,11 +320,11 @@ class FadeOutTool extends ViewportToggleTool {
319
320
  }
320
321
  }
321
322
  exports.FadeOutTool = FadeOutTool;
322
- FadeOutTool.toolId = "FadeOut";
323
323
  /** Sets the default tile size modifier used for all viewports that don't explicitly override it.
324
324
  * @beta
325
325
  */
326
326
  class DefaultTileSizeModifierTool extends core_frontend_1.Tool {
327
+ static { this.toolId = "DefaultTileSizeMod"; }
327
328
  static get minArgs() { return 1; }
328
329
  static get maxArgs() { return 1; }
329
330
  /** This method runs the tool, setting the default tile size modifier used for all viewports that don't explicitly override it.
@@ -342,11 +343,11 @@ class DefaultTileSizeModifierTool extends core_frontend_1.Tool {
342
343
  }
343
344
  }
344
345
  exports.DefaultTileSizeModifierTool = DefaultTileSizeModifierTool;
345
- DefaultTileSizeModifierTool.toolId = "DefaultTileSizeMod";
346
346
  /** Sets or clears the tile size modifier override for the selected viewport.
347
347
  * @beta
348
348
  */
349
349
  class ViewportTileSizeModifierTool extends core_frontend_1.Tool {
350
+ static { this.toolId = "ViewportTileSizeMod"; }
350
351
  static get minArgs() { return 1; }
351
352
  static get maxArgs() { return 1; }
352
353
  /** This method runs the tool, setting the tile size modifier used for the selected viewport.
@@ -368,11 +369,11 @@ class ViewportTileSizeModifierTool extends core_frontend_1.Tool {
368
369
  }
369
370
  }
370
371
  exports.ViewportTileSizeModifierTool = ViewportTileSizeModifierTool;
371
- ViewportTileSizeModifierTool.toolId = "ViewportTileSizeMod";
372
372
  /** This tool adds a reality model to the viewport.
373
373
  * @beta
374
374
  */
375
375
  class ViewportAddRealityModel extends core_frontend_1.Tool {
376
+ static { this.toolId = "ViewportAddRealityModel"; }
376
377
  static get minArgs() { return 1; }
377
378
  static get maxArgs() { return 1; }
378
379
  /** This method runs the tool, adding a reality model to the viewport
@@ -392,11 +393,11 @@ class ViewportAddRealityModel extends core_frontend_1.Tool {
392
393
  }
393
394
  }
394
395
  exports.ViewportAddRealityModel = ViewportAddRealityModel;
395
- ViewportAddRealityModel.toolId = "ViewportAddRealityModel";
396
396
  /** Changes the `allow3dManipulations` flag for the selected viewport if the viewport is displaying a `ViewState3d`.
397
397
  * @beta
398
398
  */
399
399
  class Toggle3dManipulationsTool extends ViewportToggleTool {
400
+ static { this.toolId = "Toggle3dManipulations"; }
400
401
  async toggle(vp, allow) {
401
402
  if (!vp.view.is3d())
402
403
  return Promise.resolve();
@@ -411,11 +412,11 @@ class Toggle3dManipulationsTool extends ViewportToggleTool {
411
412
  }
412
413
  }
413
414
  exports.Toggle3dManipulationsTool = Toggle3dManipulationsTool;
414
- Toggle3dManipulationsTool.toolId = "Toggle3dManipulations";
415
415
  /** Toggles display of view attachments in sheet views.
416
416
  * @beta
417
417
  */
418
418
  class ToggleViewAttachmentsTool extends ViewportToggleTool {
419
+ static { this.toolId = "ToggleViewAttachments"; }
419
420
  async toggle(vp, enable) {
420
421
  if (undefined === enable || enable !== vp.wantViewAttachments)
421
422
  vp.wantViewAttachments = !vp.wantViewAttachments;
@@ -423,11 +424,11 @@ class ToggleViewAttachmentsTool extends ViewportToggleTool {
423
424
  }
424
425
  }
425
426
  exports.ToggleViewAttachmentsTool = ToggleViewAttachmentsTool;
426
- ToggleViewAttachmentsTool.toolId = "ToggleViewAttachments";
427
427
  /** Toggle display of view attachment boundaries in sheet views.
428
428
  * @beta
429
429
  */
430
430
  class ToggleViewAttachmentBoundariesTool extends ViewportToggleTool {
431
+ static { this.toolId = "ToggleViewAttachmentBoundaries"; }
431
432
  async toggle(vp, enable) {
432
433
  if (undefined === enable || enable !== vp.wantViewAttachmentBoundaries)
433
434
  vp.wantViewAttachmentBoundaries = !vp.wantViewAttachmentBoundaries;
@@ -435,11 +436,11 @@ class ToggleViewAttachmentBoundariesTool extends ViewportToggleTool {
435
436
  }
436
437
  }
437
438
  exports.ToggleViewAttachmentBoundariesTool = ToggleViewAttachmentBoundariesTool;
438
- ToggleViewAttachmentBoundariesTool.toolId = "ToggleViewAttachmentBoundaries";
439
439
  /** Toggle display of view attachment clip shapes in sheet views.
440
440
  * @beta
441
441
  */
442
442
  class ToggleViewAttachmentClipShapesTool extends ViewportToggleTool {
443
+ static { this.toolId = "ToggleViewAttachmentClipShapes"; }
443
444
  async toggle(vp, enable) {
444
445
  if (undefined === enable || enable !== vp.wantViewAttachmentClipShapes)
445
446
  vp.wantViewAttachmentClipShapes = !vp.wantViewAttachmentClipShapes;
@@ -447,11 +448,11 @@ class ToggleViewAttachmentClipShapesTool extends ViewportToggleTool {
447
448
  }
448
449
  }
449
450
  exports.ToggleViewAttachmentClipShapesTool = ToggleViewAttachmentClipShapesTool;
450
- ToggleViewAttachmentClipShapesTool.toolId = "ToggleViewAttachmentClipShapes";
451
451
  /** Toggles display of 2d graphics in a [DrawingViewState]($frontend). This setting affects all drawing views until it is reset.
452
452
  * @beta
453
453
  */
454
454
  class ToggleDrawingGraphicsTool extends ViewportToggleTool {
455
+ static { this.toolId = "ToggleDrawingGraphics"; }
455
456
  async toggle(vp, enable) {
456
457
  if (undefined === enable || enable !== core_frontend_1.DrawingViewState.hideDrawingGraphics) {
457
458
  core_frontend_1.DrawingViewState.hideDrawingGraphics = !core_frontend_1.DrawingViewState.hideDrawingGraphics;
@@ -461,12 +462,12 @@ class ToggleDrawingGraphicsTool extends ViewportToggleTool {
461
462
  }
462
463
  }
463
464
  exports.ToggleDrawingGraphicsTool = ToggleDrawingGraphicsTool;
464
- ToggleDrawingGraphicsTool.toolId = "ToggleDrawingGraphics";
465
465
  /** Toggles whether a [SectionDrawing]($backend)'s spatial view is always displayed along with the 2d graphics by a [DrawingViewState]($frontend), even
466
466
  * if it otherwise would not be. This setting affects all section drawing views until it is reset.
467
467
  * @beta
468
468
  */
469
469
  class ToggleSectionDrawingSpatialViewTool extends ViewportToggleTool {
470
+ static { this.toolId = "ToggleSectionDrawingSpatialView"; }
470
471
  async toggle(vp, enable) {
471
472
  if (undefined === enable || enable !== core_frontend_1.DrawingViewState.alwaysDisplaySpatialView) {
472
473
  core_frontend_1.DrawingViewState.alwaysDisplaySpatialView = !core_frontend_1.DrawingViewState.alwaysDisplaySpatialView;
@@ -481,13 +482,13 @@ class ToggleSectionDrawingSpatialViewTool extends ViewportToggleTool {
481
482
  }
482
483
  }
483
484
  exports.ToggleSectionDrawingSpatialViewTool = ToggleSectionDrawingSpatialViewTool;
484
- ToggleSectionDrawingSpatialViewTool.toolId = "ToggleSectionDrawingSpatialView";
485
485
  /** Change the camera settings of the selected viewport.
486
486
  * @beta
487
487
  */
488
488
  class ChangeCameraTool extends core_frontend_1.Tool {
489
489
  static get minArgs() { return 1; }
490
490
  static get maxArgs() { return 2; }
491
+ static { this.toolId = "ChangeCamera"; }
491
492
  async run(camera) {
492
493
  const vp = core_frontend_1.IModelApp.viewManager.selectedView;
493
494
  if (camera && vp && vp.view.is3d()) {
@@ -513,5 +514,4 @@ class ChangeCameraTool extends core_frontend_1.Tool {
513
514
  }
514
515
  }
515
516
  exports.ChangeCameraTool = ChangeCameraTool;
516
- ChangeCameraTool.toolId = "ChangeCamera";
517
517
  //# sourceMappingURL=ViewportTools.js.map