@itwin/frontend-devtools 4.0.0-dev.7 → 4.0.0-dev.72

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 (359) hide show
  1. package/CHANGELOG.md +41 -1
  2. package/lib/cjs/ClipboardUtilities.d.ts +8 -8
  3. package/lib/cjs/ClipboardUtilities.js +26 -26
  4. package/lib/cjs/FrontEndDevTools.d.ts +19 -19
  5. package/lib/cjs/FrontEndDevTools.js +221 -221
  6. package/lib/cjs/FrontEndDevTools.js.map +1 -1
  7. package/lib/cjs/effects/Convolution.d.ts +68 -68
  8. package/lib/cjs/effects/Convolution.js +148 -148
  9. package/lib/cjs/effects/Convolution.js.map +1 -1
  10. package/lib/cjs/effects/EffectTools.d.ts +33 -33
  11. package/lib/cjs/effects/EffectTools.js +67 -68
  12. package/lib/cjs/effects/EffectTools.js.map +1 -1
  13. package/lib/cjs/effects/Explosion.d.ts +12 -12
  14. package/lib/cjs/effects/Explosion.js +168 -168
  15. package/lib/cjs/effects/Explosion.js.map +1 -1
  16. package/lib/cjs/effects/FlipImage.d.ts +30 -30
  17. package/lib/cjs/effects/FlipImage.js +79 -79
  18. package/lib/cjs/effects/FlipImage.js.map +1 -1
  19. package/lib/cjs/effects/LensDistortion.d.ts +34 -34
  20. package/lib/cjs/effects/LensDistortion.js +88 -88
  21. package/lib/cjs/effects/LensDistortion.js.map +1 -1
  22. package/lib/cjs/effects/Random.d.ts +24 -24
  23. package/lib/cjs/effects/Random.js +49 -49
  24. package/lib/cjs/effects/Saturation.d.ts +30 -30
  25. package/lib/cjs/effects/Saturation.js +59 -59
  26. package/lib/cjs/effects/Saturation.js.map +1 -1
  27. package/lib/cjs/effects/Snow.d.ts +76 -76
  28. package/lib/cjs/effects/Snow.js +187 -187
  29. package/lib/cjs/effects/Snow.js.map +1 -1
  30. package/lib/cjs/effects/Vignette.d.ts +39 -39
  31. package/lib/cjs/effects/Vignette.js +79 -79
  32. package/lib/cjs/effects/Vignette.js.map +1 -1
  33. package/lib/cjs/frontend-devtools.d.ts +82 -82
  34. package/lib/cjs/frontend-devtools.js +102 -98
  35. package/lib/cjs/frontend-devtools.js.map +1 -1
  36. package/lib/cjs/tools/AnimationIntervalTool.d.ts +15 -15
  37. package/lib/cjs/tools/AnimationIntervalTool.js +30 -30
  38. package/lib/cjs/tools/AnimationIntervalTool.js.map +1 -1
  39. package/lib/cjs/tools/ChangeUnitsTool.d.ts +15 -15
  40. package/lib/cjs/tools/ChangeUnitsTool.js +41 -41
  41. package/lib/cjs/tools/ChangeUnitsTool.js.map +1 -1
  42. package/lib/cjs/tools/ClipTools.d.ts +67 -67
  43. package/lib/cjs/tools/ClipTools.js +161 -164
  44. package/lib/cjs/tools/ClipTools.js.map +1 -1
  45. package/lib/cjs/tools/DisplayStyleTools.d.ts +145 -145
  46. package/lib/cjs/tools/DisplayStyleTools.js +368 -370
  47. package/lib/cjs/tools/DisplayStyleTools.js.map +1 -1
  48. package/lib/cjs/tools/EmphasizeElementsTool.d.ts +60 -60
  49. package/lib/cjs/tools/EmphasizeElementsTool.js +154 -154
  50. package/lib/cjs/tools/EmphasizeElementsTool.js.map +1 -1
  51. package/lib/cjs/tools/FrustumDecoration.d.ts +57 -57
  52. package/lib/cjs/tools/FrustumDecoration.js +374 -374
  53. package/lib/cjs/tools/FrustumDecoration.js.map +1 -1
  54. package/lib/cjs/tools/InspectElementTool.d.ts +42 -42
  55. package/lib/cjs/tools/InspectElementTool.js +198 -198
  56. package/lib/cjs/tools/InspectElementTool.js.map +1 -1
  57. package/lib/cjs/tools/MapLayerTool.d.ts +264 -264
  58. package/lib/cjs/tools/MapLayerTool.js +507 -507
  59. package/lib/cjs/tools/MapLayerTool.js.map +1 -1
  60. package/lib/cjs/tools/MeasureTileLoadTime.d.ts +12 -12
  61. package/lib/cjs/tools/MeasureTileLoadTime.js +63 -63
  62. package/lib/cjs/tools/MeasureTileLoadTime.js.map +1 -1
  63. package/lib/cjs/tools/ModelAppearanceTools.d.ts +86 -86
  64. package/lib/cjs/tools/ModelAppearanceTools.js +183 -183
  65. package/lib/cjs/tools/ModelAppearanceTools.js.map +1 -1
  66. package/lib/cjs/tools/PlanProjectionTools.d.ts +40 -40
  67. package/lib/cjs/tools/PlanProjectionTools.js +149 -149
  68. package/lib/cjs/tools/PlanProjectionTools.js.map +1 -1
  69. package/lib/cjs/tools/PlanarMaskTools.d.ts +182 -182
  70. package/lib/cjs/tools/PlanarMaskTools.js +391 -393
  71. package/lib/cjs/tools/PlanarMaskTools.js.map +1 -1
  72. package/lib/cjs/tools/ProjectExtents.d.ts +41 -41
  73. package/lib/cjs/tools/ProjectExtents.js +110 -110
  74. package/lib/cjs/tools/ProjectExtents.js.map +1 -1
  75. package/lib/cjs/tools/RealityModelTools.d.ts +116 -116
  76. package/lib/cjs/tools/RealityModelTools.js +281 -281
  77. package/lib/cjs/tools/RealityModelTools.js.map +1 -1
  78. package/lib/cjs/tools/RealityTransitionTool.d.ts +25 -25
  79. package/lib/cjs/tools/RealityTransitionTool.js +115 -116
  80. package/lib/cjs/tools/RealityTransitionTool.js.map +1 -1
  81. package/lib/cjs/tools/RenderSystemTools.d.ts +38 -38
  82. package/lib/cjs/tools/RenderSystemTools.js +69 -70
  83. package/lib/cjs/tools/RenderSystemTools.js.map +1 -1
  84. package/lib/cjs/tools/RenderTargetTools.d.ts +107 -107
  85. package/lib/cjs/tools/RenderTargetTools.d.ts.map +1 -1
  86. package/lib/cjs/tools/RenderTargetTools.js +174 -174
  87. package/lib/cjs/tools/RenderTargetTools.js.map +1 -1
  88. package/lib/cjs/tools/ReportWebGLCompatibilityTool.d.ts +11 -11
  89. package/lib/cjs/tools/ReportWebGLCompatibilityTool.js +30 -30
  90. package/lib/cjs/tools/ReportWebGLCompatibilityTool.js.map +1 -1
  91. package/lib/cjs/tools/SavedViews.d.ts +46 -46
  92. package/lib/cjs/tools/SavedViews.js +136 -136
  93. package/lib/cjs/tools/SavedViews.js.map +1 -1
  94. package/lib/cjs/tools/ScheduleScriptTools.d.ts +37 -37
  95. package/lib/cjs/tools/ScheduleScriptTools.js +157 -159
  96. package/lib/cjs/tools/ScheduleScriptTools.js.map +1 -1
  97. package/lib/cjs/tools/SelectionTools.d.ts +28 -28
  98. package/lib/cjs/tools/SelectionTools.js +87 -87
  99. package/lib/cjs/tools/SelectionTools.js.map +1 -1
  100. package/lib/cjs/tools/SetGpuMemoryLimitTool.d.ts +15 -15
  101. package/lib/cjs/tools/SetGpuMemoryLimitTool.js +33 -33
  102. package/lib/cjs/tools/SetGpuMemoryLimitTool.js.map +1 -1
  103. package/lib/cjs/tools/SourceAspectIdTools.d.ts +40 -40
  104. package/lib/cjs/tools/SourceAspectIdTools.d.ts.map +1 -1
  105. package/lib/cjs/tools/SourceAspectIdTools.js +86 -86
  106. package/lib/cjs/tools/SourceAspectIdTools.js.map +1 -1
  107. package/lib/cjs/tools/TileRequestDecoration.d.ts +12 -12
  108. package/lib/cjs/tools/TileRequestDecoration.js +83 -83
  109. package/lib/cjs/tools/TileRequestDecoration.js.map +1 -1
  110. package/lib/cjs/tools/TileTreeBoundsDecoration.d.ts +11 -11
  111. package/lib/cjs/tools/TileTreeBoundsDecoration.js +74 -74
  112. package/lib/cjs/tools/TileTreeBoundsDecoration.js.map +1 -1
  113. package/lib/cjs/tools/ToolTipProvider.d.ts +15 -15
  114. package/lib/cjs/tools/ToolTipProvider.js +66 -66
  115. package/lib/cjs/tools/ToolTipProvider.js.map +1 -1
  116. package/lib/cjs/tools/ViewportTools.d.ts +218 -218
  117. package/lib/cjs/tools/ViewportTools.d.ts.map +1 -1
  118. package/lib/cjs/tools/ViewportTools.js +516 -516
  119. package/lib/cjs/tools/ViewportTools.js.map +1 -1
  120. package/lib/cjs/tools/parseArgs.d.ts +23 -23
  121. package/lib/cjs/tools/parseArgs.js +51 -51
  122. package/lib/cjs/tools/parseBoolean.d.ts +8 -8
  123. package/lib/cjs/tools/parseBoolean.js +26 -26
  124. package/lib/cjs/tools/parseToggle.d.ts +8 -8
  125. package/lib/cjs/tools/parseToggle.js +25 -25
  126. package/lib/cjs/ui/Button.d.ts +29 -29
  127. package/lib/cjs/ui/Button.d.ts.map +1 -1
  128. package/lib/cjs/ui/Button.js +26 -26
  129. package/lib/cjs/ui/CheckBox.d.ts +23 -23
  130. package/lib/cjs/ui/CheckBox.d.ts.map +1 -1
  131. package/lib/cjs/ui/CheckBox.js +27 -27
  132. package/lib/cjs/ui/ColorInput.d.ts +27 -27
  133. package/lib/cjs/ui/ColorInput.d.ts.map +1 -1
  134. package/lib/cjs/ui/ColorInput.js +53 -53
  135. package/lib/cjs/ui/ComboBox.d.ts +28 -28
  136. package/lib/cjs/ui/ComboBox.d.ts.map +1 -1
  137. package/lib/cjs/ui/ComboBox.js +42 -42
  138. package/lib/cjs/ui/DataList.d.ts +27 -27
  139. package/lib/cjs/ui/DataList.d.ts.map +1 -1
  140. package/lib/cjs/ui/DataList.js +39 -39
  141. package/lib/cjs/ui/NestedMenu.d.ts +19 -19
  142. package/lib/cjs/ui/NestedMenu.d.ts.map +1 -1
  143. package/lib/cjs/ui/NestedMenu.js +46 -46
  144. package/lib/cjs/ui/NumericInput.d.ts +35 -35
  145. package/lib/cjs/ui/NumericInput.d.ts.map +1 -1
  146. package/lib/cjs/ui/NumericInput.js +61 -61
  147. package/lib/cjs/ui/RadioBox.d.ts +29 -29
  148. package/lib/cjs/ui/RadioBox.d.ts.map +1 -1
  149. package/lib/cjs/ui/RadioBox.js +76 -76
  150. package/lib/cjs/ui/Slider.d.ts +28 -28
  151. package/lib/cjs/ui/Slider.d.ts.map +1 -1
  152. package/lib/cjs/ui/Slider.js +42 -42
  153. package/lib/cjs/ui/TextBox.d.ts +32 -32
  154. package/lib/cjs/ui/TextBox.d.ts.map +1 -1
  155. package/lib/cjs/ui/TextBox.js +56 -56
  156. package/lib/cjs/widgets/DiagnosticsPanel.d.ts +37 -37
  157. package/lib/cjs/widgets/DiagnosticsPanel.js +81 -81
  158. package/lib/cjs/widgets/FpsTracker.d.ts +19 -19
  159. package/lib/cjs/widgets/FpsTracker.js +56 -56
  160. package/lib/cjs/widgets/GpuProfiler.d.ts +16 -16
  161. package/lib/cjs/widgets/GpuProfiler.js +192 -192
  162. package/lib/cjs/widgets/KeyinField.d.ts +61 -61
  163. package/lib/cjs/widgets/KeyinField.js +186 -187
  164. package/lib/cjs/widgets/KeyinField.js.map +1 -1
  165. package/lib/cjs/widgets/MemoryTracker.d.ts +27 -27
  166. package/lib/cjs/widgets/MemoryTracker.js +242 -243
  167. package/lib/cjs/widgets/MemoryTracker.js.map +1 -1
  168. package/lib/cjs/widgets/RenderCommandBreakdown.d.ts +15 -15
  169. package/lib/cjs/widgets/RenderCommandBreakdown.js +67 -68
  170. package/lib/cjs/widgets/RenderCommandBreakdown.js.map +1 -1
  171. package/lib/cjs/widgets/TileMemoryBreakdown.d.ts +30 -30
  172. package/lib/cjs/widgets/TileMemoryBreakdown.js +203 -204
  173. package/lib/cjs/widgets/TileMemoryBreakdown.js.map +1 -1
  174. package/lib/cjs/widgets/TileStatisticsTracker.d.ts +21 -21
  175. package/lib/cjs/widgets/TileStatisticsTracker.d.ts.map +1 -1
  176. package/lib/cjs/widgets/TileStatisticsTracker.js +144 -142
  177. package/lib/cjs/widgets/TileStatisticsTracker.js.map +1 -1
  178. package/lib/cjs/widgets/ToolSettingsTracker.d.ts +9 -9
  179. package/lib/cjs/widgets/ToolSettingsTracker.js +211 -211
  180. package/lib/cjs/widgets/ToolSettingsTracker.js.map +1 -1
  181. package/lib/esm/ClipboardUtilities.d.ts +8 -8
  182. package/lib/esm/ClipboardUtilities.js +22 -22
  183. package/lib/esm/FrontEndDevTools.d.ts +19 -19
  184. package/lib/esm/FrontEndDevTools.js +218 -217
  185. package/lib/esm/FrontEndDevTools.js.map +1 -1
  186. package/lib/esm/effects/Convolution.d.ts +68 -68
  187. package/lib/esm/effects/Convolution.js +144 -138
  188. package/lib/esm/effects/Convolution.js.map +1 -1
  189. package/lib/esm/effects/EffectTools.d.ts +33 -33
  190. package/lib/esm/effects/EffectTools.js +63 -62
  191. package/lib/esm/effects/EffectTools.js.map +1 -1
  192. package/lib/esm/effects/Explosion.d.ts +12 -12
  193. package/lib/esm/effects/Explosion.js +165 -164
  194. package/lib/esm/effects/Explosion.js.map +1 -1
  195. package/lib/esm/effects/FlipImage.d.ts +30 -30
  196. package/lib/esm/effects/FlipImage.js +76 -74
  197. package/lib/esm/effects/FlipImage.js.map +1 -1
  198. package/lib/esm/effects/LensDistortion.d.ts +34 -34
  199. package/lib/esm/effects/LensDistortion.js +85 -83
  200. package/lib/esm/effects/LensDistortion.js.map +1 -1
  201. package/lib/esm/effects/Random.d.ts +24 -24
  202. package/lib/esm/effects/Random.js +41 -41
  203. package/lib/esm/effects/Saturation.d.ts +30 -30
  204. package/lib/esm/effects/Saturation.js +56 -54
  205. package/lib/esm/effects/Saturation.js.map +1 -1
  206. package/lib/esm/effects/Snow.d.ts +76 -76
  207. package/lib/esm/effects/Snow.js +184 -182
  208. package/lib/esm/effects/Snow.js.map +1 -1
  209. package/lib/esm/effects/Vignette.d.ts +39 -39
  210. package/lib/esm/effects/Vignette.js +76 -74
  211. package/lib/esm/effects/Vignette.js.map +1 -1
  212. package/lib/esm/frontend-devtools.d.ts +82 -82
  213. package/lib/esm/frontend-devtools.js +86 -86
  214. package/lib/esm/tools/AnimationIntervalTool.d.ts +15 -15
  215. package/lib/esm/tools/AnimationIntervalTool.js +27 -26
  216. package/lib/esm/tools/AnimationIntervalTool.js.map +1 -1
  217. package/lib/esm/tools/ChangeUnitsTool.d.ts +15 -15
  218. package/lib/esm/tools/ChangeUnitsTool.js +38 -37
  219. package/lib/esm/tools/ChangeUnitsTool.js.map +1 -1
  220. package/lib/esm/tools/ClipTools.d.ts +67 -67
  221. package/lib/esm/tools/ClipTools.js +158 -158
  222. package/lib/esm/tools/ClipTools.js.map +1 -1
  223. package/lib/esm/tools/DisplayStyleTools.d.ts +145 -145
  224. package/lib/esm/tools/DisplayStyleTools.js +364 -356
  225. package/lib/esm/tools/DisplayStyleTools.js.map +1 -1
  226. package/lib/esm/tools/EmphasizeElementsTool.d.ts +60 -60
  227. package/lib/esm/tools/EmphasizeElementsTool.js +150 -145
  228. package/lib/esm/tools/EmphasizeElementsTool.js.map +1 -1
  229. package/lib/esm/tools/FrustumDecoration.d.ts +57 -57
  230. package/lib/esm/tools/FrustumDecoration.js +370 -367
  231. package/lib/esm/tools/FrustumDecoration.js.map +1 -1
  232. package/lib/esm/tools/InspectElementTool.d.ts +42 -42
  233. package/lib/esm/tools/InspectElementTool.js +195 -194
  234. package/lib/esm/tools/InspectElementTool.js.map +1 -1
  235. package/lib/esm/tools/MapLayerTool.d.ts +264 -264
  236. package/lib/esm/tools/MapLayerTool.js +504 -485
  237. package/lib/esm/tools/MapLayerTool.js.map +1 -1
  238. package/lib/esm/tools/MeasureTileLoadTime.d.ts +12 -12
  239. package/lib/esm/tools/MeasureTileLoadTime.js +60 -59
  240. package/lib/esm/tools/MeasureTileLoadTime.js.map +1 -1
  241. package/lib/esm/tools/ModelAppearanceTools.d.ts +86 -86
  242. package/lib/esm/tools/ModelAppearanceTools.js +180 -172
  243. package/lib/esm/tools/ModelAppearanceTools.js.map +1 -1
  244. package/lib/esm/tools/PlanProjectionTools.d.ts +40 -40
  245. package/lib/esm/tools/PlanProjectionTools.js +146 -143
  246. package/lib/esm/tools/PlanProjectionTools.js.map +1 -1
  247. package/lib/esm/tools/PlanarMaskTools.d.ts +182 -182
  248. package/lib/esm/tools/PlanarMaskTools.js +387 -377
  249. package/lib/esm/tools/PlanarMaskTools.js.map +1 -1
  250. package/lib/esm/tools/ProjectExtents.d.ts +41 -41
  251. package/lib/esm/tools/ProjectExtents.js +105 -104
  252. package/lib/esm/tools/ProjectExtents.js.map +1 -1
  253. package/lib/esm/tools/RealityModelTools.d.ts +116 -116
  254. package/lib/esm/tools/RealityModelTools.js +278 -268
  255. package/lib/esm/tools/RealityModelTools.js.map +1 -1
  256. package/lib/esm/tools/RealityTransitionTool.d.ts +25 -25
  257. package/lib/esm/tools/RealityTransitionTool.js +112 -112
  258. package/lib/esm/tools/RealityTransitionTool.js.map +1 -1
  259. package/lib/esm/tools/RenderSystemTools.d.ts +38 -38
  260. package/lib/esm/tools/RenderSystemTools.js +65 -63
  261. package/lib/esm/tools/RenderSystemTools.js.map +1 -1
  262. package/lib/esm/tools/RenderTargetTools.d.ts +107 -107
  263. package/lib/esm/tools/RenderTargetTools.d.ts.map +1 -1
  264. package/lib/esm/tools/RenderTargetTools.js +169 -159
  265. package/lib/esm/tools/RenderTargetTools.js.map +1 -1
  266. package/lib/esm/tools/ReportWebGLCompatibilityTool.d.ts +11 -11
  267. package/lib/esm/tools/ReportWebGLCompatibilityTool.js +27 -26
  268. package/lib/esm/tools/ReportWebGLCompatibilityTool.js.map +1 -1
  269. package/lib/esm/tools/SavedViews.d.ts +46 -46
  270. package/lib/esm/tools/SavedViews.js +131 -128
  271. package/lib/esm/tools/SavedViews.js.map +1 -1
  272. package/lib/esm/tools/ScheduleScriptTools.d.ts +37 -37
  273. package/lib/esm/tools/ScheduleScriptTools.js +154 -153
  274. package/lib/esm/tools/ScheduleScriptTools.js.map +1 -1
  275. package/lib/esm/tools/SelectionTools.d.ts +28 -28
  276. package/lib/esm/tools/SelectionTools.js +84 -82
  277. package/lib/esm/tools/SelectionTools.js.map +1 -1
  278. package/lib/esm/tools/SetGpuMemoryLimitTool.d.ts +15 -15
  279. package/lib/esm/tools/SetGpuMemoryLimitTool.js +30 -29
  280. package/lib/esm/tools/SetGpuMemoryLimitTool.js.map +1 -1
  281. package/lib/esm/tools/SourceAspectIdTools.d.ts +40 -40
  282. package/lib/esm/tools/SourceAspectIdTools.d.ts.map +1 -1
  283. package/lib/esm/tools/SourceAspectIdTools.js +82 -80
  284. package/lib/esm/tools/SourceAspectIdTools.js.map +1 -1
  285. package/lib/esm/tools/TileRequestDecoration.d.ts +12 -12
  286. package/lib/esm/tools/TileRequestDecoration.js +80 -79
  287. package/lib/esm/tools/TileRequestDecoration.js.map +1 -1
  288. package/lib/esm/tools/TileTreeBoundsDecoration.d.ts +11 -11
  289. package/lib/esm/tools/TileTreeBoundsDecoration.js +71 -70
  290. package/lib/esm/tools/TileTreeBoundsDecoration.js.map +1 -1
  291. package/lib/esm/tools/ToolTipProvider.d.ts +15 -15
  292. package/lib/esm/tools/ToolTipProvider.js +63 -62
  293. package/lib/esm/tools/ToolTipProvider.js.map +1 -1
  294. package/lib/esm/tools/ViewportTools.d.ts +218 -218
  295. package/lib/esm/tools/ViewportTools.d.ts.map +1 -1
  296. package/lib/esm/tools/ViewportTools.js +511 -492
  297. package/lib/esm/tools/ViewportTools.js.map +1 -1
  298. package/lib/esm/tools/parseArgs.d.ts +23 -23
  299. package/lib/esm/tools/parseArgs.js +47 -47
  300. package/lib/esm/tools/parseBoolean.d.ts +8 -8
  301. package/lib/esm/tools/parseBoolean.js +22 -22
  302. package/lib/esm/tools/parseToggle.d.ts +8 -8
  303. package/lib/esm/tools/parseToggle.js +21 -21
  304. package/lib/esm/ui/Button.d.ts +29 -29
  305. package/lib/esm/ui/Button.d.ts.map +1 -1
  306. package/lib/esm/ui/Button.js +22 -22
  307. package/lib/esm/ui/CheckBox.d.ts +23 -23
  308. package/lib/esm/ui/CheckBox.d.ts.map +1 -1
  309. package/lib/esm/ui/CheckBox.js +23 -23
  310. package/lib/esm/ui/ColorInput.d.ts +27 -27
  311. package/lib/esm/ui/ColorInput.d.ts.map +1 -1
  312. package/lib/esm/ui/ColorInput.js +48 -48
  313. package/lib/esm/ui/ComboBox.d.ts +28 -28
  314. package/lib/esm/ui/ComboBox.d.ts.map +1 -1
  315. package/lib/esm/ui/ComboBox.js +38 -38
  316. package/lib/esm/ui/DataList.d.ts +27 -27
  317. package/lib/esm/ui/DataList.d.ts.map +1 -1
  318. package/lib/esm/ui/DataList.js +34 -34
  319. package/lib/esm/ui/NestedMenu.d.ts +19 -19
  320. package/lib/esm/ui/NestedMenu.d.ts.map +1 -1
  321. package/lib/esm/ui/NestedMenu.js +42 -42
  322. package/lib/esm/ui/NumericInput.d.ts +35 -35
  323. package/lib/esm/ui/NumericInput.d.ts.map +1 -1
  324. package/lib/esm/ui/NumericInput.js +56 -56
  325. package/lib/esm/ui/RadioBox.d.ts +29 -29
  326. package/lib/esm/ui/RadioBox.d.ts.map +1 -1
  327. package/lib/esm/ui/RadioBox.js +72 -72
  328. package/lib/esm/ui/Slider.d.ts +28 -28
  329. package/lib/esm/ui/Slider.d.ts.map +1 -1
  330. package/lib/esm/ui/Slider.js +38 -38
  331. package/lib/esm/ui/TextBox.d.ts +32 -32
  332. package/lib/esm/ui/TextBox.d.ts.map +1 -1
  333. package/lib/esm/ui/TextBox.js +52 -52
  334. package/lib/esm/widgets/DiagnosticsPanel.d.ts +37 -37
  335. package/lib/esm/widgets/DiagnosticsPanel.js +77 -77
  336. package/lib/esm/widgets/FpsTracker.d.ts +19 -19
  337. package/lib/esm/widgets/FpsTracker.js +52 -52
  338. package/lib/esm/widgets/GpuProfiler.d.ts +16 -16
  339. package/lib/esm/widgets/GpuProfiler.js +188 -188
  340. package/lib/esm/widgets/KeyinField.d.ts +61 -61
  341. package/lib/esm/widgets/KeyinField.js +182 -183
  342. package/lib/esm/widgets/KeyinField.js.map +1 -1
  343. package/lib/esm/widgets/MemoryTracker.d.ts +27 -27
  344. package/lib/esm/widgets/MemoryTracker.js +237 -238
  345. package/lib/esm/widgets/MemoryTracker.js.map +1 -1
  346. package/lib/esm/widgets/RenderCommandBreakdown.d.ts +15 -15
  347. package/lib/esm/widgets/RenderCommandBreakdown.js +63 -64
  348. package/lib/esm/widgets/RenderCommandBreakdown.js.map +1 -1
  349. package/lib/esm/widgets/TileMemoryBreakdown.d.ts +30 -30
  350. package/lib/esm/widgets/TileMemoryBreakdown.js +199 -200
  351. package/lib/esm/widgets/TileMemoryBreakdown.js.map +1 -1
  352. package/lib/esm/widgets/TileStatisticsTracker.d.ts +21 -21
  353. package/lib/esm/widgets/TileStatisticsTracker.d.ts.map +1 -1
  354. package/lib/esm/widgets/TileStatisticsTracker.js +140 -138
  355. package/lib/esm/widgets/TileStatisticsTracker.js.map +1 -1
  356. package/lib/esm/widgets/ToolSettingsTracker.d.ts +9 -9
  357. package/lib/esm/widgets/ToolSettingsTracker.js +208 -207
  358. package/lib/esm/widgets/ToolSettingsTracker.js.map +1 -1
  359. package/package.json +13 -13
