@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":"TileMemoryBreakdown.js","sourceRoot":"","sources":["../../../src/widgets/TileMemoryBreakdown.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/** @packageDocumentation\r\n * @module Widgets\r\n */\r\n\r\nimport { IModelApp, IModelConnection, RenderMemory, Tile } from \"@itwin/core-frontend\";\r\nimport { createCheckBox } from \"../ui/CheckBox\";\r\nimport { formatMemory } from \"./MemoryTracker\";\r\n\r\ninterface TileMemoryCounter {\r\n numTiles: number;\r\n bytesUsed: number;\r\n}\r\n\r\nenum TileMemorySelector {\r\n Selected, // Tiles selected for display by at least one viewport.\r\n Ancestors, // Ancestors of selected tiles, themselves not selected for display by any viewport.\r\n Descendants, // Descendants of selected tiles, themselves not selected for display by any viewport.\r\n Orphaned, // Tiles not selected for display having no ancestors nor descendants selected for display.\r\n Total, // Total of all the above\r\n Count,\r\n}\r\n\r\nclass TileMemoryTracer {\r\n private readonly _stats = new RenderMemory.Statistics();\r\n private readonly _processedTiles = new Set<Tile>();\r\n public readonly counters: TileMemoryCounter[] = [];\r\n public numSelected = 0;\r\n\r\n public constructor() {\r\n for (let i = 0; i < TileMemorySelector.Count; i++)\r\n this.counters.push({ numTiles: 0, bytesUsed: 0 });\r\n }\r\n\r\n public update(): void {\r\n this.reset();\r\n\r\n const imodels = new Set<IModelConnection>();\r\n const selectedTiles = new Set<Tile>();\r\n for (const vp of IModelApp.viewManager) {\r\n imodels.add(vp.iModel);\r\n const tiles = IModelApp.tileAdmin.getTilesForUser(vp)?.selected;\r\n if (tiles)\r\n for (const tile of tiles)\r\n selectedTiles.add(tile);\r\n }\r\n\r\n for (const selected of selectedTiles)\r\n this.add(selected, TileMemorySelector.Selected);\r\n\r\n for (const selected of selectedTiles) {\r\n this.processParent(selected.parent);\r\n this.processChildren(selected.children);\r\n }\r\n\r\n for (const imodel of imodels) {\r\n imodel.tiles.forEachTreeOwner((owner) => {\r\n const tree = owner.tileTree;\r\n if (tree)\r\n this.processOrphan(tree.rootTile);\r\n });\r\n }\r\n\r\n this.counters[TileMemorySelector.Total].numTiles = this.counters.reduce((accum, counter) => accum + counter.numTiles, 0);\r\n this.counters[TileMemorySelector.Total].bytesUsed = this.counters.reduce((accum, counter) => accum + counter.bytesUsed, 0);\r\n }\r\n\r\n private reset(): void {\r\n this._processedTiles.clear();\r\n this.numSelected = 0;\r\n for (const counter of this.counters)\r\n counter.numTiles = counter.bytesUsed = 0;\r\n }\r\n\r\n private add(tile: Tile, selector: TileMemorySelector): void {\r\n this._processedTiles.add(tile);\r\n this._stats.clear();\r\n tile.collectStatistics(this._stats, false);\r\n\r\n const bytesUsed = this._stats.totalBytes;\r\n if (bytesUsed > 0) {\r\n const counter = this.counters[selector];\r\n ++counter.numTiles;\r\n counter.bytesUsed += bytesUsed;\r\n }\r\n }\r\n\r\n private processParent(parent: Tile | undefined): void {\r\n if (parent && !this._processedTiles.has(parent)) {\r\n this.add(parent, TileMemorySelector.Ancestors);\r\n this.processParent(parent.parent);\r\n }\r\n }\r\n\r\n private processChildren(children: Tile[] | undefined): void {\r\n if (!children)\r\n return;\r\n\r\n for (const child of children) {\r\n if (!this._processedTiles.has(child)) {\r\n this.add(child, TileMemorySelector.Descendants);\r\n this.processChildren(child.children);\r\n }\r\n }\r\n }\r\n\r\n private processOrphan(tile: Tile): void {\r\n if (!this._processedTiles.has(tile))\r\n this.add(tile, TileMemorySelector.Orphaned);\r\n\r\n const children = tile.children;\r\n if (children)\r\n for (const child of children)\r\n this.processOrphan(child);\r\n }\r\n}\r\n\r\nconst statsLabels = [\"Selected\", \"Ancestors\", \"Descendants\", \"Orphaned\", \"Total\"];\r\n\r\nfunction format(count: number, label: string, bytesUsed: number): string {\r\n return `${count} ${label}: ${formatMemory(bytesUsed)}`;\r\n}\r\n\r\n/** Breaks down the GPU memory allocated to tiles into categories displayed in two panes.\r\n * The left-hand pane obtains its information from [TileAdmin]($frontend), displaying the number of selected and unselected tiles that are consuming graphics memory along with the amount of memory consumed.\r\n * The right-hand pane computes its information from the set of all [TileTree]($frontend)s, broken down into groups:\r\n * - \"Selected\" - tiles that have been selected for display in at least one viewport.\r\n * - \"Ancestors\" - tiles not selected for display, but have descendents selected for display.\r\n * - \"Descendants\" - tiles not selected for display, but have ancestors selected for display.\r\n * - \"Orphans\" - tiles not selected for display that have no ancestors nor descendants selected for display.\r\n * - \"Total\" - totals of the above categories.\r\n *\r\n * Each row of data shows `(number of tiles) Group Name: amount of memory consumed by group`.\r\n * The number of tiles in each group includes only those tiles that are consuming a non-zero amount of GPU memory.\r\n * The widget includes a checkbox to toggle tracking and display of these statistics.\r\n * @beta\r\n */\r\nexport class TileMemoryBreakdown {\r\n private readonly _tracer = new TileMemoryTracer();\r\n private readonly _div: HTMLDivElement;\r\n private _curIntervalId?: NodeJS.Timer;\r\n private readonly _statsElements: HTMLElement[] = [];\r\n private readonly _totalsElements: HTMLElement[] = [];\r\n\r\n /** Construct a new breakdown widget as a child of the specified parent element. */\r\n public constructor(parent: HTMLElement) {\r\n createCheckBox({\r\n parent,\r\n name: \"Tile Memory Breakdown\",\r\n id: \"tileMemoryBreakdown\",\r\n handler: (_cb) => this.toggle(),\r\n });\r\n\r\n parent.appendChild(this._div = document.createElement(\"div\"));\r\n this._div.style.display = \"none\";\r\n this._div.style.textAlign = \"right\";\r\n\r\n const table = document.createElement(\"table\");\r\n table.style.width = \"100%\";\r\n table.setAttribute(\"border\", \"1\");\r\n this._div.appendChild(table);\r\n\r\n const row = document.createElement(\"tr\");\r\n const leftCell = document.createElement(\"td\");\r\n const rightCell = document.createElement(\"td\");\r\n leftCell.style.width = rightCell.style.width = \"50%\";\r\n row.appendChild(leftCell);\r\n row.appendChild(rightCell);\r\n table.appendChild(row);\r\n\r\n for (let i = 0; i < TileMemorySelector.Count; i++) {\r\n const div = document.createElement(\"div\");\r\n const elem = document.createElement(\"text\");\r\n this._statsElements.push(elem);\r\n div.appendChild(elem);\r\n rightCell.appendChild(div);\r\n }\r\n\r\n for (let i = 0; i < 3; i++) {\r\n const div = document.createElement(\"div\");\r\n const elem = document.createElement(\"text\");\r\n this._totalsElements.push(elem);\r\n div.appendChild(elem);\r\n leftCell.appendChild(div);\r\n }\r\n }\r\n\r\n public dispose(): void {\r\n this.clearInterval();\r\n }\r\n\r\n private toggle(): void {\r\n if (undefined !== this._curIntervalId) {\r\n this._div.style.display = \"none\";\r\n this.clearInterval();\r\n } else {\r\n this._div.style.display = \"block\";\r\n this.update();\r\n this._curIntervalId = setInterval(() => this.update(), 500);\r\n }\r\n }\r\n\r\n private clearInterval(): void {\r\n if (undefined !== this._curIntervalId) {\r\n clearInterval(this._curIntervalId);\r\n this._curIntervalId = undefined;\r\n }\r\n }\r\n\r\n private update(): void {\r\n this._tracer.update();\r\n for (let i = 0; i < this._statsElements.length; i++) {\r\n const counter = this._tracer.counters[i];\r\n this._statsElements[i].innerText = format(counter.numTiles, statsLabels[i], counter.bytesUsed);\r\n }\r\n\r\n let numUnselected = 0;\r\n let unselectedBytes = 0;\r\n for (const unselected of IModelApp.tileAdmin.unselectedLoadedTiles) {\r\n ++numUnselected;\r\n unselectedBytes += unselected.bytesUsed;\r\n }\r\n\r\n let numSelected = 0;\r\n let selectedBytes = 0;\r\n for (const selected of IModelApp.tileAdmin.selectedLoadedTiles) {\r\n ++numSelected;\r\n selectedBytes += selected.bytesUsed;\r\n }\r\n\r\n this._totalsElements[0].innerText = format(numSelected, \"Selected\", selectedBytes);\r\n this._totalsElements[1].innerText = format(numUnselected, \"Unselected\", unselectedBytes);\r\n this._totalsElements[2].innerText = format(numSelected + numUnselected, \"Total\", IModelApp.tileAdmin.totalTileContentBytes);\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"TileMemoryBreakdown.js","sourceRoot":"","sources":["../../../src/widgets/TileMemoryBreakdown.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/** @packageDocumentation\r\n * @module Widgets\r\n */\r\n\r\nimport { IModelApp, IModelConnection, RenderMemory, Tile } from \"@itwin/core-frontend\";\r\nimport { createCheckBox } from \"../ui/CheckBox\";\r\nimport { formatMemory } from \"./MemoryTracker\";\r\n\r\ninterface TileMemoryCounter {\r\n numTiles: number;\r\n bytesUsed: number;\r\n}\r\n\r\nenum TileMemorySelector {\r\n Selected, // Tiles selected for display by at least one viewport.\r\n Ancestors, // Ancestors of selected tiles, themselves not selected for display by any viewport.\r\n Descendants, // Descendants of selected tiles, themselves not selected for display by any viewport.\r\n Orphaned, // Tiles not selected for display having no ancestors nor descendants selected for display.\r\n Total, // Total of all the above\r\n Count,\r\n}\r\n\r\nclass TileMemoryTracer {\r\n private readonly _stats = new RenderMemory.Statistics();\r\n private readonly _processedTiles = new Set<Tile>();\r\n public readonly counters: TileMemoryCounter[] = [];\r\n public numSelected = 0;\r\n\r\n public constructor() {\r\n for (let i = 0; i < TileMemorySelector.Count; i++)\r\n this.counters.push({ numTiles: 0, bytesUsed: 0 });\r\n }\r\n\r\n public update(): void {\r\n this.reset();\r\n\r\n const imodels = new Set<IModelConnection>();\r\n const selectedTiles = new Set<Tile>();\r\n for (const vp of IModelApp.viewManager) {\r\n imodels.add(vp.iModel);\r\n const tiles = IModelApp.tileAdmin.getTilesForUser(vp)?.selected;\r\n if (tiles)\r\n for (const tile of tiles)\r\n selectedTiles.add(tile);\r\n }\r\n\r\n for (const selected of selectedTiles)\r\n this.add(selected, TileMemorySelector.Selected);\r\n\r\n for (const selected of selectedTiles) {\r\n this.processParent(selected.parent);\r\n this.processChildren(selected.children);\r\n }\r\n\r\n for (const imodel of imodels) {\r\n imodel.tiles.forEachTreeOwner((owner) => {\r\n const tree = owner.tileTree;\r\n if (tree)\r\n this.processOrphan(tree.rootTile);\r\n });\r\n }\r\n\r\n this.counters[TileMemorySelector.Total].numTiles = this.counters.reduce((accum, counter) => accum + counter.numTiles, 0);\r\n this.counters[TileMemorySelector.Total].bytesUsed = this.counters.reduce((accum, counter) => accum + counter.bytesUsed, 0);\r\n }\r\n\r\n private reset(): void {\r\n this._processedTiles.clear();\r\n this.numSelected = 0;\r\n for (const counter of this.counters)\r\n counter.numTiles = counter.bytesUsed = 0;\r\n }\r\n\r\n private add(tile: Tile, selector: TileMemorySelector): void {\r\n this._processedTiles.add(tile);\r\n this._stats.clear();\r\n tile.collectStatistics(this._stats, false);\r\n\r\n const bytesUsed = this._stats.totalBytes;\r\n if (bytesUsed > 0) {\r\n const counter = this.counters[selector];\r\n ++counter.numTiles;\r\n counter.bytesUsed += bytesUsed;\r\n }\r\n }\r\n\r\n private processParent(parent: Tile | undefined): void {\r\n if (parent && !this._processedTiles.has(parent)) {\r\n this.add(parent, TileMemorySelector.Ancestors);\r\n this.processParent(parent.parent);\r\n }\r\n }\r\n\r\n private processChildren(children: Tile[] | undefined): void {\r\n if (!children)\r\n return;\r\n\r\n for (const child of children) {\r\n if (!this._processedTiles.has(child)) {\r\n this.add(child, TileMemorySelector.Descendants);\r\n this.processChildren(child.children);\r\n }\r\n }\r\n }\r\n\r\n private processOrphan(tile: Tile): void {\r\n if (!this._processedTiles.has(tile))\r\n this.add(tile, TileMemorySelector.Orphaned);\r\n\r\n const children = tile.children;\r\n if (children)\r\n for (const child of children)\r\n this.processOrphan(child);\r\n }\r\n}\r\n\r\nconst statsLabels = [\"Selected\", \"Ancestors\", \"Descendants\", \"Orphaned\", \"Total\"];\r\n\r\nfunction format(count: number, label: string, bytesUsed: number): string {\r\n return `${count} ${label}: ${formatMemory(bytesUsed)}`;\r\n}\r\n\r\n/** Breaks down the GPU memory allocated to tiles into categories displayed in two panes.\r\n * The left-hand pane obtains its information from [TileAdmin]($frontend), displaying the number of selected and unselected tiles that are consuming graphics memory along with the amount of memory consumed.\r\n * The right-hand pane computes its information from the set of all [TileTree]($frontend)s, broken down into groups:\r\n * - \"Selected\" - tiles that have been selected for display in at least one viewport.\r\n * - \"Ancestors\" - tiles not selected for display, but have descendents selected for display.\r\n * - \"Descendants\" - tiles not selected for display, but have ancestors selected for display.\r\n * - \"Orphans\" - tiles not selected for display that have no ancestors nor descendants selected for display.\r\n * - \"Total\" - totals of the above categories.\r\n *\r\n * Each row of data shows `(number of tiles) Group Name: amount of memory consumed by group`.\r\n * The number of tiles in each group includes only those tiles that are consuming a non-zero amount of GPU memory.\r\n * The widget includes a checkbox to toggle tracking and display of these statistics.\r\n * @beta\r\n */\r\nexport class TileMemoryBreakdown {\r\n private readonly _tracer = new TileMemoryTracer();\r\n private readonly _div: HTMLDivElement;\r\n private _curIntervalId?: NodeJS.Timer;\r\n private readonly _statsElements: HTMLElement[] = [];\r\n private readonly _totalsElements: HTMLElement[] = [];\r\n\r\n /** Construct a new breakdown widget as a child of the specified parent element. */\r\n public constructor(parent: HTMLElement) {\r\n createCheckBox({\r\n parent,\r\n name: \"Tile Memory Breakdown\",\r\n id: \"tileMemoryBreakdown\",\r\n handler: (_cb) => this.toggle(),\r\n });\r\n\r\n parent.appendChild(this._div = document.createElement(\"div\"));\r\n this._div.style.display = \"none\";\r\n this._div.style.textAlign = \"right\";\r\n\r\n const table = document.createElement(\"table\");\r\n table.style.width = \"100%\";\r\n table.setAttribute(\"border\", \"1\");\r\n this._div.appendChild(table);\r\n\r\n const row = document.createElement(\"tr\");\r\n const leftCell = document.createElement(\"td\");\r\n const rightCell = document.createElement(\"td\");\r\n leftCell.style.width = rightCell.style.width = \"50%\";\r\n row.appendChild(leftCell);\r\n row.appendChild(rightCell);\r\n table.appendChild(row);\r\n\r\n for (let i = 0; i < TileMemorySelector.Count; i++) {\r\n const div = document.createElement(\"div\");\r\n const elem = document.createElement(\"text\");\r\n this._statsElements.push(elem);\r\n div.appendChild(elem);\r\n rightCell.appendChild(div);\r\n }\r\n\r\n for (let i = 0; i < 3; i++) {\r\n const div = document.createElement(\"div\");\r\n const elem = document.createElement(\"text\");\r\n this._totalsElements.push(elem);\r\n div.appendChild(elem);\r\n leftCell.appendChild(div);\r\n }\r\n }\r\n\r\n public dispose(): void {\r\n this.clearInterval();\r\n }\r\n\r\n private toggle(): void {\r\n if (undefined !== this._curIntervalId) {\r\n this._div.style.display = \"none\";\r\n this.clearInterval();\r\n } else {\r\n this._div.style.display = \"block\";\r\n this.update();\r\n this._curIntervalId = setInterval(() => this.update(), 500);\r\n }\r\n }\r\n\r\n private clearInterval(): void {\r\n if (undefined !== this._curIntervalId) {\r\n clearInterval(this._curIntervalId);\r\n this._curIntervalId = undefined;\r\n }\r\n }\r\n\r\n private update(): void {\r\n this._tracer.update();\r\n for (let i = 0; i < this._statsElements.length; i++) {\r\n const counter = this._tracer.counters[i];\r\n this._statsElements[i].innerText = format(counter.numTiles, statsLabels[i], counter.bytesUsed);\r\n }\r\n\r\n let numUnselected = 0;\r\n let unselectedBytes = 0;\r\n for (const unselected of IModelApp.tileAdmin.unselectedLoadedTiles) {\r\n ++numUnselected;\r\n unselectedBytes += unselected.bytesUsed;\r\n }\r\n\r\n let numSelected = 0;\r\n let selectedBytes = 0;\r\n for (const selected of IModelApp.tileAdmin.selectedLoadedTiles) {\r\n ++numSelected;\r\n selectedBytes += selected.bytesUsed;\r\n }\r\n\r\n this._totalsElements[0].innerText = format(numSelected, \"Selected\", selectedBytes);\r\n this._totalsElements[1].innerText = format(numUnselected, \"Unselected\", unselectedBytes);\r\n this._totalsElements[2].innerText = format(numSelected + numUnselected, \"Total\", IModelApp.tileAdmin.totalTileContentBytes);\r\n }\r\n}\r\n"]}
@@ -1,22 +1,22 @@
1
- /** @packageDocumentation
2
- * @module Widgets
3
- */
4
- import { Viewport } from "@itwin/core-frontend";
5
- /** Outputs statistics related to tile requests including the current number of active, pending, selected, and ready tile requests; as well as cumulative statistics for the session including the number of failed, timed-out, empty, and elided tile requests.
6
- * @beta
7
- */
8
- export declare class TileStatisticsTracker {
9
- private readonly _statElements;
10
- private readonly _div;
11
- private readonly _vp;
12
- private _curIntervalId?;
13
- constructor(parent: HTMLElement, vp: Viewport);
14
- dispose(): void;
15
- private addMaxActive;
16
- private updateMaxActive;
17
- private clearInterval;
18
- private toggle;
19
- private update;
20
- private reset;
21
- }
1
+ /** @packageDocumentation
2
+ * @module Widgets
3
+ */
4
+ import { Viewport } from "@itwin/core-frontend";
5
+ /** Outputs statistics related to tile requests including the current number of active, pending, selected, and ready tile requests; as well as cumulative statistics for the session including the number of failed, timed-out, empty, and elided tile requests.
6
+ * @beta
7
+ */
8
+ export declare class TileStatisticsTracker {
9
+ private readonly _statElements;
10
+ private readonly _div;
11
+ private readonly _vp;
12
+ private _curIntervalId?;
13
+ constructor(parent: HTMLElement, vp: Viewport);
14
+ dispose(): void;
15
+ private addMaxActive;
16
+ private updateMaxActive;
17
+ private clearInterval;
18
+ private toggle;
19
+ private update;
20
+ private reset;
21
+ }
22
22
  //# sourceMappingURL=TileStatisticsTracker.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TileStatisticsTracker.d.ts","sourceRoot":"","sources":["../../../src/widgets/TileStatisticsTracker.ts"],"names":[],"mappings":"AAKA;;GAEG;AAEH,OAAO,EAAwB,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAwCtE;;GAEG;AACH,qBAAa,qBAAqB;IAChC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAqB;IACnD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAiB;IACtC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAW;IAC/B,OAAO,CAAC,cAAc,CAAC,CAAe;gBAEnB,MAAM,EAAE,WAAW,EAAE,EAAE,EAAE,QAAQ;IAgD7C,OAAO,IAAI,IAAI;IAItB,OAAO,CAAC,YAAY;IAsBpB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,MAAM;IAad,OAAO,CAAC,MAAM;IASd,OAAO,CAAC,KAAK;CAId"}