@@ -1 +1 @@
1
- {"version":3,"file":"SelectionTools.js","sourceRoot":"","sources":["../../../src/tools/SelectionTools.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 { CompressedId64Set, Id64Arg, OrderedId64Iterable } from \"@itwin/core-bentley\";\r\nimport { IModelApp, NotifyMessageDetails, OutputMessagePriority, Tool } from \"@itwin/core-frontend\";\r\nimport { copyStringToClipboard } from \"../ClipboardUtilities\";\r\nimport { parseArgs } from \"./parseArgs\";\r\n\r\n/** Replaces the contents of the selection set with the set of element Ids specified.\r\n * Element Ids are separated by whitespace.\r\n * @beta\r\n */\r\nexport class SelectElementsByIdTool extends Tool {\r\n public static override toolId = \"SelectElementsById\";\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return undefined; }\r\n\r\n public override async run(ids?: Id64Arg): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp && undefined !== ids)\r\n vp.iModel.selectionSet.replace(ids);\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n return this.run(args);\r\n }\r\n}\r\n\r\n/** A tool that outputs the Ids of the elements in the [SelectionSet]($frontend) of the [IModelConnection]($frontend) associated with the selected [Viewport]($frontend).\r\n * @beta\r\n */\r\nexport class DumpSelectionSetTool extends Tool {\r\n public static override toolId = \"DumpSelectionSet\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 2; }\r\n\r\n private _format: \"json\" | \"compressed\" | \"list\" = \"list\";\r\n private _copy?: boolean;\r\n\r\n public override async run(): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (!vp)\r\n return false;\r\n\r\n const elems = Array.from(vp.iModel.selectionSet.elements);\r\n OrderedId64Iterable.sortArray(elems);\r\n\r\n let output;\r\n switch (this._format) {\r\n case \"compressed\":\r\n output = CompressedId64Set.compressArray(elems);\r\n break;\r\n case \"json\":\r\n output = JSON.stringify(elems);\r\n break;\r\n default:\r\n output = elems.join(\" \");\r\n break;\r\n }\r\n\r\n if (this._copy)\r\n copyStringToClipboard(output);\r\n\r\n const brief = `Selection set dumped${this._copy ? \" to clipboard\" : \"\"}.`;\r\n const details = new NotifyMessageDetails(OutputMessagePriority.Info, brief, output);\r\n IModelApp.notifications.outputMessage(details);\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...input: string[]): Promise<boolean> {\r\n const args = parseArgs(input);\r\n this._copy = args.getBoolean(\"c\");\r\n const formatArg = args.get(\"f\");\r\n if (formatArg) {\r\n switch (formatArg[0].toLowerCase()) {\r\n case \"j\":\r\n this._format = \"json\";\r\n break;\r\n case \"c\":\r\n this._format = \"compressed\";\r\n break;\r\n }\r\n }\r\n\r\n return this.run();\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"SelectionTools.js","sourceRoot":"","sources":["../../../src/tools/SelectionTools.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 { CompressedId64Set, Id64Arg, OrderedId64Iterable } from \"@itwin/core-bentley\";\r\nimport { IModelApp, NotifyMessageDetails, OutputMessagePriority, Tool } from \"@itwin/core-frontend\";\r\nimport { copyStringToClipboard } from \"../ClipboardUtilities\";\r\nimport { parseArgs } from \"./parseArgs\";\r\n\r\n/** Replaces the contents of the selection set with the set of element Ids specified.\r\n * Element Ids are separated by whitespace.\r\n * @beta\r\n */\r\nexport class SelectElementsByIdTool extends Tool {\r\n public static override toolId = \"SelectElementsById\";\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return undefined; }\r\n\r\n public override async run(ids?: Id64Arg): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp && undefined !== ids)\r\n vp.iModel.selectionSet.replace(ids);\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n return this.run(args);\r\n }\r\n}\r\n\r\n/** A tool that outputs the Ids of the elements in the [SelectionSet]($frontend) of the [IModelConnection]($frontend) associated with the selected [Viewport]($frontend).\r\n * @beta\r\n */\r\nexport class DumpSelectionSetTool extends Tool {\r\n public static override toolId = \"DumpSelectionSet\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 2; }\r\n\r\n private _format: \"json\" | \"compressed\" | \"list\" = \"list\";\r\n private _copy?: boolean;\r\n\r\n public override async run(): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (!vp)\r\n return false;\r\n\r\n const elems = Array.from(vp.iModel.selectionSet.elements);\r\n OrderedId64Iterable.sortArray(elems);\r\n\r\n let output;\r\n switch (this._format) {\r\n case \"compressed\":\r\n output = CompressedId64Set.compressArray(elems);\r\n break;\r\n case \"json\":\r\n output = JSON.stringify(elems);\r\n break;\r\n default:\r\n output = elems.join(\" \");\r\n break;\r\n }\r\n\r\n if (this._copy)\r\n copyStringToClipboard(output);\r\n\r\n const brief = `Selection set dumped${this._copy ? \" to clipboard\" : \"\"}.`;\r\n const details = new NotifyMessageDetails(OutputMessagePriority.Info, brief, output);\r\n IModelApp.notifications.outputMessage(details);\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...input: string[]): Promise<boolean> {\r\n const args = parseArgs(input);\r\n this._copy = args.getBoolean(\"c\");\r\n const formatArg = args.get(\"f\");\r\n if (formatArg) {\r\n switch (formatArg[0].toLowerCase()) {\r\n case \"j\":\r\n this._format = \"json\";\r\n break;\r\n case \"c\":\r\n this._format = \"compressed\";\r\n break;\r\n }\r\n }\r\n\r\n return this.run();\r\n }\r\n}\r\n"]}
@@ -1,16 +1,16 @@
1
- /** @packageDocumentation
2
- * @module Tools
3
- */
4
- import { GpuMemoryLimit, Tool } from "@itwin/core-frontend";
5
- /** Adjust the value of [TileAdmin.gpuMemoryLimit]($frontend). This controls how much GPU memory is allowed to be consumed
6
- * by tile graphics before the system starts discarding the graphics for the least recently drawn tiles.
7
- * @beta
8
- */
9
- export declare class SetGpuMemoryLimitTool extends Tool {
10
- static toolId: string;
11
- static get minArgs(): number;
12
- static get maxArgs(): number;
13
- run(limit?: GpuMemoryLimit): Promise<boolean>;
14
- parseAndRun(...args: string[]): Promise<boolean>;
15
- }
1
+ /** @packageDocumentation
2
+ * @module Tools
3
+ */
4
+ import { GpuMemoryLimit, Tool } from "@itwin/core-frontend";
5
+ /** Adjust the value of [TileAdmin.gpuMemoryLimit]($frontend). This controls how much GPU memory is allowed to be consumed
6
+ * by tile graphics before the system starts discarding the graphics for the least recently drawn tiles.
7
+ * @beta
8
+ */
9
+ export declare class SetGpuMemoryLimitTool extends Tool {
10
+ static toolId: string;
11
+ static get minArgs(): number;
12
+ static get maxArgs(): number;
13
+ run(limit?: GpuMemoryLimit): Promise<boolean>;
14
+ parseAndRun(...args: string[]): Promise<boolean>;
15
+ }
16
16
  //# sourceMappingURL=SetGpuMemoryLimitTool.d.ts.map