1
+ {"version":3,"file":"TileStatisticsTracker.d.ts","sourceRoot":"","sources":["../../../src/widgets/TileStatisticsTracker.ts"],"names":[],"mappings":"AAKA;;GAEG;AAEH,OAAO,EAAwB,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AA0CtE;;GAEG;AACH,qBAAa,qBAAqB;IAChC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAqB;IACnD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAiB;IACtC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAW;IAC/B,OAAO,CAAC,cAAc,CAAC,CAAe;gBAEnB,MAAM,EAAE,WAAW,EAAE,EAAE,EAAE,QAAQ;IAgD7C,OAAO,IAAI,IAAI;IAItB,OAAO,CAAC,YAAY;IAsBpB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,MAAM;IAad,OAAO,CAAC,MAAM;IASd,OAAO,CAAC,KAAK;CAId"}
@@ -1,139 +1,141 @@
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 Widgets
7
- */
8
- import { IModelApp } from "@itwin/core-frontend";
9
- import { createButton } from "../ui/Button";
10
- import { createCheckBox } from "../ui/CheckBox";
11
- import { createNumericInput } from "../ui/NumericInput";
12
- function computeProgress(vp) {
13
- const ready = vp.numReadyTiles;
14
- const requested = vp.numRequestedTiles;
15
- const total = ready + requested;
16
- const ratio = (total > 0) ? (ready / total) : 1.0;
17
- return Math.round(ratio * 100);
18
- }
19
- const statEntries = [
20
- { getValue: (stats, vp) => { var _a, _b; return stats.numActiveRequests + ((_b = (_a = IModelApp.tileAdmin.getTilesForUser(vp)) === null || _a === void 0 ? void 0 : _a.external.requested) !== null && _b !== void 0 ? _b : 0); }, label: "Active" },
21
- { getValue: (stats, _vp) => stats.numPendingRequests, label: "Pending" },
22
- { getValue: (stats, _vp) => stats.numCanceled, label: "Canceled" },
23
- { getValue: (stats, _vp) => stats.numActiveRequests + stats.numPendingRequests, label: "Total" },
24
- { getValue: (_stats, vp) => vp.numSelectedTiles, label: "Selected" },
25
- { getValue: (_stats, vp) => vp.numReadyTiles, label: "Ready" },
26
- { getValue: (_stats, vp) => computeProgress(vp), label: "Progress" },
27
- { getValue: (stats, _vp) => stats.totalCompletedRequests, label: "Completed" },
28
- { getValue: (stats, _vp) => stats.totalTimedOutRequests, label: "Timed Out" },
29
- { getValue: (stats, _vp) => stats.totalFailedRequests, label: "Failed" },
30
- { getValue: (stats, _vp) => stats.totalEmptyTiles, label: "Empty" },
31
- { getValue: (stats, _vp) => stats.totalUndisplayableTiles, label: "Undisplayable" },
32
- { getValue: (stats, _vp) => stats.totalElidedTiles, label: "Elided" },
33
- { getValue: (stats, _vp) => stats.totalCacheMisses, label: "Cache Misses" },
34
- { getValue: (stats, _vp) => stats.totalDispatchedRequests, label: "Dispatched" },
35
- { getValue: (stats, _vp) => stats.totalAbortedRequests, label: "Aborted" },
36
- ];
37
- const indexOfFirstGlobalStatistic = 7; // "Completed"
38
- /** Outputs statistics related to tile requests including the current number of active, pending, selected, and ready tile requests; as well as cumulative statistics for the session including the number of failed, timed-out, empty, and elided tile requests.
39
- * @beta
40
- */
41
- export class TileStatisticsTracker {
42
- constructor(parent, vp) {
43
- this._statElements = [];
44
- this._vp = vp;
45
- this.addMaxActive(parent);
46
- createCheckBox({
47
- parent,
48
- name: "Track Tile Requests",
49
- id: "stats_trackMemory",
50
- handler: (_cb) => this.toggle(),
51
- });
52
- this._div = document.createElement("div");
53
- this._div.style.display = "none";
54
- this._div.style.textAlign = "right";
55
- const table = document.createElement("table");
56
- table.style.width = "100%";
57
- table.setAttribute("border", "1");
58
- this._div.appendChild(table);
59
- const row = document.createElement("tr");
60
- const frameColumn = document.createElement("td");
61
- const globalColumn = document.createElement("td");
62
- frameColumn.style.width = globalColumn.style.width = "50%";
63
- row.appendChild(frameColumn);
64
- row.appendChild(globalColumn);
65
- table.appendChild(row);
66
- for (let i = 0; i < statEntries.length; i++) {
67
- const div = document.createElement("div");
68
- const elem = document.createElement("text");
69
- this._statElements[i] = elem;
70
- div.appendChild(elem);
71
- const column = i >= indexOfFirstGlobalStatistic ? globalColumn : frameColumn;
72
- column.appendChild(div);
73
- }
74
- const resetButton = createButton({
75
- parent: this._div,
76
- value: "Reset",
77
- tooltip: "Reset all cumulative statistics",
78
- handler: () => this.reset(),
79
- });
80
- resetButton.div.style.textAlign = "center";
81
- parent.appendChild(this._div);
82
- }
83
- dispose() {
84
- this.clearInterval();
85
- }
86
- addMaxActive(parent) {
87
- const div = document.createElement("div");
88
- const label = document.createElement("label");
89
- label.style.display = "inline";
90
- label.htmlFor = "maxActiveRequests";
91
- label.innerText = "Max Active Requests: ";
92
- div.appendChild(label);
93
- createNumericInput({
94
- parent: div,
95
- id: "maxActiveRequests",
96
- display: "inline",
97
- min: 0,
98
- step: 1,
99
- value: IModelApp.tileAdmin.channels.rpcConcurrency,
100
- handler: (value, _input) => this.updateMaxActive(value),
101
- });
102
- parent.appendChild(div);
103
- }
104
- updateMaxActive(value) {
105
- IModelApp.tileAdmin.channels.setRpcConcurrency(value);
106
- }
107
- clearInterval() {
108
- if (undefined !== this._curIntervalId) {
109
- clearInterval(this._curIntervalId);
110
- this._curIntervalId = undefined;
111
- }
112
- }
113
- toggle() {
114
- if (undefined !== this._curIntervalId) {
115
- // Currently on - turn off.
116
- this._div.style.display = "none";
117
- this.clearInterval();
118
- }
119
- else {
120
- // Currently off - turn on.
121
- this._div.style.display = "block";
122
- this.update();
123
- this._curIntervalId = setInterval(() => this.update(), 500);
124
- }
125
- }
126
- update() {
127
- const stats = IModelApp.tileAdmin.statistics;
128
- for (let i = 0; i < statEntries.length; i++) {
129
- const stat = statEntries[i];
130
- const label = `${stat.label}: ${stat.getValue(stats, this._vp)}`;
131
- this._statElements[i].innerText = label;
132
- }
133
- }
134
- reset() {
135
- IModelApp.tileAdmin.resetStatistics();
136
- this.update();
137
- }
138
- }
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 Widgets
7
+ */
8
+ import { IModelApp } from "@itwin/core-frontend";
9
+ import { createButton } from "../ui/Button";
10
+ import { createCheckBox } from "../ui/CheckBox";
11
+ import { createNumericInput } from "../ui/NumericInput";
12
+ function computeProgress(vp) {
13
+ const ready = vp.numReadyTiles;
14
+ const requested = vp.numRequestedTiles;
15
+ const total = ready + requested;
16
+ const ratio = (total > 0) ? (ready / total) : 1.0;
17
+ return Math.round(ratio * 100);
18
+ }
19
+ const statEntries = [
20
+ { getValue: (stats, vp) => stats.numActiveRequests + (IModelApp.tileAdmin.getTilesForUser(vp)?.external.requested ?? 0), label: "Active" },
21
+ { getValue: (stats, _vp) => stats.numPendingRequests, label: "Pending" },
22
+ { getValue: (stats, _vp) => stats.numCanceled, label: "Canceled" },
23
+ { getValue: (stats, _vp) => stats.numActiveRequests + stats.numPendingRequests, label: "Total" },
24
+ { getValue: (_stats, vp) => vp.numSelectedTiles, label: "Selected" },
25
+ { getValue: (_stats, vp) => vp.numReadyTiles, label: "Ready" },
26
+ { getValue: (_stats, vp) => computeProgress(vp), label: "Progress" },
27
+ { getValue: (stats, _vp) => stats.totalCompletedRequests, label: "Completed" },
28
+ { getValue: (stats, _vp) => stats.totalTimedOutRequests, label: "Timed Out" },
29
+ { getValue: (stats, _vp) => stats.totalFailedRequests, label: "Failed" },
30
+ { getValue: (stats, _vp) => stats.totalEmptyTiles, label: "Empty" },
31
+ { getValue: (stats, _vp) => stats.totalUndisplayableTiles, label: "Undisplayable" },
32
+ { getValue: (stats, _vp) => stats.totalElidedTiles, label: "Elided" },
33
+ { getValue: (stats, _vp) => stats.totalCacheMisses, label: "Cache Misses" },
34
+ { getValue: (stats, _vp) => stats.totalDispatchedRequests, label: "Dispatched" },
35
+ { getValue: (stats, _vp) => stats.totalAbortedRequests, label: "Aborted" },
36
+ { getValue: (stats) => Math.round(stats.decoding.mean), label: "Decoding mean time (ms)" },
37
+ { getValue: (stats) => stats.decoding.max, label: "Decoding max time (ms)" },
38
+ ];
39
+ const indexOfFirstGlobalStatistic = 7; // "Completed"
40
+ /** Outputs statistics related to tile requests including the current number of active, pending, selected, and ready tile requests; as well as cumulative statistics for the session including the number of failed, timed-out, empty, and elided tile requests.
41
+ * @beta
42
+ */
43
+ export class TileStatisticsTracker {
44
+ constructor(parent, vp) {
45
+ this._statElements = [];
46
+ this._vp = vp;
47
+ this.addMaxActive(parent);
48
+ createCheckBox({
49
+ parent,
50
+ name: "Track Tile Requests",
51
+ id: "stats_trackMemory",
52
+ handler: (_cb) => this.toggle(),
53
+ });
54
+ this._div = document.createElement("div");
55
+ this._div.style.display = "none";
56
+ this._div.style.textAlign = "right";
57
+ const table = document.createElement("table");
58
+ table.style.width = "100%";
59
+ table.setAttribute("border", "1");
60
+ this._div.appendChild(table);
61
+ const row = document.createElement("tr");
62
+ const frameColumn = document.createElement("td");
63
+ const globalColumn = document.createElement("td");
64
+ frameColumn.style.width = globalColumn.style.width = "50%";
65
+ row.appendChild(frameColumn);
66
+ row.appendChild(globalColumn);
67
+ table.appendChild(row);
68
+ for (let i = 0; i < statEntries.length; i++) {
69
+ const div = document.createElement("div");
70
+ const elem = document.createElement("text");
71
+ this._statElements[i] = elem;
72
+ div.appendChild(elem);
73
+ const column = i >= indexOfFirstGlobalStatistic ? globalColumn : frameColumn;
74
+ column.appendChild(div);
75
+ }
76
+ const resetButton = createButton({
77
+ parent: this._div,
78
+ value: "Reset",
79
+ tooltip: "Reset all cumulative statistics",
80
+ handler: () => this.reset(),
81
+ });
82
+ resetButton.div.style.textAlign = "center";
83
+ parent.appendChild(this._div);
84
+ }
85
+ dispose() {
86
+ this.clearInterval();
87
+ }
88
+ addMaxActive(parent) {
89
+ const div = document.createElement("div");
90
+ const label = document.createElement("label");
91
+ label.style.display = "inline";
92
+ label.htmlFor = "maxActiveRequests";
93
+ label.innerText = "Max Active Requests: ";
94
+ div.appendChild(label);
95
+ createNumericInput({
96
+ parent: div,
97
+ id: "maxActiveRequests",
98
+ display: "inline",
99
+ min: 0,
100
+ step: 1,
101
+ value: IModelApp.tileAdmin.channels.rpcConcurrency,
102
+ handler: (value, _input) => this.updateMaxActive(value),
103
+ });
104
+ parent.appendChild(div);
105
+ }
106
+ updateMaxActive(value) {
107
+ IModelApp.tileAdmin.channels.setRpcConcurrency(value);
108
+ }
109
+ clearInterval() {
110
+ if (undefined !== this._curIntervalId) {
111
+ clearInterval(this._curIntervalId);
112
+ this._curIntervalId = undefined;
113
+ }
114
+ }
115
+ toggle() {
116
+ if (undefined !== this._curIntervalId) {
117
+ // Currently on - turn off.
118
+ this._div.style.display = "none";
119
+ this.clearInterval();
120
+ }
121
+ else {
122
+ // Currently off - turn on.
123
+ this._div.style.display = "block";
124
+ this.update();
125
+ this._curIntervalId = setInterval(() => this.update(), 500);
126
+ }
127
+ }
128
+ update() {
129
+ const stats = IModelApp.tileAdmin.statistics;
130
+ for (let i = 0; i < statEntries.length; i++) {
131
+ const stat = statEntries[i];
132
+ const label = `${stat.label}: ${stat.getValue(stats, this._vp)}`;
133
+ this._statElements[i].innerText = label;
134
+ }
135
+ }
136
+ reset() {
137
+ IModelApp.tileAdmin.resetStatistics();
138
+ this.update();
139
+ }
140
+ }
139
141
  //# sourceMappingURL=TileStatisticsTracker.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TileStatisticsTracker.js","sourceRoot":"","sources":["../../../src/widgets/TileStatisticsTracker.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 Widgets\r\n */\r\n\r\nimport { IModelApp, TileAdmin, Viewport } from \"@itwin/core-frontend\";\r\nimport { createButton } from \"../ui/Button\";\r\nimport { createCheckBox } from \"../ui/CheckBox\";\r\nimport { createNumericInput } from \"../ui/NumericInput\";\r\n\r\ntype GetStatValue = (stats: TileAdmin.Statistics, vp: Viewport) => number;\r\ninterface StatEntry {\r\n label: string;\r\n getValue: GetStatValue;\r\n}\r\n\r\nfunction computeProgress(vp: Viewport): number {\r\n const ready = vp.numReadyTiles;\r\n const requested = vp.numRequestedTiles;\r\n const total = ready + requested;\r\n const ratio = (total > 0) ? (ready / total) : 1.0;\r\n return Math.round(ratio * 100);\r\n}\r\n\r\nconst statEntries: StatEntry[] = [\r\n { getValue: (stats, vp) => stats.numActiveRequests + (IModelApp.tileAdmin.getTilesForUser(vp)?.external.requested ?? 0), label: \"Active\" },\r\n { getValue: (stats, _vp) => stats.numPendingRequests, label: \"Pending\" },\r\n { getValue: (stats, _vp) => stats.numCanceled, label: \"Canceled\" },\r\n { getValue: (stats, _vp) => stats.numActiveRequests + stats.numPendingRequests, label: \"Total\" },\r\n { getValue: (_stats, vp) => vp.numSelectedTiles, label: \"Selected\" },\r\n { getValue: (_stats, vp) => vp.numReadyTiles, label: \"Ready\" },\r\n { getValue: (_stats, vp) => computeProgress(vp), label: \"Progress\" },\r\n { getValue: (stats, _vp) => stats.totalCompletedRequests, label: \"Completed\" },\r\n { getValue: (stats, _vp) => stats.totalTimedOutRequests, label: \"Timed Out\" },\r\n { getValue: (stats, _vp) => stats.totalFailedRequests, label: \"Failed\" },\r\n { getValue: (stats, _vp) => stats.totalEmptyTiles, label: \"Empty\" },\r\n { getValue: (stats, _vp) => stats.totalUndisplayableTiles, label: \"Undisplayable\" },\r\n { getValue: (stats, _vp) => stats.totalElidedTiles, label: \"Elided\" },\r\n { getValue: (stats, _vp) => stats.totalCacheMisses, label: \"Cache Misses\" },\r\n { getValue: (stats, _vp) => stats.totalDispatchedRequests, label: \"Dispatched\" },\r\n { getValue: (stats, _vp) => stats.totalAbortedRequests, label: \"Aborted\" },\r\n];\r\n\r\nconst indexOfFirstGlobalStatistic = 7; // \"Completed\"\r\n\r\n/** Outputs statistics related to tile requests including the current number of active, pending, selected, and ready tile requests; as well as cumulative statistics for the session including the number of failed, timed-out, empty, and elided tile requests.\r\n * @beta\r\n */\r\nexport class TileStatisticsTracker {\r\n private readonly _statElements: HTMLElement[] = [];\r\n private readonly _div: HTMLDivElement;\r\n private readonly _vp: Viewport;\r\n private _curIntervalId?: NodeJS.Timer;\r\n\r\n public constructor(parent: HTMLElement, vp: Viewport) {\r\n this._vp = vp;\r\n this.addMaxActive(parent);\r\n createCheckBox({\r\n parent,\r\n name: \"Track Tile Requests\",\r\n id: \"stats_trackMemory\",\r\n handler: (_cb) => this.toggle(),\r\n });\r\n\r\n this._div = document.createElement(\"div\");\r\n this._div.style.display = \"none\";\r\n this._div.style.textAlign = \"right\";\r\n\r\n const table = document.createElement(\"table\");\r\n table.style.width = \"100%\";\r\n table.setAttribute(\"border\", \"1\");\r\n this._div.appendChild(table);\r\n\r\n const row = document.createElement(\"tr\");\r\n const frameColumn = document.createElement(\"td\");\r\n const globalColumn = document.createElement(\"td\");\r\n frameColumn.style.width = globalColumn.style.width = \"50%\";\r\n row.appendChild(frameColumn);\r\n row.appendChild(globalColumn);\r\n table.appendChild(row);\r\n\r\n for (let i = 0; i < statEntries.length; i++) {\r\n const div = document.createElement(\"div\");\r\n const elem = document.createElement(\"text\");\r\n this._statElements[i] = elem;\r\n div.appendChild(elem);\r\n\r\n const column = i >= indexOfFirstGlobalStatistic ? globalColumn : frameColumn;\r\n column.appendChild(div);\r\n }\r\n\r\n const resetButton = createButton({\r\n parent: this._div,\r\n value: \"Reset\",\r\n tooltip: \"Reset all cumulative statistics\",\r\n handler: () => this.reset(),\r\n });\r\n resetButton.div.style.textAlign = \"center\";\r\n\r\n parent.appendChild(this._div);\r\n }\r\n\r\n public dispose(): void {\r\n this.clearInterval();\r\n }\r\n\r\n private addMaxActive(parent: HTMLElement): void {\r\n const div = document.createElement(\"div\");\r\n\r\n const label = document.createElement(\"label\");\r\n label.style.display = \"inline\";\r\n label.htmlFor = \"maxActiveRequests\";\r\n label.innerText = \"Max Active Requests: \";\r\n div.appendChild(label);\r\n\r\n createNumericInput({\r\n parent: div,\r\n id: \"maxActiveRequests\",\r\n display: \"inline\",\r\n min: 0,\r\n step: 1,\r\n value: IModelApp.tileAdmin.channels.rpcConcurrency,\r\n handler: (value, _input) => this.updateMaxActive(value),\r\n });\r\n\r\n parent.appendChild(div);\r\n }\r\n\r\n private updateMaxActive(value: number): void {\r\n IModelApp.tileAdmin.channels.setRpcConcurrency(value);\r\n }\r\n\r\n private clearInterval(): void {\r\n if (undefined !== this._curIntervalId) {\r\n clearInterval(this._curIntervalId);\r\n this._curIntervalId = undefined;\r\n }\r\n }\r\n\r\n private toggle(): void {\r\n if (undefined !== this._curIntervalId) {\r\n // Currently on - turn off.\r\n this._div.style.display = \"none\";\r\n this.clearInterval();\r\n } else {\r\n // Currently off - turn on.\r\n this._div.style.display = \"block\";\r\n this.update();\r\n this._curIntervalId = setInterval(() => this.update(), 500);\r\n }\r\n }\r\n\r\n private update(): void {\r\n const stats = IModelApp.tileAdmin.statistics;\r\n for (let i = 0; i < statEntries.length; i++) {\r\n const stat = statEntries[i];\r\n const label = `${stat.label}: ${stat.getValue(stats, this._vp)}`;\r\n this._statElements[i].innerText = label;\r\n }\r\n }\r\n\r\n private reset(): void {\r\n IModelApp.tileAdmin.resetStatistics();\r\n this.update();\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"TileStatisticsTracker.js","sourceRoot":"","sources":["../../../src/widgets/TileStatisticsTracker.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAE/F;;GAEG;AAEH,OAAO,EAAE,SAAS,EAAuB,MAAM,sBAAsB,CAAC;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAQxD,SAAS,eAAe,CAAC,EAAY;IACnC,MAAM,KAAK,GAAG,EAAE,CAAC,aAAa,CAAC;IAC/B,MAAM,SAAS,GAAG,EAAE,CAAC,iBAAiB,CAAC;IACvC,MAAM,KAAK,GAAG,KAAK,GAAG,SAAS,CAAC;IAChC,MAAM,KAAK,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IAClD,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;AACjC,CAAC;AAED,MAAM,WAAW,GAAgB;IAC/B,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,iBAAiB,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,SAAS,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE;IAC1I,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,kBAAkB,EAAE,KAAK,EAAE,SAAS,EAAE;IACxE,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,EAAE,UAAU,EAAE;IAClE,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,iBAAiB,GAAG,KAAK,CAAC,kBAAkB,EAAE,KAAK,EAAE,OAAO,EAAE;IAChG,EAAE,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,gBAAgB,EAAE,KAAK,EAAE,UAAU,EAAE;IACpE,EAAE,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,aAAa,EAAE,KAAK,EAAE,OAAO,EAAE;IAC9D,EAAE,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,eAAe,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE;IACpE,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,sBAAsB,EAAE,KAAK,EAAE,WAAW,EAAE;IAC9E,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,qBAAqB,EAAE,KAAK,EAAE,WAAW,EAAE;IAC7E,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,mBAAmB,EAAE,KAAK,EAAE,QAAQ,EAAE;IACxE,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,eAAe,EAAE,KAAK,EAAE,OAAO,EAAE;IACnE,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,uBAAuB,EAAE,KAAK,EAAE,eAAe,EAAE;IACnF,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,gBAAgB,EAAE,KAAK,EAAE,QAAQ,EAAE;IACrE,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,gBAAgB,EAAE,KAAK,EAAE,cAAc,EAAE;IAC3E,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,uBAAuB,EAAE,KAAK,EAAE,YAAY,EAAE;IAChF,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,oBAAoB,EAAE,KAAK,EAAE,SAAS,EAAE;IAC1E,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,yBAAyB,EAAE;IAC1F,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,EAAE,KAAK,EAAE,wBAAwB,EAAE;CAC7E,CAAC;AAEF,MAAM,2BAA2B,GAAG,CAAC,CAAC,CAAC,cAAc;AAErD;;GAEG;AACH,MAAM,OAAO,qBAAqB;IAMhC,YAAmB,MAAmB,EAAE,EAAY;QALnC,kBAAa,GAAkB,EAAE,CAAC;QAMjD,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;QACd,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC1B,cAAc,CAAC;YACb,MAAM;YACN,IAAI,EAAE,qBAAqB;YAC3B,EAAE,EAAE,mBAAmB;YACvB,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE;SAChC,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;QACjC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,OAAO,CAAC;QAEpC,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC9C,KAAK,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC;QAC3B,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAE7B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACjD,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAClD,WAAW,CAAC,KAAK,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QAC3D,GAAG,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAC7B,GAAG,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAC9B,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAEvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC1C,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;YAC7B,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAEtB,MAAM,MAAM,GAAG,CAAC,IAAI,2BAA2B,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,CAAC;YAC7E,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;SACzB;QAED,MAAM,WAAW,GAAG,YAAY,CAAC;YAC/B,MAAM,EAAE,IAAI,CAAC,IAAI;YACjB,KAAK,EAAE,OAAO;YACd,OAAO,EAAE,iCAAiC;YAC1C,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE;SAC5B,CAAC,CAAC;QACH,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,GAAG,QAAQ,CAAC;QAE3C,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAEO,YAAY,CAAC,MAAmB;QACtC,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE1C,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC9C,KAAK,CAAC,KAAK,CAAC,OAAO,GAAG,QAAQ,CAAC;QAC/B,KAAK,CAAC,OAAO,GAAG,mBAAmB,CAAC;QACpC,KAAK,CAAC,SAAS,GAAG,uBAAuB,CAAC;QAC1C,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAEvB,kBAAkB,CAAC;YACjB,MAAM,EAAE,GAAG;YACX,EAAE,EAAE,mBAAmB;YACvB,OAAO,EAAE,QAAQ;YACjB,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,CAAC;YACP,KAAK,EAAE,SAAS,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc;YAClD,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC;SACxD,CAAC,CAAC;QAEH,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAEO,eAAe,CAAC,KAAa;QACnC,SAAS,CAAC,SAAS,CAAC,QAAQ,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IAEO,aAAa;QACnB,IAAI,SAAS,KAAK,IAAI,CAAC,cAAc,EAAE;YACrC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACnC,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;SACjC;IACH,CAAC;IAEO,MAAM;QACZ,IAAI,SAAS,KAAK,IAAI,CAAC,cAAc,EAAE;YACrC,2BAA2B;YAC3B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;YACjC,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;aAAM;YACL,2BAA2B;YAC3B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;YAClC,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,GAAG,CAAC,CAAC;SAC7D;IACH,CAAC;IAEO,MAAM;QACZ,MAAM,KAAK,GAAG,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC;QAC7C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,IAAI,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;YAC5B,MAAM,KAAK,GAAG,GAAG,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;YACjE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC;SACzC;IACH,CAAC;IAEO,KAAK;QACX,SAAS,CAAC,SAAS,CAAC,eAAe,EAAE,CAAC;QACtC,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;CACF","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 Widgets\r\n */\r\n\r\nimport { IModelApp, TileAdmin, Viewport } from \"@itwin/core-frontend\";\r\nimport { createButton } from \"../ui/Button\";\r\nimport { createCheckBox } from \"../ui/CheckBox\";\r\nimport { createNumericInput } from \"../ui/NumericInput\";\r\n\r\ntype GetStatValue = (stats: TileAdmin.Statistics, vp: Viewport) => number;\r\ninterface StatEntry {\r\n label: string;\r\n getValue: GetStatValue;\r\n}\r\n\r\nfunction computeProgress(vp: Viewport): number {\r\n const ready = vp.numReadyTiles;\r\n const requested = vp.numRequestedTiles;\r\n const total = ready + requested;\r\n const ratio = (total > 0) ? (ready / total) : 1.0;\r\n return Math.round(ratio * 100);\r\n}\r\n\r\nconst statEntries: StatEntry[] = [\r\n { getValue: (stats, vp) => stats.numActiveRequests + (IModelApp.tileAdmin.getTilesForUser(vp)?.external.requested ?? 0), label: \"Active\" },\r\n { getValue: (stats, _vp) => stats.numPendingRequests, label: \"Pending\" },\r\n { getValue: (stats, _vp) => stats.numCanceled, label: \"Canceled\" },\r\n { getValue: (stats, _vp) => stats.numActiveRequests + stats.numPendingRequests, label: \"Total\" },\r\n { getValue: (_stats, vp) => vp.numSelectedTiles, label: \"Selected\" },\r\n { getValue: (_stats, vp) => vp.numReadyTiles, label: \"Ready\" },\r\n { getValue: (_stats, vp) => computeProgress(vp), label: \"Progress\" },\r\n { getValue: (stats, _vp) => stats.totalCompletedRequests, label: \"Completed\" },\r\n { getValue: (stats, _vp) => stats.totalTimedOutRequests, label: \"Timed Out\" },\r\n { getValue: (stats, _vp) => stats.totalFailedRequests, label: \"Failed\" },\r\n { getValue: (stats, _vp) => stats.totalEmptyTiles, label: \"Empty\" },\r\n { getValue: (stats, _vp) => stats.totalUndisplayableTiles, label: \"Undisplayable\" },\r\n { getValue: (stats, _vp) => stats.totalElidedTiles, label: \"Elided\" },\r\n { getValue: (stats, _vp) => stats.totalCacheMisses, label: \"Cache Misses\" },\r\n { getValue: (stats, _vp) => stats.totalDispatchedRequests, label: \"Dispatched\" },\r\n { getValue: (stats, _vp) => stats.totalAbortedRequests, label: \"Aborted\" },\r\n { getValue: (stats) => Math.round(stats.decoding.mean), label: \"Decoding mean time (ms)\" },\r\n { getValue: (stats) => stats.decoding.max, label: \"Decoding max time (ms)\" },\r\n];\r\n\r\nconst indexOfFirstGlobalStatistic = 7; // \"Completed\"\r\n\r\n/** Outputs statistics related to tile requests including the current number of active, pending, selected, and ready tile requests; as well as cumulative statistics for the session including the number of failed, timed-out, empty, and elided tile requests.\r\n * @beta\r\n */\r\nexport class TileStatisticsTracker {\r\n private readonly _statElements: HTMLElement[] = [];\r\n private readonly _div: HTMLDivElement;\r\n private readonly _vp: Viewport;\r\n private _curIntervalId?: NodeJS.Timer;\r\n\r\n public constructor(parent: HTMLElement, vp: Viewport) {\r\n this._vp = vp;\r\n this.addMaxActive(parent);\r\n createCheckBox({\r\n parent,\r\n name: \"Track Tile Requests\",\r\n id: \"stats_trackMemory\",\r\n handler: (_cb) => this.toggle(),\r\n });\r\n\r\n this._div = document.createElement(\"div\");\r\n this._div.style.display = \"none\";\r\n this._div.style.textAlign = \"right\";\r\n\r\n const table = document.createElement(\"table\");\r\n table.style.width = \"100%\";\r\n table.setAttribute(\"border\", \"1\");\r\n this._div.appendChild(table);\r\n\r\n const row = document.createElement(\"tr\");\r\n const frameColumn = document.createElement(\"td\");\r\n const globalColumn = document.createElement(\"td\");\r\n frameColumn.style.width = globalColumn.style.width = \"50%\";\r\n row.appendChild(frameColumn);\r\n row.appendChild(globalColumn);\r\n table.appendChild(row);\r\n\r\n for (let i = 0; i < statEntries.length; i++) {\r\n const div = document.createElement(\"div\");\r\n const elem = document.createElement(\"text\");\r\n this._statElements[i] = elem;\r\n div.appendChild(elem);\r\n\r\n const column = i >= indexOfFirstGlobalStatistic ? globalColumn : frameColumn;\r\n column.appendChild(div);\r\n }\r\n\r\n const resetButton = createButton({\r\n parent: this._div,\r\n value: \"Reset\",\r\n tooltip: \"Reset all cumulative statistics\",\r\n handler: () => this.reset(),\r\n });\r\n resetButton.div.style.textAlign = \"center\";\r\n\r\n parent.appendChild(this._div);\r\n }\r\n\r\n public dispose(): void {\r\n this.clearInterval();\r\n }\r\n\r\n private addMaxActive(parent: HTMLElement): void {\r\n const div = document.createElement(\"div\");\r\n\r\n const label = document.createElement(\"label\");\r\n label.style.display = \"inline\";\r\n label.htmlFor = \"maxActiveRequests\";\r\n label.innerText = \"Max Active Requests: \";\r\n div.appendChild(label);\r\n\r\n createNumericInput({\r\n parent: div,\r\n id: \"maxActiveRequests\",\r\n display: \"inline\",\r\n min: 0,\r\n step: 1,\r\n value: IModelApp.tileAdmin.channels.rpcConcurrency,\r\n handler: (value, _input) => this.updateMaxActive(value),\r\n });\r\n\r\n parent.appendChild(div);\r\n }\r\n\r\n private updateMaxActive(value: number): void {\r\n IModelApp.tileAdmin.channels.setRpcConcurrency(value);\r\n }\r\n\r\n private clearInterval(): void {\r\n if (undefined !== this._curIntervalId) {\r\n clearInterval(this._curIntervalId);\r\n this._curIntervalId = undefined;\r\n }\r\n }\r\n\r\n private toggle(): void {\r\n if (undefined !== this._curIntervalId) {\r\n // Currently on - turn off.\r\n this._div.style.display = \"none\";\r\n this.clearInterval();\r\n } else {\r\n // Currently off - turn on.\r\n this._div.style.display = \"block\";\r\n this.update();\r\n this._curIntervalId = setInterval(() => this.update(), 500);\r\n }\r\n }\r\n\r\n private update(): void {\r\n const stats = IModelApp.tileAdmin.statistics;\r\n for (let i = 0; i < statEntries.length; i++) {\r\n const stat = statEntries[i];\r\n const label = `${stat.label}: ${stat.getValue(stats, this._vp)}`;\r\n this._statElements[i].innerText = label;\r\n }\r\n }\r\n\r\n private reset(): void {\r\n IModelApp.tileAdmin.resetStatistics();\r\n this.update();\r\n }\r\n}\r\n"]}
@@ -1,10 +1,10 @@
1
- import { Viewport } from "@itwin/core-frontend";
2
- /** Allows the global settings controlling the behavior of viewing tools to be customized.
3
- * @alpha
4
- */
5
- export declare class ToolSettingsTracker {
6
- private static _expandToolSettings;
7
- constructor(parent: HTMLElement, _vp: Viewport);
8
- dispose(): void;
9
- }
1
+ import { Viewport } from "@itwin/core-frontend";
2
+ /** Allows the global settings controlling the behavior of viewing tools to be customized.
3
+ * @alpha
4
+ */
5
+ export declare class ToolSettingsTracker {
6
+ private static _expandToolSettings;
7
+ constructor(parent: HTMLElement, _vp: Viewport);
8
+ dispose(): void;
9
+ }
10
10
  //# sourceMappingURL=ToolSettingsTracker.d.ts.map