@@ -1,30 +1,31 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Tools
7
- */
8
- import { IModelApp, Tool } from "@itwin/core-frontend";
9
- /** Adjust the value of [TileAdmin.gpuMemoryLimit]($frontend). This controls how much GPU memory is allowed to be consumed
10
- * by tile graphics before the system starts discarding the graphics for the least recently drawn tiles.
11
- * @beta
12
- */
13
- export class SetGpuMemoryLimitTool extends Tool {
14
- static get minArgs() { return 1; }
15
- static get maxArgs() { return 1; }
16
- async run(limit) {
17
- if (undefined !== limit) {
18
- IModelApp.tileAdmin.gpuMemoryLimit = limit;
19
- IModelApp.requestNextAnimation();
20
- }
21
- return true;
22
- }
23
- async parseAndRun(...args) {
24
- const maxBytes = Number.parseInt(args[0], 10);
25
- const limit = Number.isNaN(maxBytes) ? args[0] : maxBytes;
26
- return this.run(limit);
27
- }
28
- }
29
- SetGpuMemoryLimitTool.toolId = "SetGpuMemoryLimit";
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Tools
7
+ */
8
+ import { IModelApp, Tool } from "@itwin/core-frontend";
9
+ /** Adjust the value of [TileAdmin.gpuMemoryLimit]($frontend). This controls how much GPU memory is allowed to be consumed
10
+ * by tile graphics before the system starts discarding the graphics for the least recently drawn tiles.
11
+ * @beta
12
+ */
13
+ class SetGpuMemoryLimitTool extends Tool {
14
+ static get minArgs() { return 1; }
15
+ static get maxArgs() { return 1; }
16
+ async run(limit) {
17
+ if (undefined !== limit) {
18
+ IModelApp.tileAdmin.gpuMemoryLimit = limit;
19
+ IModelApp.requestNextAnimation();
20
+ }
21
+ return true;
22
+ }
23
+ async parseAndRun(...args) {
24
+ const maxBytes = Number.parseInt(args[0], 10);
25
+ const limit = Number.isNaN(maxBytes) ? args[0] : maxBytes;
26
+ return this.run(limit);
27
+ }
28
+ }
29
+ SetGpuMemoryLimitTool.toolId = "SetGpuMemoryLimit";
30
+ export { SetGpuMemoryLimitTool };
30
31
  //# sourceMappingURL=SetGpuMemoryLimitTool.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SetGpuMemoryLimitTool.js","sourceRoot":"","sources":["../../../src/tools/SetGpuMemoryLimitTool.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAkB,SAAS,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAEvE;;;GAGG;AACH,MAAM,OAAO,qBAAsB,SAAQ,IAAI;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;YACvB,SAAS,CAAC,SAAS,CAAC,cAAc,GAAG,KAAK,CAAC;YAC3C,SAAS,CAAC,oBAAoB,EAAE,CAAC;SAClC;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;;AAjBsB,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,OAAO,EAAkB,SAAS,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAEvE;;;GAGG;AACH,MAAa,qBAAsB,SAAQ,IAAI;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;YACvB,SAAS,CAAC,SAAS,CAAC,cAAc,GAAG,KAAK,CAAC;YAC3C,SAAS,CAAC,oBAAoB,EAAE,CAAC;SAClC;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;;AAjBsB,4BAAM,GAAG,mBAAmB,CAAC;SADzC,qBAAqB","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,41 +1,41 @@
1
- import { Tool } from "@itwin/core-frontend";
2
- /** Base class for a tool that can convert between source aspect Ids and element Ids.
3
- * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
4
- * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
5
- * @beta
6
- */
7
- export declare abstract class SourceAspectIdTool extends Tool {
8
- static get minArgs(): number;
9
- static get maxArgs(): number;
10
- protected abstract getECSql(queryId: string): string;
11
- run(idToQuery?: string, copyToClipboard?: boolean): Promise<boolean>;
12
- parseAndRun(...keyinArgs: string[]): Promise<boolean>;
13
- private doQuery;
14
- }
15
- /** Given a source aspect Id, output the Id of the corresponding element in the iModel.
16
- * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
17
- * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
18
- * Arguments:
19
- * - `id=elementId` where `elementId` is the numeric Id of the element of interest (e.g., `0x13a6c`; decimal notation is also permitted).
20
- * - `copy=0|1` where `1` indicates the source aspect Id should be copied to the clipboard.
21
- * The command outputs to the IModelApp.notifications the corresponding source aspect Id, or "NOT FOUND".
22
- * @beta
23
- */
24
- export declare class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {
25
- static toolId: string;
26
- protected getECSql(queryId: string): string;
27
- }
28
- /** 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.
29
- * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
30
- * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
31
- * Arguments:
32
- * - `id=sourceAspectId` where `sourceAspectId` is the string identifier of the object of interest.
33
- * - `copy=0|1` where `1` indicates the element Id should be copied to the clipboard.
34
- * The command outputs to the IModelApp.notifications the corresponding element Id, or "NOT FOUND".
35
- * @beta
36
- */
37
- export declare class ElementIdFromSourceAspectIdTool extends SourceAspectIdTool {
38
- static toolId: string;
39
- protected getECSql(queryId: string): string;
40
- }
1
+ import { Tool } from "@itwin/core-frontend";
2
+ /** Base class for a tool that can convert between source aspect Ids and element Ids.
3
+ * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
4
+ * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
5
+ * @beta
6
+ */
7
+ export declare abstract class SourceAspectIdTool extends Tool {
8
+ static get minArgs(): number;
9
+ static get maxArgs(): number;
10
+ protected abstract getECSql(queryId: string): string;
11
+ run(idToQuery?: string, copyToClipboard?: boolean): Promise<boolean>;
12
+ parseAndRun(...keyinArgs: string[]): Promise<boolean>;
13
+ private doQuery;
14
+ }
15
+ /** Given a source aspect Id, output the Id of the corresponding element in the iModel.
16
+ * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
17
+ * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
18
+ * Arguments:
19
+ * - `id=elementId` where `elementId` is the numeric Id of the element of interest (e.g., `0x13a6c`; decimal notation is also permitted).
20
+ * - `copy=0|1` where `1` indicates the source aspect Id should be copied to the clipboard.
21
+ * The command outputs to the IModelApp.notifications the corresponding source aspect Id, or "NOT FOUND".
22
+ * @beta
23
+ */
24
+ export declare class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {
25
+ static toolId: string;
26
+ protected getECSql(queryId: string): string;
27
+ }
28
+ /** 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.
29
+ * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
30
+ * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
31
+ * Arguments:
32
+ * - `id=sourceAspectId` where `sourceAspectId` is the string identifier of the object of interest.
33
+ * - `copy=0|1` where `1` indicates the element Id should be copied to the clipboard.
34
+ * The command outputs to the IModelApp.notifications the corresponding element Id, or "NOT FOUND".
35
+ * @beta
36
+ */
37
+ export declare class ElementIdFromSourceAspectIdTool extends SourceAspectIdTool {
38
+ static toolId: string;
39
+ protected getECSql(queryId: string): string;
40
+ }
41
41
  //# sourceMappingURL=SourceAspectIdTools.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"SourceAspectIdTools.d.ts","sourceRoot":"","sources":["../../../src/tools/SourceAspectIdTools.ts"],"names":[],"mappings":"AAWA,OAAO,EAA0D,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAIpG;;;;GAIG;AACH,8BAAsB,kBAAmB,SAAQ,IAAI;IACnD,WAA2B,OAAO,WAAgB;IAClD,WAA2B,OAAO,WAAgB;IAElD,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;IAE9B,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,eAAe,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAOpE,WAAW,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;YAK7D,OAAO;CAsBtB;AAED;;;;;;;;GAQG;AACH,qBAAa,+BAAgC,SAAQ,kBAAkB;IACrE,OAAuB,MAAM,SAAiC;IAE9D,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAG5C;AAED;;;;;;;;GAQG;AACH,qBAAa,+BAAgC,SAAQ,kBAAkB;IACrE,OAAuB,MAAM,SAAiC;IAE9D,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAG5C"}
1
+ {"version":3,"file":"SourceAspectIdTools.d.ts","sourceRoot":"","sources":["../../../src/tools/SourceAspectIdTools.ts"],"names":[],"mappings":"AAWA,OAAO,EAA0D,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAIpG;;;;GAIG;AACH,8BAAsB,kBAAmB,SAAQ,IAAI;IACnD,WAA2B,OAAO,WAAgB;IAClD,WAA2B,OAAO,WAAgB;IAElD,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;IAE9B,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,eAAe,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAOpE,WAAW,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;YAK7D,OAAO;CAuBtB;AAED;;;;;;;;GAQG;AACH,qBAAa,+BAAgC,SAAQ,kBAAkB;IACrE,OAAuB,MAAM,SAAiC;IAE9D,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAG5C;AAED;;;;;;;;GAQG;AACH,qBAAa,+BAAgC,SAAQ,kBAAkB;IACrE,OAAuB,MAAM,SAAiC;IAE9D,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAG5C"}
@@ -1,81 +1,83 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Tools
7
- */
8
- import { BentleyError } from "@itwin/core-bentley";
9
- import { QueryRowFormat } from "@itwin/core-common";
10
- import { IModelApp, NotifyMessageDetails, OutputMessagePriority, Tool } from "@itwin/core-frontend";
11
- import { copyStringToClipboard } from "../ClipboardUtilities";
12
- import { parseArgs } from "./parseArgs";
13
- /** Base class for a tool that can convert between source aspect Ids and element Ids.
14
- * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
15
- * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
16
- * @beta
17
- */
18
- export class SourceAspectIdTool extends Tool {
19
- static get minArgs() { return 1; }
20
- static get maxArgs() { return 2; }
21
- async run(idToQuery, copyToClipboard) {
22
- if (typeof idToQuery === "string")
23
- await this.doQuery(idToQuery, true === copyToClipboard);
24
- return true;
25
- }
26
- async parseAndRun(...keyinArgs) {
27
- const args = parseArgs(keyinArgs);
28
- return this.run(args.get("i"), args.getBoolean("c"));
29
- }
30
- async doQuery(queryId, copyToClipboard) {
31
- var _a;
32
- const imodel = (_a = IModelApp.viewManager.selectedView) === null || _a === void 0 ? void 0 : _a.iModel;
33
- if (undefined === imodel)
34
- return;
35
- let resultId;
36
- try {
37
- for await (const row of imodel.query(this.getECSql(queryId), undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames, limit: { count: 1 } }))
38
- resultId = row.resultId;
39
- }
40
- catch (ex) {
41
- resultId = BentleyError.getErrorMessage(ex);
42
- }
43
- if (typeof resultId !== "string")
44
- resultId = "NOT FOUND";
45
- if (copyToClipboard)
46
- copyStringToClipboard(resultId);
47
- const message = `${queryId} => ${resultId}`;
48
- IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Info, message));
49
- }
50
- }
51
- /** Given a source aspect Id, output the Id of the corresponding element in the iModel.
52
- * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
53
- * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
54
- * Arguments:
55
- * - `id=elementId` where `elementId` is the numeric Id of the element of interest (e.g., `0x13a6c`; decimal notation is also permitted).
56
- * - `copy=0|1` where `1` indicates the source aspect Id should be copied to the clipboard.
57
- * The command outputs to the IModelApp.notifications the corresponding source aspect Id, or "NOT FOUND".
58
- * @beta
59
- */
60
- export class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {
61
- getECSql(queryId) {
62
- return `SELECT Identifier as resultId FROM BisCore.ExternalSourceAspect WHERE Element.Id=${queryId} AND [Kind]='Element'`;
63
- }
64
- }
65
- SourceAspectIdFromElementIdTool.toolId = "SourceAspectIdFromElementId";
66
- /** 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.
67
- * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
68
- * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
69
- * Arguments:
70
- * - `id=sourceAspectId` where `sourceAspectId` is the string identifier of the object of interest.
71
- * - `copy=0|1` where `1` indicates the element Id should be copied to the clipboard.
72
- * The command outputs to the IModelApp.notifications the corresponding element Id, or "NOT FOUND".
73
- * @beta
74
- */
75
- export class ElementIdFromSourceAspectIdTool extends SourceAspectIdTool {
76
- getECSql(queryId) {
77
- return `SELECT Element.Id as resultId FROM BisCore.ExternalSourceAspect WHERE Identifier='${queryId}' AND [Kind]='Element'`;
78
- }
79
- }
80
- ElementIdFromSourceAspectIdTool.toolId = "ElementIdFromSourceAspectId";
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Tools
7
+ */
8
+ import { BentleyError } from "@itwin/core-bentley";
9
+ import { QueryRowFormat } from "@itwin/core-common";
10
+ import { IModelApp, NotifyMessageDetails, OutputMessagePriority, Tool } from "@itwin/core-frontend";
11
+ import { copyStringToClipboard } from "../ClipboardUtilities";
12
+ import { parseArgs } from "./parseArgs";
13
+ /** Base class for a tool that can convert between source aspect Ids and element Ids.
14
+ * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
15
+ * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
16
+ * @beta
17
+ */
18
+ export class SourceAspectIdTool extends Tool {
19
+ static get minArgs() { return 1; }
20
+ static get maxArgs() { return 2; }
21
+ async run(idToQuery, copyToClipboard) {
22
+ if (typeof idToQuery === "string")
23
+ await this.doQuery(idToQuery, true === copyToClipboard);
24
+ return true;
25
+ }
26
+ async parseAndRun(...keyinArgs) {
27
+ const args = parseArgs(keyinArgs);
28
+ return this.run(args.get("i"), args.getBoolean("c"));
29
+ }
30
+ async doQuery(queryId, copyToClipboard) {
31
+ const imodel = IModelApp.viewManager.selectedView?.iModel;
32
+ if (undefined === imodel)
33
+ return;
34
+ let resultId;
35
+ try {
36
+ // eslint-disable-next-line deprecation/deprecation
37
+ for await (const row of imodel.query(this.getECSql(queryId), undefined, { rowFormat: QueryRowFormat.UseJsPropertyNames, limit: { count: 1 } }))
38
+ resultId = row.resultId;
39
+ }
40
+ catch (ex) {
41
+ resultId = BentleyError.getErrorMessage(ex);
42
+ }
43
+ if (typeof resultId !== "string")
44
+ resultId = "NOT FOUND";
45
+ if (copyToClipboard)
46
+ copyStringToClipboard(resultId);
47
+ const message = `${queryId} => ${resultId}`;
48
+ IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Info, message));
49
+ }
50
+ }
51
+ /** Given a source aspect Id, output the Id of the corresponding element in the iModel.
52
+ * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
53
+ * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
54
+ * Arguments:
55
+ * - `id=elementId` where `elementId` is the numeric Id of the element of interest (e.g., `0x13a6c`; decimal notation is also permitted).
56
+ * - `copy=0|1` where `1` indicates the source aspect Id should be copied to the clipboard.
57
+ * The command outputs to the IModelApp.notifications the corresponding source aspect Id, or "NOT FOUND".
58
+ * @beta
59
+ */
60
+ class SourceAspectIdFromElementIdTool extends SourceAspectIdTool {
61
+ getECSql(queryId) {
62
+ return `SELECT Identifier as resultId FROM BisCore.ExternalSourceAspect WHERE Element.Id=${queryId} AND [Kind]='Element'`;
63
+ }
64
+ }
65
+ SourceAspectIdFromElementIdTool.toolId = "SourceAspectIdFromElementId";
66
+ export { SourceAspectIdFromElementIdTool };
67
+ /** 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.
68
+ * A "source aspect Id" is a string that identifies an object (such as an element) in the source document from which the iModel originated.
69
+ * For example, if the iModel was produced by the MicroStation bridge, the source aspect Id is usually a V8 element Id.
70
+ * Arguments:
71
+ * - `id=sourceAspectId` where `sourceAspectId` is the string identifier of the object of interest.
72
+ * - `copy=0|1` where `1` indicates the element Id should be copied to the clipboard.
73
+ * The command outputs to the IModelApp.notifications the corresponding element Id, or "NOT FOUND".
74
+ * @beta
75
+ */
76
+ class ElementIdFromSourceAspectIdTool extends SourceAspectIdTool {
77
+ getECSql(queryId) {
78
+ return `SELECT Element.Id as resultId FROM BisCore.ExternalSourceAspect WHERE Identifier='${queryId}' AND [Kind]='Element'`;
79
+ }
80
+ }
81
+ ElementIdFromSourceAspectIdTool.toolId = "ElementIdFromSourceAspectId";
82
+ export { ElementIdFromSourceAspectIdTool };
81
83
  //# 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,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AACpG,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC;;;;GAIG;AACH,MAAM,OAAgB,kBAAmB,SAAQ,IAAI;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,SAAS,CAAC,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,MAAA,SAAS,CAAC,WAAW,CAAC,YAAY,0CAAE,MAAM,CAAC;QAC1D,IAAI,SAAS,KAAK,MAAM;YACtB,OAAO;QAET,IAAI,QAAQ,CAAC;QACb,IAAI;YACF,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,cAAc,CAAC,kBAAkB,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC5I,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;SAC3B;QAAC,OAAO,EAAE,EAAE;YACX,QAAQ,GAAG,YAAY,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;SAC7C;QAED,IAAI,OAAO,QAAQ,KAAK,QAAQ;YAC9B,QAAQ,GAAG,WAAW,CAAC;QAEzB,IAAI,eAAe;YACjB,qBAAqB,CAAC,QAAQ,CAAC,CAAC;QAElC,MAAM,OAAO,GAAG,GAAG,OAAO,OAAO,QAAQ,EAAE,CAAC;QAC5C,SAAS,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,oBAAoB,CAAC,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IACvG,CAAC;CACF;AAED;;;;;;;;GAQG;AACH,MAAM,OAAO,+BAAgC,SAAQ,kBAAkB;IAG3D,QAAQ,CAAC,OAAe;QAChC,OAAO,oFAAoF,OAAO,uBAAuB,CAAC;IAC5H,CAAC;;AAJsB,sCAAM,GAAG,6BAA6B,CAAC;AAOhE;;;;;;;;GAQG;AACH,MAAM,OAAO,+BAAgC,SAAQ,kBAAkB;IAG3D,QAAQ,CAAC,OAAe;QAChC,OAAO,qFAAqF,OAAO,wBAAwB,CAAC;IAC9H,CAAC;;AAJsB,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.query(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,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AACpG,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC;;;;GAIG;AACH,MAAM,OAAgB,kBAAmB,SAAQ,IAAI;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,SAAS,CAAC,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,SAAS,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM,CAAC;QAC1D,IAAI,SAAS,KAAK,MAAM;YACtB,OAAO;QAET,IAAI,QAAQ,CAAC;QACb,IAAI;YACF,mDAAmD;YACnD,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,cAAc,CAAC,kBAAkB,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC5I,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;SAC3B;QAAC,OAAO,EAAE,EAAE;YACX,QAAQ,GAAG,YAAY,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;SAC7C;QAED,IAAI,OAAO,QAAQ,KAAK,QAAQ;YAC9B,QAAQ,GAAG,WAAW,CAAC;QAEzB,IAAI,eAAe;YACjB,qBAAqB,CAAC,QAAQ,CAAC,CAAC;QAElC,MAAM,OAAO,GAAG,GAAG,OAAO,OAAO,QAAQ,EAAE,CAAC;QAC5C,SAAS,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,oBAAoB,CAAC,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IACvG,CAAC;CACF;AAED;;;;;;;;GAQG;AACH,MAAa,+BAAgC,SAAQ,kBAAkB;IAG3D,QAAQ,CAAC,OAAe;QAChC,OAAO,oFAAoF,OAAO,uBAAuB,CAAC;IAC5H,CAAC;;AAJsB,sCAAM,GAAG,6BAA6B,CAAC;SADnD,+BAA+B;AAQ5C;;;;;;;;GAQG;AACH,MAAa,+BAAgC,SAAQ,kBAAkB;IAG3D,QAAQ,CAAC,OAAe;QAChC,OAAO,qFAAqF,OAAO,wBAAwB,CAAC;IAC9H,CAAC;;AAJsB,sCAAM,GAAG,6BAA6B,CAAC;SADnD,+BAA+B","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 // eslint-disable-next-line deprecation/deprecation\r\n for await (const row of imodel.query(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,13 +1,13 @@
1
- import { Tool } from "@itwin/core-frontend";
2
- /** 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.
3
- * Green indicates queued (http request not yet sent), red indicates active (http request sent). White indicates unexpected state.
4
- * @beta
5
- */
6
- export declare class ToggleTileRequestDecorationTool extends Tool {
7
- static toolId: string;
8
- static get minArgs(): number;
9
- static get maxArgs(): number;
10
- run(enable?: boolean): Promise<boolean>;
11
- parseAndRun(...args: string[]): Promise<boolean>;
12
- }
1
+ import { Tool } from "@itwin/core-frontend";
2
+ /** 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.
3
+ * Green indicates queued (http request not yet sent), red indicates active (http request sent). White indicates unexpected state.
4
+ * @beta
5
+ */
6
+ export declare class ToggleTileRequestDecorationTool extends Tool {
7
+ static toolId: string;
8
+ static get minArgs(): number;
9
+ static get maxArgs(): number;
10
+ run(enable?: boolean): Promise<boolean>;
11
+ parseAndRun(...args: string[]): Promise<boolean>;
12
+ }
13
13
  //# sourceMappingURL=TileRequestDecoration.d.ts.map
@@ -1,80 +1,81 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Tools
7
- */
8
- import { ColorDef, LinePixels } from "@itwin/core-common";
9
- import { GraphicType, IModelApp, Tool } from "@itwin/core-frontend";
10
- import { parseToggle } from "./parseToggle";
11
- class TileRequestDecoration {
12
- constructor(vp) {
13
- /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */
14
- this.useCachedDecorations = true;
15
- this._targetVp = vp;
16
- this._removeDecorator = IModelApp.viewManager.addDecorator(this);
17
- }
18
- stop() {
19
- if (this._removeDecorator) {
20
- this._removeDecorator();
21
- this._removeDecorator = undefined;
22
- }
23
- }
24
- decorate(context) {
25
- const tiles = IModelApp.tileAdmin.getRequestsForUser(this._targetVp);
26
- if (undefined === tiles)
27
- return;
28
- const map = new Map();
29
- for (const tile of tiles) {
30
- let builder = map.get(tile.tree);
31
- if (undefined === builder) {
32
- builder = context.createGraphicBuilder(GraphicType.WorldDecoration, tile.tree.iModelTransform);
33
- map.set(tile.tree, builder);
34
- }
35
- let color = ColorDef.white;
36
- if (undefined !== tile.request)
37
- color = tile.request.isQueued ? ColorDef.green : ColorDef.red;
38
- builder.setSymbology(color, color, 1, LinePixels.Solid);
39
- builder.addRangeBox(tile.range);
40
- }
41
- for (const builder of map.values())
42
- context.addDecorationFromBuilder(builder);
43
- }
44
- static toggle(vp, enabled) {
45
- const instance = TileRequestDecoration._instance;
46
- if (undefined !== enabled) {
47
- if ((undefined !== instance) === enabled)
48
- return;
49
- }
50
- if (undefined === instance) {
51
- TileRequestDecoration._instance = new TileRequestDecoration(vp);
52
- }
53
- else {
54
- instance.stop();
55
- TileRequestDecoration._instance = undefined;
56
- }
57
- }
58
- }
59
- /** 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.
60
- * Green indicates queued (http request not yet sent), red indicates active (http request sent). White indicates unexpected state.
61
- * @beta
62
- */
63
- export class ToggleTileRequestDecorationTool extends Tool {
64
- static get minArgs() { return 0; }
65
- static get maxArgs() { return 1; }
66
- async run(enable) {
67
- const vp = IModelApp.viewManager.selectedView;
68
- if (undefined !== vp)
69
- TileRequestDecoration.toggle(vp, enable);
70
- return true;
71
- }
72
- async parseAndRun(...args) {
73
- const enable = parseToggle(args[0]);
74
- if (typeof enable !== "string")
75
- await this.run(enable);
76
- return true;
77
- }
78
- }
79
- ToggleTileRequestDecorationTool.toolId = "ToggleTileRequestDecoration";
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Tools
7
+ */
8
+ import { ColorDef, LinePixels } from "@itwin/core-common";
9
+ import { GraphicType, IModelApp, Tool } from "@itwin/core-frontend";
10
+ import { parseToggle } from "./parseToggle";
11
+ class TileRequestDecoration {
12
+ constructor(vp) {
13
+ /** This will allow the render system to cache and reuse the decorations created by this decorator's decorate() method. */
14
+ this.useCachedDecorations = true;
15
+ this._targetVp = vp;
16
+ this._removeDecorator = IModelApp.viewManager.addDecorator(this);
17
+ }
18
+ stop() {
19
+ if (this._removeDecorator) {
20
+ this._removeDecorator();
21
+ this._removeDecorator = undefined;
22
+ }
23
+ }
24
+ decorate(context) {
25
+ const tiles = IModelApp.tileAdmin.getRequestsForUser(this._targetVp);
26
+ if (undefined === tiles)
27
+ return;
28
+ const map = new Map();
29
+ for (const tile of tiles) {
30
+ let builder = map.get(tile.tree);
31
+ if (undefined === builder) {
32
+ builder = context.createGraphicBuilder(GraphicType.WorldDecoration, tile.tree.iModelTransform);
33
+ map.set(tile.tree, builder);
34
+ }
35
+ let color = ColorDef.white;
36
+ if (undefined !== tile.request)
37
+ color = tile.request.isQueued ? ColorDef.green : ColorDef.red;
38
+ builder.setSymbology(color, color, 1, LinePixels.Solid);
39
+ builder.addRangeBox(tile.range);
40
+ }
41
+ for (const builder of map.values())
42
+ context.addDecorationFromBuilder(builder);
43
+ }
44
+ static toggle(vp, enabled) {
45
+ const instance = TileRequestDecoration._instance;
46
+ if (undefined !== enabled) {
47
+ if ((undefined !== instance) === enabled)
48
+ return;
49
+ }
50
+ if (undefined === instance) {
51
+ TileRequestDecoration._instance = new TileRequestDecoration(vp);
52
+ }
53
+ else {
54
+ instance.stop();
55
+ TileRequestDecoration._instance = undefined;
56
+ }
57
+ }
58
+ }
59
+ /** 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.
60
+ * Green indicates queued (http request not yet sent), red indicates active (http request sent). White indicates unexpected state.
61
+ * @beta
62
+ */
63
+ class ToggleTileRequestDecorationTool extends Tool {
64
+ static get minArgs() { return 0; }
65
+ static get maxArgs() { return 1; }
66
+ async run(enable) {
67
+ const vp = IModelApp.viewManager.selectedView;
68
+ if (undefined !== vp)
69
+ TileRequestDecoration.toggle(vp, enable);
70
+ return true;
71
+ }
72
+ async parseAndRun(...args) {
73
+ const enable = parseToggle(args[0]);
74
+ if (typeof enable !== "string")
75
+ await this.run(enable);
76
+ return true;
77
+ }
78
+ }
79
+ ToggleTileRequestDecorationTool.toolId = "ToggleTileRequestDecoration";
80
+ export { ToggleTileRequestDecorationTool };
80
81
  //# sourceMappingURL=TileRequestDecoration.js.map