@itwin/frontend-devtools 3.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 (244) hide show
  1. package/CHANGELOG.md +723 -0
  2. package/LICENSE.md +9 -0
  3. package/README.md +321 -0
  4. package/lib/ClipboardUtilities.d.ts +9 -0
  5. package/lib/ClipboardUtilities.d.ts.map +1 -0
  6. package/lib/ClipboardUtilities.js +27 -0
  7. package/lib/ClipboardUtilities.js.map +1 -0
  8. package/lib/FrontEndDevTools.d.ts +19 -0
  9. package/lib/FrontEndDevTools.d.ts.map +1 -0
  10. package/lib/FrontEndDevTools.js +203 -0
  11. package/lib/FrontEndDevTools.js.map +1 -0
  12. package/lib/effects/Convolution.d.ts +69 -0
  13. package/lib/effects/Convolution.d.ts.map +1 -0
  14. package/lib/effects/Convolution.js +166 -0
  15. package/lib/effects/Convolution.js.map +1 -0
  16. package/lib/effects/EffectTools.d.ts +34 -0
  17. package/lib/effects/EffectTools.d.ts.map +1 -0
  18. package/lib/effects/EffectTools.js +69 -0
  19. package/lib/effects/EffectTools.js.map +1 -0
  20. package/lib/effects/Explosion.d.ts +13 -0
  21. package/lib/effects/Explosion.d.ts.map +1 -0
  22. package/lib/effects/Explosion.js +168 -0
  23. package/lib/effects/Explosion.js.map +1 -0
  24. package/lib/effects/FlipImage.d.ts +31 -0
  25. package/lib/effects/FlipImage.d.ts.map +1 -0
  26. package/lib/effects/FlipImage.js +100 -0
  27. package/lib/effects/FlipImage.js.map +1 -0
  28. package/lib/effects/LensDistortion.d.ts +35 -0
  29. package/lib/effects/LensDistortion.d.ts.map +1 -0
  30. package/lib/effects/LensDistortion.js +110 -0
  31. package/lib/effects/LensDistortion.js.map +1 -0
  32. package/lib/effects/Random.d.ts +25 -0
  33. package/lib/effects/Random.d.ts.map +1 -0
  34. package/lib/effects/Random.js +50 -0
  35. package/lib/effects/Random.js.map +1 -0
  36. package/lib/effects/Saturation.d.ts +31 -0
  37. package/lib/effects/Saturation.d.ts.map +1 -0
  38. package/lib/effects/Saturation.js +86 -0
  39. package/lib/effects/Saturation.js.map +1 -0
  40. package/lib/effects/Snow.d.ts +77 -0
  41. package/lib/effects/Snow.d.ts.map +1 -0
  42. package/lib/effects/Snow.js +187 -0
  43. package/lib/effects/Snow.js.map +1 -0
  44. package/lib/effects/Vignette.d.ts +40 -0
  45. package/lib/effects/Vignette.d.ts.map +1 -0
  46. package/lib/effects/Vignette.js +109 -0
  47. package/lib/effects/Vignette.js.map +1 -0
  48. package/lib/frontend-devtools.d.ts +82 -0
  49. package/lib/frontend-devtools.d.ts.map +1 -0
  50. package/lib/frontend-devtools.js +98 -0
  51. package/lib/frontend-devtools.js.map +1 -0
  52. package/lib/public/locales/en/FrontendDevTools.json +449 -0
  53. package/lib/public/sprites/particle_explosion.png +0 -0
  54. package/lib/public/sprites/particle_flame.png +0 -0
  55. package/lib/public/sprites/particle_snow.png +0 -0
  56. package/lib/tools/AnimationIntervalTool.d.ts +16 -0
  57. package/lib/tools/AnimationIntervalTool.d.ts.map +1 -0
  58. package/lib/tools/AnimationIntervalTool.js +31 -0
  59. package/lib/tools/AnimationIntervalTool.js.map +1 -0
  60. package/lib/tools/ChangeUnitsTool.d.ts +16 -0
  61. package/lib/tools/ChangeUnitsTool.d.ts.map +1 -0
  62. package/lib/tools/ChangeUnitsTool.js +42 -0
  63. package/lib/tools/ChangeUnitsTool.js.map +1 -0
  64. package/lib/tools/ClipTools.d.ts +68 -0
  65. package/lib/tools/ClipTools.d.ts.map +1 -0
  66. package/lib/tools/ClipTools.js +162 -0
  67. package/lib/tools/ClipTools.js.map +1 -0
  68. package/lib/tools/DisplayStyleTools.d.ts +99 -0
  69. package/lib/tools/DisplayStyleTools.d.ts.map +1 -0
  70. package/lib/tools/DisplayStyleTools.js +242 -0
  71. package/lib/tools/DisplayStyleTools.js.map +1 -0
  72. package/lib/tools/EmphasizeElementsTool.d.ts +61 -0
  73. package/lib/tools/EmphasizeElementsTool.d.ts.map +1 -0
  74. package/lib/tools/EmphasizeElementsTool.js +155 -0
  75. package/lib/tools/EmphasizeElementsTool.js.map +1 -0
  76. package/lib/tools/FrustumDecoration.d.ts +58 -0
  77. package/lib/tools/FrustumDecoration.d.ts.map +1 -0
  78. package/lib/tools/FrustumDecoration.js +372 -0
  79. package/lib/tools/FrustumDecoration.js.map +1 -0
  80. package/lib/tools/InspectElementTool.d.ts +42 -0
  81. package/lib/tools/InspectElementTool.d.ts.map +1 -0
  82. package/lib/tools/InspectElementTool.js +185 -0
  83. package/lib/tools/InspectElementTool.js.map +1 -0
  84. package/lib/tools/MapLayerTool.d.ts +248 -0
  85. package/lib/tools/MapLayerTool.d.ts.map +1 -0
  86. package/lib/tools/MapLayerTool.js +462 -0
  87. package/lib/tools/MapLayerTool.js.map +1 -0
  88. package/lib/tools/MeasureTileLoadTime.d.ts +13 -0
  89. package/lib/tools/MeasureTileLoadTime.d.ts.map +1 -0
  90. package/lib/tools/MeasureTileLoadTime.js +61 -0
  91. package/lib/tools/MeasureTileLoadTime.js.map +1 -0
  92. package/lib/tools/ModelAppearanceTools.d.ts +87 -0
  93. package/lib/tools/ModelAppearanceTools.d.ts.map +1 -0
  94. package/lib/tools/ModelAppearanceTools.js +184 -0
  95. package/lib/tools/ModelAppearanceTools.js.map +1 -0
  96. package/lib/tools/PlanProjectionTools.d.ts +41 -0
  97. package/lib/tools/PlanProjectionTools.d.ts.map +1 -0
  98. package/lib/tools/PlanProjectionTools.js +150 -0
  99. package/lib/tools/PlanProjectionTools.js.map +1 -0
  100. package/lib/tools/PlanarMaskTools.d.ts +182 -0
  101. package/lib/tools/PlanarMaskTools.d.ts.map +1 -0
  102. package/lib/tools/PlanarMaskTools.js +366 -0
  103. package/lib/tools/PlanarMaskTools.js.map +1 -0
  104. package/lib/tools/ProjectExtents.d.ts +41 -0
  105. package/lib/tools/ProjectExtents.d.ts.map +1 -0
  106. package/lib/tools/ProjectExtents.js +108 -0
  107. package/lib/tools/ProjectExtents.js.map +1 -0
  108. package/lib/tools/RealityModelTools.d.ts +117 -0
  109. package/lib/tools/RealityModelTools.d.ts.map +1 -0
  110. package/lib/tools/RealityModelTools.js +269 -0
  111. package/lib/tools/RealityModelTools.js.map +1 -0
  112. package/lib/tools/RealityTransitionTool.d.ts +26 -0
  113. package/lib/tools/RealityTransitionTool.d.ts.map +1 -0
  114. package/lib/tools/RealityTransitionTool.js +110 -0
  115. package/lib/tools/RealityTransitionTool.js.map +1 -0
  116. package/lib/tools/RenderSystemTools.d.ts +46 -0
  117. package/lib/tools/RenderSystemTools.d.ts.map +1 -0
  118. package/lib/tools/RenderSystemTools.js +81 -0
  119. package/lib/tools/RenderSystemTools.js.map +1 -0
  120. package/lib/tools/RenderTargetTools.d.ts +101 -0
  121. package/lib/tools/RenderTargetTools.d.ts.map +1 -0
  122. package/lib/tools/RenderTargetTools.js +167 -0
  123. package/lib/tools/RenderTargetTools.js.map +1 -0
  124. package/lib/tools/ReportWebGLCompatibilityTool.d.ts +12 -0
  125. package/lib/tools/ReportWebGLCompatibilityTool.d.ts.map +1 -0
  126. package/lib/tools/ReportWebGLCompatibilityTool.js +31 -0
  127. package/lib/tools/ReportWebGLCompatibilityTool.js.map +1 -0
  128. package/lib/tools/SavedViews.d.ts +47 -0
  129. package/lib/tools/SavedViews.d.ts.map +1 -0
  130. package/lib/tools/SavedViews.js +137 -0
  131. package/lib/tools/SavedViews.js.map +1 -0
  132. package/lib/tools/SelectionTools.d.ts +17 -0
  133. package/lib/tools/SelectionTools.d.ts.map +1 -0
  134. package/lib/tools/SelectionTools.js +28 -0
  135. package/lib/tools/SelectionTools.js.map +1 -0
  136. package/lib/tools/SetGpuMemoryLimitTool.d.ts +16 -0
  137. package/lib/tools/SetGpuMemoryLimitTool.d.ts.map +1 -0
  138. package/lib/tools/SetGpuMemoryLimitTool.js +34 -0
  139. package/lib/tools/SetGpuMemoryLimitTool.js.map +1 -0
  140. package/lib/tools/SourceAspectIdTools.d.ts +41 -0
  141. package/lib/tools/SourceAspectIdTools.d.ts.map +1 -0
  142. package/lib/tools/SourceAspectIdTools.js +105 -0
  143. package/lib/tools/SourceAspectIdTools.js.map +1 -0
  144. package/lib/tools/TileRequestDecoration.d.ts +13 -0
  145. package/lib/tools/TileRequestDecoration.d.ts.map +1 -0
  146. package/lib/tools/TileRequestDecoration.js +84 -0
  147. package/lib/tools/TileRequestDecoration.js.map +1 -0
  148. package/lib/tools/TileTreeBoundsDecoration.d.ts +12 -0
  149. package/lib/tools/TileTreeBoundsDecoration.d.ts.map +1 -0
  150. package/lib/tools/TileTreeBoundsDecoration.js +75 -0
  151. package/lib/tools/TileTreeBoundsDecoration.js.map +1 -0
  152. package/lib/tools/ToolTipProvider.d.ts +16 -0
  153. package/lib/tools/ToolTipProvider.d.ts.map +1 -0
  154. package/lib/tools/ToolTipProvider.js +67 -0
  155. package/lib/tools/ToolTipProvider.js.map +1 -0
  156. package/lib/tools/ViewportTools.d.ts +194 -0
  157. package/lib/tools/ViewportTools.d.ts.map +1 -0
  158. package/lib/tools/ViewportTools.js +451 -0
  159. package/lib/tools/ViewportTools.js.map +1 -0
  160. package/lib/tools/parseArgs.d.ts +24 -0
  161. package/lib/tools/parseArgs.d.ts.map +1 -0
  162. package/lib/tools/parseArgs.js +52 -0
  163. package/lib/tools/parseArgs.js.map +1 -0
  164. package/lib/tools/parseBoolean.d.ts +9 -0
  165. package/lib/tools/parseBoolean.d.ts.map +1 -0
  166. package/lib/tools/parseBoolean.js +27 -0
  167. package/lib/tools/parseBoolean.js.map +1 -0
  168. package/lib/tools/parseToggle.d.ts +9 -0
  169. package/lib/tools/parseToggle.d.ts.map +1 -0
  170. package/lib/tools/parseToggle.js +26 -0
  171. package/lib/tools/parseToggle.js.map +1 -0
  172. package/lib/ui/Button.d.ts +30 -0
  173. package/lib/ui/Button.d.ts.map +1 -0
  174. package/lib/ui/Button.js +27 -0
  175. package/lib/ui/Button.js.map +1 -0
  176. package/lib/ui/CheckBox.d.ts +24 -0
  177. package/lib/ui/CheckBox.d.ts.map +1 -0
  178. package/lib/ui/CheckBox.js +28 -0
  179. package/lib/ui/CheckBox.js.map +1 -0
  180. package/lib/ui/ColorInput.d.ts +28 -0
  181. package/lib/ui/ColorInput.d.ts.map +1 -0
  182. package/lib/ui/ColorInput.js +54 -0
  183. package/lib/ui/ColorInput.js.map +1 -0
  184. package/lib/ui/ComboBox.d.ts +29 -0
  185. package/lib/ui/ComboBox.d.ts.map +1 -0
  186. package/lib/ui/ComboBox.js +43 -0
  187. package/lib/ui/ComboBox.js.map +1 -0
  188. package/lib/ui/DataList.d.ts +28 -0
  189. package/lib/ui/DataList.d.ts.map +1 -0
  190. package/lib/ui/DataList.js +40 -0
  191. package/lib/ui/DataList.js.map +1 -0
  192. package/lib/ui/NestedMenu.d.ts +20 -0
  193. package/lib/ui/NestedMenu.d.ts.map +1 -0
  194. package/lib/ui/NestedMenu.js +47 -0
  195. package/lib/ui/NestedMenu.js.map +1 -0
  196. package/lib/ui/NumericInput.d.ts +35 -0
  197. package/lib/ui/NumericInput.d.ts.map +1 -0
  198. package/lib/ui/NumericInput.js +60 -0
  199. package/lib/ui/NumericInput.js.map +1 -0
  200. package/lib/ui/RadioBox.d.ts +29 -0
  201. package/lib/ui/RadioBox.d.ts.map +1 -0
  202. package/lib/ui/RadioBox.js +77 -0
  203. package/lib/ui/RadioBox.js.map +1 -0
  204. package/lib/ui/Slider.d.ts +25 -0
  205. package/lib/ui/Slider.d.ts.map +1 -0
  206. package/lib/ui/Slider.js +33 -0
  207. package/lib/ui/Slider.js.map +1 -0
  208. package/lib/ui/TextBox.d.ts +33 -0
  209. package/lib/ui/TextBox.d.ts.map +1 -0
  210. package/lib/ui/TextBox.js +57 -0
  211. package/lib/ui/TextBox.js.map +1 -0
  212. package/lib/widgets/DiagnosticsPanel.d.ts +36 -0
  213. package/lib/widgets/DiagnosticsPanel.d.ts.map +1 -0
  214. package/lib/widgets/DiagnosticsPanel.js +76 -0
  215. package/lib/widgets/DiagnosticsPanel.js.map +1 -0
  216. package/lib/widgets/FpsTracker.d.ts +20 -0
  217. package/lib/widgets/FpsTracker.d.ts.map +1 -0
  218. package/lib/widgets/FpsTracker.js +57 -0
  219. package/lib/widgets/FpsTracker.js.map +1 -0
  220. package/lib/widgets/GpuProfiler.d.ts +17 -0
  221. package/lib/widgets/GpuProfiler.d.ts.map +1 -0
  222. package/lib/widgets/GpuProfiler.js +193 -0
  223. package/lib/widgets/GpuProfiler.js.map +1 -0
  224. package/lib/widgets/KeyinField.d.ts +62 -0
  225. package/lib/widgets/KeyinField.d.ts.map +1 -0
  226. package/lib/widgets/KeyinField.js +188 -0
  227. package/lib/widgets/KeyinField.js.map +1 -0
  228. package/lib/widgets/MemoryTracker.d.ts +28 -0
  229. package/lib/widgets/MemoryTracker.d.ts.map +1 -0
  230. package/lib/widgets/MemoryTracker.js +244 -0
  231. package/lib/widgets/MemoryTracker.js.map +1 -0
  232. package/lib/widgets/TileMemoryBreakdown.d.ts +31 -0
  233. package/lib/widgets/TileMemoryBreakdown.d.ts.map +1 -0
  234. package/lib/widgets/TileMemoryBreakdown.js +205 -0
  235. package/lib/widgets/TileMemoryBreakdown.js.map +1 -0
  236. package/lib/widgets/TileStatisticsTracker.d.ts +22 -0
  237. package/lib/widgets/TileStatisticsTracker.d.ts.map +1 -0
  238. package/lib/widgets/TileStatisticsTracker.js +143 -0
  239. package/lib/widgets/TileStatisticsTracker.js.map +1 -0
  240. package/lib/widgets/ToolSettingsTracker.d.ts +10 -0
  241. package/lib/widgets/ToolSettingsTracker.d.ts.map +1 -0
  242. package/lib/widgets/ToolSettingsTracker.js +182 -0
  243. package/lib/widgets/ToolSettingsTracker.js.map +1 -0
  244. package/package.json +59 -0
@@ -0,0 +1,451 @@
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.ChangeCameraTool = exports.ToggleSectionDrawingSpatialViewTool = exports.ToggleDrawingGraphicsTool = exports.ToggleViewAttachmentClipShapesTool = exports.ToggleViewAttachmentBoundariesTool = exports.ToggleViewAttachmentsTool = exports.Toggle3dManipulationsTool = exports.ViewportAddRealityModel = exports.ViewportTileSizeModifierTool = exports.DefaultTileSizeModifierTool = exports.FadeOutTool = exports.ChangeFlashSettingsTool = exports.ChangeEmphasisSettingsTool = exports.ChangeHiliteSettingsTool = exports.ChangeHiliteTool = exports.SetAspectRatioSkewTool = exports.ShowTileVolumesTool = exports.FreezeSceneTool = exports.ViewportToggleTool = void 0;
8
+ /** @packageDocumentation
9
+ * @module Tools
10
+ */
11
+ const core_bentley_1 = require("@itwin/core-bentley");
12
+ const core_common_1 = require("@itwin/core-common");
13
+ const core_frontend_1 = require("@itwin/core-frontend");
14
+ const parseArgs_1 = require("./parseArgs");
15
+ const parseToggle_1 = require("./parseToggle");
16
+ /** Base class for a tool that toggles some aspect of a Viewport.
17
+ * @beta
18
+ */
19
+ class ViewportToggleTool extends core_frontend_1.Tool {
20
+ static get minArgs() { return 0; }
21
+ static get maxArgs() { return 1; }
22
+ async run(enable) {
23
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
24
+ if (undefined !== vp)
25
+ await this.toggle(vp, enable);
26
+ return true;
27
+ }
28
+ async parseAndRun(...args) {
29
+ const enable = (0, parseToggle_1.parseToggle)(args[0]);
30
+ if (typeof enable !== "string")
31
+ await this.run(enable);
32
+ return true;
33
+ }
34
+ }
35
+ exports.ViewportToggleTool = ViewportToggleTool;
36
+ /** Freeze or unfreeze the scene for the selected viewport. While the scene is frozen, no new tiles will be selected for drawing within the viewport.
37
+ * @beta
38
+ */
39
+ class FreezeSceneTool extends ViewportToggleTool {
40
+ async toggle(vp, enable) {
41
+ if (undefined === enable || enable !== vp.freezeScene)
42
+ vp.freezeScene = !vp.freezeScene;
43
+ return Promise.resolve();
44
+ }
45
+ }
46
+ exports.FreezeSceneTool = FreezeSceneTool;
47
+ FreezeSceneTool.toolId = "FreezeScene";
48
+ const boundingVolumeNames = [
49
+ "none",
50
+ "volume",
51
+ "content",
52
+ "both",
53
+ "children",
54
+ "sphere",
55
+ ];
56
+ /** Set the tile bounding volume decorations to display in the selected viewport.
57
+ * Omitting the argument turns on Volume bounding boxes if bounding boxes are currently off; otherwise, toggles them off.
58
+ * Allowed inputs are "none", "volume", "content", "both" (volume and content), "children", and "sphere".
59
+ * @beta
60
+ */
61
+ class ShowTileVolumesTool extends core_frontend_1.Tool {
62
+ static get minArgs() { return 0; }
63
+ static get maxArgs() { return 1; }
64
+ async run(boxes) {
65
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
66
+ if (undefined === vp)
67
+ return true;
68
+ if (undefined === boxes)
69
+ boxes = core_frontend_1.TileBoundingBoxes.None === vp.debugBoundingBoxes ? core_frontend_1.TileBoundingBoxes.Volume : core_frontend_1.TileBoundingBoxes.None;
70
+ vp.debugBoundingBoxes = boxes;
71
+ return true;
72
+ }
73
+ async parseAndRun(...args) {
74
+ let boxes;
75
+ if (0 !== args.length) {
76
+ const arg = args[0].toLowerCase();
77
+ for (let i = 0; i < boundingVolumeNames.length; i++) {
78
+ if (arg === boundingVolumeNames[i]) {
79
+ boxes = i;
80
+ break;
81
+ }
82
+ }
83
+ if (undefined === boxes)
84
+ return true;
85
+ }
86
+ return this.run(boxes);
87
+ }
88
+ }
89
+ exports.ShowTileVolumesTool = ShowTileVolumesTool;
90
+ ShowTileVolumesTool.toolId = "ShowTileVolumes";
91
+ /** This tool sets the aspect ratio skew for the selected viewport.
92
+ * @beta
93
+ */
94
+ class SetAspectRatioSkewTool extends core_frontend_1.Tool {
95
+ static get minArgs() { return 0; }
96
+ static get maxArgs() { return 1; }
97
+ /** This method runs the tool, setting the aspect ratio skew for the selected viewport.
98
+ * @param skew the aspect ratio (x/y) skew value; 1.0 or undefined removes any skew
99
+ */
100
+ async run(skew) {
101
+ if (undefined === skew)
102
+ skew = 1.0;
103
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
104
+ if (undefined !== vp) {
105
+ vp.view.setAspectRatioSkew(skew);
106
+ vp.synchWithView();
107
+ }
108
+ return true;
109
+ }
110
+ /** Executes this tool's run method.
111
+ * @param args the first entry of this array contains the `skew` argument
112
+ * @see [[run]]
113
+ */
114
+ async parseAndRun(...args) {
115
+ const skew = args.length > 0 ? parseFloat(args[0]) : 1.0;
116
+ return !Number.isNaN(skew) && this.run(skew);
117
+ }
118
+ }
119
+ exports.SetAspectRatioSkewTool = SetAspectRatioSkewTool;
120
+ SetAspectRatioSkewTool.toolId = "SetAspectRatioSkew";
121
+ /** Changes the selected viewport's hilite or emphasis settings.
122
+ * @beta
123
+ */
124
+ class ChangeHiliteTool extends core_frontend_1.Tool {
125
+ static get minArgs() { return 0; }
126
+ static get maxArgs() { return 6; }
127
+ async run(settings) {
128
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
129
+ if (undefined !== vp)
130
+ this.apply(vp, settings);
131
+ return true;
132
+ }
133
+ async parseAndRun(...inputArgs) {
134
+ if (0 === inputArgs.length)
135
+ return this.run();
136
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
137
+ if (undefined === vp)
138
+ return true;
139
+ const cur = this.getCurrentSettings(vp);
140
+ const colors = cur.color.colors;
141
+ let visible = cur.visibleRatio;
142
+ let hidden = cur.hiddenRatio;
143
+ let silhouette = cur.silhouette;
144
+ const args = (0, parseArgs_1.parseArgs)(inputArgs);
145
+ const parseColorComponent = (c) => {
146
+ const num = args.getInteger(c);
147
+ if (undefined !== num)
148
+ colors[c] = Math.floor(Math.max(0, Math.min(255, num)));
149
+ };
150
+ parseColorComponent("r");
151
+ parseColorComponent("g");
152
+ parseColorComponent("b");
153
+ const silhouetteArg = args.getInteger("s");
154
+ if (undefined !== silhouetteArg && silhouetteArg >= core_common_1.Hilite.Silhouette.None && silhouetteArg <= core_common_1.Hilite.Silhouette.Thick)
155
+ silhouette = silhouetteArg;
156
+ const v = args.getFloat("v");
157
+ if (undefined !== v && v >= 0 && v <= 1)
158
+ visible = v;
159
+ const h = args.getFloat("h");
160
+ if (undefined !== h && h >= 0 && h <= 1)
161
+ hidden = h;
162
+ if (undefined === silhouette)
163
+ silhouette = cur.silhouette;
164
+ if (undefined === visible)
165
+ visible = cur.visibleRatio;
166
+ if (undefined === hidden)
167
+ hidden = cur.hiddenRatio;
168
+ const settings = {
169
+ color: core_common_1.ColorDef.from(colors.r, colors.g, colors.b),
170
+ silhouette,
171
+ visibleRatio: visible,
172
+ hiddenRatio: hidden,
173
+ };
174
+ return this.run(settings);
175
+ }
176
+ }
177
+ exports.ChangeHiliteTool = ChangeHiliteTool;
178
+ /** Changes the selected viewport's hilite settings, or resets to defaults.
179
+ * @beta
180
+ */
181
+ class ChangeHiliteSettingsTool extends ChangeHiliteTool {
182
+ getCurrentSettings(vp) { return vp.hilite; }
183
+ apply(vp, settings) {
184
+ vp.hilite = undefined !== settings ? settings : new core_common_1.Hilite.Settings();
185
+ }
186
+ }
187
+ exports.ChangeHiliteSettingsTool = ChangeHiliteSettingsTool;
188
+ ChangeHiliteSettingsTool.toolId = "ChangeHiliteSettings";
189
+ /** Changes the selected viewport's emphasis settings.
190
+ * @beta
191
+ */
192
+ class ChangeEmphasisSettingsTool extends ChangeHiliteTool {
193
+ getCurrentSettings(vp) { return vp.emphasisSettings; }
194
+ apply(vp, settings) {
195
+ if (undefined !== settings)
196
+ vp.emphasisSettings = settings;
197
+ }
198
+ }
199
+ exports.ChangeEmphasisSettingsTool = ChangeEmphasisSettingsTool;
200
+ ChangeEmphasisSettingsTool.toolId = "ChangeEmphasisSettings";
201
+ /** Changes the [FlashSettings]($frontend) for the selected [Viewport]($frontend).
202
+ * @beta
203
+ */
204
+ class ChangeFlashSettingsTool extends core_frontend_1.Tool {
205
+ static get minArgs() { return 0; }
206
+ static get maxArgs() { return 3; }
207
+ async run(settings) {
208
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
209
+ if (vp)
210
+ vp.flashSettings = settings !== null && settings !== void 0 ? settings : new core_frontend_1.FlashSettings();
211
+ return true;
212
+ }
213
+ async parseAndRun(...inputArgs) {
214
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
215
+ if (!vp)
216
+ return true;
217
+ if (1 === inputArgs.length && "default" === inputArgs[0].toLowerCase())
218
+ return this.run();
219
+ const options = {};
220
+ const args = (0, parseArgs_1.parseArgs)(inputArgs);
221
+ const intensity = args.getFloat("i");
222
+ if (undefined !== intensity)
223
+ options.maxIntensity = intensity;
224
+ const mode = args.get("m");
225
+ if (mode) {
226
+ switch (mode[0].toLowerCase()) {
227
+ case "b":
228
+ options.litMode = core_frontend_1.FlashMode.Brighten;
229
+ break;
230
+ case "h":
231
+ options.litMode = core_frontend_1.FlashMode.Hilite;
232
+ break;
233
+ default:
234
+ return false;
235
+ }
236
+ }
237
+ const duration = args.getFloat("d");
238
+ if (undefined !== duration)
239
+ options.duration = core_bentley_1.BeDuration.fromSeconds(duration);
240
+ return this.run(vp.flashSettings.clone(options));
241
+ }
242
+ }
243
+ exports.ChangeFlashSettingsTool = ChangeFlashSettingsTool;
244
+ ChangeFlashSettingsTool.toolId = "ChangeFlashSettings";
245
+ /** Enables or disables fade-out transparency mode for the selected viewport.
246
+ * @beta
247
+ */
248
+ class FadeOutTool extends ViewportToggleTool {
249
+ async toggle(vp, enable) {
250
+ if (undefined === enable || enable !== vp.isFadeOutActive)
251
+ vp.isFadeOutActive = !vp.isFadeOutActive;
252
+ return Promise.resolve();
253
+ }
254
+ }
255
+ exports.FadeOutTool = FadeOutTool;
256
+ FadeOutTool.toolId = "FadeOut";
257
+ /** Sets the default tile size modifier used for all viewports that don't explicitly override it.
258
+ * @beta
259
+ */
260
+ class DefaultTileSizeModifierTool extends core_frontend_1.Tool {
261
+ static get minArgs() { return 1; }
262
+ static get maxArgs() { return 1; }
263
+ /** This method runs the tool, setting the default tile size modifier used for all viewports that don't explicitly override it.
264
+ * @param modifier the tile size modifier to use; if undefined, do not set modifier
265
+ */
266
+ async run(modifier) {
267
+ if (undefined !== modifier)
268
+ core_frontend_1.IModelApp.tileAdmin.defaultTileSizeModifier = modifier;
269
+ return true;
270
+ }
271
+ /** Executes this tool's run method with args[0] containing `modifier`.
272
+ * @see [[run]]
273
+ */
274
+ async parseAndRun(...args) {
275
+ return this.run(Number.parseFloat(args[0]));
276
+ }
277
+ }
278
+ exports.DefaultTileSizeModifierTool = DefaultTileSizeModifierTool;
279
+ DefaultTileSizeModifierTool.toolId = "DefaultTileSizeMod";
280
+ /** Sets or clears the tile size modifier override for the selected viewport.
281
+ * @beta
282
+ */
283
+ class ViewportTileSizeModifierTool extends core_frontend_1.Tool {
284
+ static get minArgs() { return 1; }
285
+ static get maxArgs() { return 1; }
286
+ /** This method runs the tool, setting the tile size modifier used for the selected viewport.
287
+ * @param modifier the tile size modifier to use; if undefined, reset the modifier
288
+ */
289
+ async run(modifier) {
290
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
291
+ if (undefined !== vp)
292
+ vp.setTileSizeModifier(modifier);
293
+ return true;
294
+ }
295
+ /** Executes this tool's run method with args[0] containing the `modifier` argument or the string "reset" in order to reset the modifier.
296
+ * @see [[run]]
297
+ */
298
+ async parseAndRun(...args) {
299
+ const arg = args[0].toLowerCase();
300
+ const modifier = "reset" === arg ? undefined : Number.parseFloat(args[0]);
301
+ return this.run(modifier);
302
+ }
303
+ }
304
+ exports.ViewportTileSizeModifierTool = ViewportTileSizeModifierTool;
305
+ ViewportTileSizeModifierTool.toolId = "ViewportTileSizeMod";
306
+ /** This tool adds a reality model to the viewport.
307
+ * @beta
308
+ */
309
+ class ViewportAddRealityModel extends core_frontend_1.Tool {
310
+ static get minArgs() { return 1; }
311
+ static get maxArgs() { return 1; }
312
+ /** This method runs the tool, adding a reality model to the viewport
313
+ * @param url the URL which points to the reality model tileset
314
+ */
315
+ async run(url) {
316
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
317
+ if (undefined !== vp)
318
+ vp.displayStyle.attachRealityModel({ tilesetUrl: url });
319
+ return true;
320
+ }
321
+ /** Executes this tool's run method with args[0] containing the `url` argument.
322
+ * @see [[run]]
323
+ */
324
+ async parseAndRun(...args) {
325
+ return this.run(args[0]);
326
+ }
327
+ }
328
+ exports.ViewportAddRealityModel = ViewportAddRealityModel;
329
+ ViewportAddRealityModel.toolId = "ViewportAddRealityModel";
330
+ /** Changes the `allow3dManipulations` flag for the selected viewport if the viewport is displaying a `ViewState3d`.
331
+ * @beta
332
+ */
333
+ class Toggle3dManipulationsTool extends ViewportToggleTool {
334
+ async toggle(vp, allow) {
335
+ if (!vp.view.is3d())
336
+ return Promise.resolve();
337
+ if (undefined === allow)
338
+ allow = !vp.view.allow3dManipulations();
339
+ if (allow !== vp.view.allow3dManipulations()) {
340
+ vp.view.setAllow3dManipulations(allow);
341
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
342
+ core_frontend_1.IModelApp.toolAdmin.startDefaultTool();
343
+ }
344
+ return Promise.resolve();
345
+ }
346
+ }
347
+ exports.Toggle3dManipulationsTool = Toggle3dManipulationsTool;
348
+ Toggle3dManipulationsTool.toolId = "Toggle3dManipulations";
349
+ /** Toggles display of view attachments in sheet views.
350
+ * @beta
351
+ */
352
+ class ToggleViewAttachmentsTool extends ViewportToggleTool {
353
+ async toggle(vp, enable) {
354
+ if (undefined === enable || enable !== vp.wantViewAttachments)
355
+ vp.wantViewAttachments = !vp.wantViewAttachments;
356
+ return Promise.resolve();
357
+ }
358
+ }
359
+ exports.ToggleViewAttachmentsTool = ToggleViewAttachmentsTool;
360
+ ToggleViewAttachmentsTool.toolId = "ToggleViewAttachments";
361
+ /** Toggle display of view attachment boundaries in sheet views.
362
+ * @beta
363
+ */
364
+ class ToggleViewAttachmentBoundariesTool extends ViewportToggleTool {
365
+ async toggle(vp, enable) {
366
+ if (undefined === enable || enable !== vp.wantViewAttachmentBoundaries)
367
+ vp.wantViewAttachmentBoundaries = !vp.wantViewAttachmentBoundaries;
368
+ return Promise.resolve();
369
+ }
370
+ }
371
+ exports.ToggleViewAttachmentBoundariesTool = ToggleViewAttachmentBoundariesTool;
372
+ ToggleViewAttachmentBoundariesTool.toolId = "ToggleViewAttachmentBoundaries";
373
+ /** Toggle display of view attachment clip shapes in sheet views.
374
+ * @beta
375
+ */
376
+ class ToggleViewAttachmentClipShapesTool extends ViewportToggleTool {
377
+ async toggle(vp, enable) {
378
+ if (undefined === enable || enable !== vp.wantViewAttachmentClipShapes)
379
+ vp.wantViewAttachmentClipShapes = !vp.wantViewAttachmentClipShapes;
380
+ return Promise.resolve();
381
+ }
382
+ }
383
+ exports.ToggleViewAttachmentClipShapesTool = ToggleViewAttachmentClipShapesTool;
384
+ ToggleViewAttachmentClipShapesTool.toolId = "ToggleViewAttachmentClipShapes";
385
+ /** Toggles display of 2d graphics in a [DrawingViewState]($frontend). This setting affects all drawing views until it is reset.
386
+ * @beta
387
+ */
388
+ class ToggleDrawingGraphicsTool extends ViewportToggleTool {
389
+ async toggle(vp, enable) {
390
+ if (undefined === enable || enable !== core_frontend_1.DrawingViewState.hideDrawingGraphics) {
391
+ core_frontend_1.DrawingViewState.hideDrawingGraphics = !core_frontend_1.DrawingViewState.hideDrawingGraphics;
392
+ vp.invalidateScene();
393
+ }
394
+ return Promise.resolve();
395
+ }
396
+ }
397
+ exports.ToggleDrawingGraphicsTool = ToggleDrawingGraphicsTool;
398
+ ToggleDrawingGraphicsTool.toolId = "ToggleDrawingGraphics";
399
+ /** Toggles whether a [SectionDrawing]($backend)'s spatial view is always displayed along with the 2d graphics by a [DrawingViewState]($frontend), even
400
+ * if it otherwise would not be. This setting affects all section drawing views until it is reset.
401
+ * @beta
402
+ */
403
+ class ToggleSectionDrawingSpatialViewTool extends ViewportToggleTool {
404
+ async toggle(vp, enable) {
405
+ if (undefined === enable || enable !== core_frontend_1.DrawingViewState.alwaysDisplaySpatialView) {
406
+ core_frontend_1.DrawingViewState.alwaysDisplaySpatialView = !core_frontend_1.DrawingViewState.alwaysDisplaySpatialView;
407
+ if (vp.view instanceof core_frontend_1.DrawingViewState) {
408
+ // Force the view to update its section drawing attachment.
409
+ const view = vp.view.clone();
410
+ await view.changeViewedModel(view.baseModelId);
411
+ await view.load();
412
+ vp.changeView(view);
413
+ }
414
+ }
415
+ }
416
+ }
417
+ exports.ToggleSectionDrawingSpatialViewTool = ToggleSectionDrawingSpatialViewTool;
418
+ ToggleSectionDrawingSpatialViewTool.toolId = "ToggleSectionDrawingSpatialView";
419
+ /** Change the camera settings of the selected viewport.
420
+ * @beta
421
+ */
422
+ class ChangeCameraTool extends core_frontend_1.Tool {
423
+ static get minArgs() { return 1; }
424
+ static get maxArgs() { return 2; }
425
+ async run(camera) {
426
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
427
+ if (camera && vp && vp.view.is3d()) {
428
+ const view = vp.view.clone();
429
+ view.camera.setFrom(camera);
430
+ vp.changeView(view);
431
+ }
432
+ return true;
433
+ }
434
+ async parseAndRun(...inArgs) {
435
+ const vp = core_frontend_1.IModelApp.viewManager.selectedView;
436
+ if (!vp || !vp.view.is3d())
437
+ return false;
438
+ const camera = vp.view.camera.clone();
439
+ const args = (0, parseArgs_1.parseArgs)(inArgs);
440
+ const lens = args.getFloat("l");
441
+ if (undefined !== lens)
442
+ camera.lens.setDegrees(lens);
443
+ const focusDist = args.getFloat("d");
444
+ if (undefined !== focusDist)
445
+ camera.focusDist = focusDist;
446
+ return this.run(camera);
447
+ }
448
+ }
449
+ exports.ChangeCameraTool = ChangeCameraTool;
450
+ ChangeCameraTool.toolId = "ChangeCamera";
451
+ //# sourceMappingURL=ViewportTools.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ViewportTools.js","sourceRoot":"","sources":["../../src/tools/ViewportTools.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 { BeDuration } from \"@itwin/core-bentley\";\r\nimport { Camera, ColorDef, Hilite } from \"@itwin/core-common\";\r\nimport {\r\n DrawingViewState, FlashMode, FlashSettings, FlashSettingsOptions, IModelApp, TileBoundingBoxes, Tool, Viewport,\r\n} from \"@itwin/core-frontend\";\r\nimport { parseArgs } from \"./parseArgs\";\r\nimport { parseToggle } from \"./parseToggle\";\r\n\r\n/** Base class for a tool that toggles some aspect of a Viewport.\r\n * @beta\r\n */\r\nexport abstract class ViewportToggleTool extends Tool {\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n protected abstract toggle(vp: Viewport, enable?: boolean): Promise<void>;\r\n\r\n public override async run(enable?: boolean): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp)\r\n await this.toggle(vp, enable);\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n const enable = parseToggle(args[0]);\r\n if (typeof enable !== \"string\")\r\n await this.run(enable);\r\n\r\n return true;\r\n }\r\n}\r\n\r\n/** Freeze or unfreeze the scene for the selected viewport. While the scene is frozen, no new tiles will be selected for drawing within the viewport.\r\n * @beta\r\n */\r\nexport class FreezeSceneTool extends ViewportToggleTool {\r\n public static override toolId = \"FreezeScene\";\r\n\r\n protected override async toggle(vp: Viewport, enable?: boolean) {\r\n if (undefined === enable || enable !== vp.freezeScene)\r\n vp.freezeScene = !vp.freezeScene;\r\n\r\n return Promise.resolve();\r\n }\r\n}\r\n\r\nconst boundingVolumeNames = [\r\n \"none\",\r\n \"volume\",\r\n \"content\",\r\n \"both\",\r\n \"children\",\r\n \"sphere\",\r\n];\r\n\r\n/** Set the tile bounding volume decorations to display in the selected viewport.\r\n * Omitting the argument turns on Volume bounding boxes if bounding boxes are currently off; otherwise, toggles them off.\r\n * Allowed inputs are \"none\", \"volume\", \"content\", \"both\" (volume and content), \"children\", and \"sphere\".\r\n * @beta\r\n */\r\nexport class ShowTileVolumesTool extends Tool {\r\n public static override toolId = \"ShowTileVolumes\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n public override async run(boxes?: TileBoundingBoxes): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined === vp)\r\n return true;\r\n\r\n if (undefined === boxes)\r\n boxes = TileBoundingBoxes.None === vp.debugBoundingBoxes ? TileBoundingBoxes.Volume : TileBoundingBoxes.None;\r\n\r\n vp.debugBoundingBoxes = boxes;\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n let boxes: TileBoundingBoxes | undefined;\r\n if (0 !== args.length) {\r\n const arg = args[0].toLowerCase();\r\n for (let i = 0; i < boundingVolumeNames.length; i++) {\r\n if (arg === boundingVolumeNames[i]) {\r\n boxes = i;\r\n break;\r\n }\r\n }\r\n\r\n if (undefined === boxes)\r\n return true;\r\n }\r\n\r\n return this.run(boxes);\r\n }\r\n}\r\n\r\n/** This tool sets the aspect ratio skew for the selected viewport.\r\n * @beta\r\n */\r\nexport class SetAspectRatioSkewTool extends Tool {\r\n public static override toolId = \"SetAspectRatioSkew\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n /** This method runs the tool, setting the aspect ratio skew for the selected viewport.\r\n * @param skew the aspect ratio (x/y) skew value; 1.0 or undefined removes any skew\r\n */\r\n public override async run(skew?: number): Promise<boolean> {\r\n if (undefined === skew)\r\n skew = 1.0;\r\n\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp) {\r\n vp.view.setAspectRatioSkew(skew);\r\n vp.synchWithView();\r\n }\r\n\r\n return true;\r\n }\r\n\r\n /** Executes this tool's run method.\r\n * @param args the first entry of this array contains the `skew` argument\r\n * @see [[run]]\r\n */\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n const skew = args.length > 0 ? parseFloat(args[0]) : 1.0;\r\n return !Number.isNaN(skew) && this.run(skew);\r\n }\r\n}\r\n\r\n/** Changes the selected viewport's hilite or emphasis settings.\r\n * @beta\r\n */\r\nexport abstract class ChangeHiliteTool extends Tool {\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 6; }\r\n\r\n public override async run(settings?: Hilite.Settings): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp)\r\n this.apply(vp, settings);\r\n\r\n return true;\r\n }\r\n\r\n protected abstract apply(vp: Viewport, settings: Hilite.Settings | undefined): void;\r\n protected abstract getCurrentSettings(vp: Viewport): Hilite.Settings;\r\n\r\n public override async parseAndRun(...inputArgs: string[]): Promise<boolean> {\r\n if (0 === inputArgs.length)\r\n return this.run();\r\n\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined === vp)\r\n return true;\r\n\r\n const cur = this.getCurrentSettings(vp);\r\n const colors = cur.color.colors;\r\n let visible = cur.visibleRatio;\r\n let hidden = cur.hiddenRatio;\r\n let silhouette = cur.silhouette;\r\n\r\n const args = parseArgs(inputArgs);\r\n const parseColorComponent = (c: \"r\" | \"g\" | \"b\") => {\r\n const num = args.getInteger(c);\r\n if (undefined !== num)\r\n colors[c] = Math.floor(Math.max(0, Math.min(255, num)));\r\n };\r\n\r\n parseColorComponent(\"r\");\r\n parseColorComponent(\"g\");\r\n parseColorComponent(\"b\");\r\n\r\n const silhouetteArg = args.getInteger(\"s\");\r\n if (undefined !== silhouetteArg && silhouetteArg >= Hilite.Silhouette.None && silhouetteArg <= Hilite.Silhouette.Thick)\r\n silhouette = silhouetteArg;\r\n\r\n const v = args.getFloat(\"v\");\r\n if (undefined !== v && v >= 0 && v <= 1)\r\n visible = v;\r\n\r\n const h = args.getFloat(\"h\");\r\n if (undefined !== h && h >= 0 && h <= 1)\r\n hidden = h;\r\n\r\n if (undefined === silhouette)\r\n silhouette = cur.silhouette;\r\n\r\n if (undefined === visible)\r\n visible = cur.visibleRatio;\r\n\r\n if (undefined === hidden)\r\n hidden = cur.hiddenRatio;\r\n\r\n const settings: Hilite.Settings = {\r\n color: ColorDef.from(colors.r, colors.g, colors.b),\r\n silhouette,\r\n visibleRatio: visible,\r\n hiddenRatio: hidden,\r\n };\r\n\r\n return this.run(settings);\r\n }\r\n}\r\n\r\n/** Changes the selected viewport's hilite settings, or resets to defaults.\r\n * @beta\r\n */\r\nexport class ChangeHiliteSettingsTool extends ChangeHiliteTool {\r\n public static override toolId = \"ChangeHiliteSettings\";\r\n\r\n protected getCurrentSettings(vp: Viewport) { return vp.hilite; }\r\n protected apply(vp: Viewport, settings?: Hilite.Settings): void {\r\n vp.hilite = undefined !== settings ? settings : new Hilite.Settings();\r\n }\r\n}\r\n\r\n/** Changes the selected viewport's emphasis settings.\r\n * @beta\r\n */\r\nexport class ChangeEmphasisSettingsTool extends ChangeHiliteTool {\r\n public static override toolId = \"ChangeEmphasisSettings\";\r\n\r\n protected getCurrentSettings(vp: Viewport) { return vp.emphasisSettings; }\r\n protected apply(vp: Viewport, settings?: Hilite.Settings): void {\r\n if (undefined !== settings)\r\n vp.emphasisSettings = settings;\r\n }\r\n}\r\n\r\n/** Changes the [FlashSettings]($frontend) for the selected [Viewport]($frontend).\r\n * @beta\r\n */\r\nexport class ChangeFlashSettingsTool extends Tool {\r\n public static override toolId = \"ChangeFlashSettings\";\r\n public static override get minArgs() { return 0; }\r\n public static override get maxArgs() { return 3; }\r\n\r\n public override async run(settings?: FlashSettings): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (vp)\r\n vp.flashSettings = settings ?? new FlashSettings();\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...inputArgs: string[]): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (!vp)\r\n return true;\r\n\r\n if (1 === inputArgs.length && \"default\" === inputArgs[0].toLowerCase())\r\n return this.run();\r\n\r\n const options: FlashSettingsOptions = {};\r\n const args = parseArgs(inputArgs);\r\n\r\n const intensity = args.getFloat(\"i\");\r\n if (undefined !== intensity)\r\n options.maxIntensity = intensity;\r\n\r\n const mode = args.get(\"m\");\r\n if (mode) {\r\n switch (mode[0].toLowerCase()) {\r\n case \"b\":\r\n options.litMode = FlashMode.Brighten;\r\n break;\r\n case \"h\":\r\n options.litMode = FlashMode.Hilite;\r\n break;\r\n default:\r\n return false;\r\n }\r\n }\r\n\r\n const duration = args.getFloat(\"d\");\r\n if (undefined !== duration)\r\n options.duration = BeDuration.fromSeconds(duration);\r\n\r\n return this.run(vp.flashSettings.clone(options));\r\n }\r\n}\r\n\r\n/** Enables or disables fade-out transparency mode for the selected viewport.\r\n * @beta\r\n */\r\nexport class FadeOutTool extends ViewportToggleTool {\r\n public static override toolId = \"FadeOut\";\r\n\r\n protected override async toggle(vp: Viewport, enable?: boolean): Promise<void> {\r\n if (undefined === enable || enable !== vp.isFadeOutActive)\r\n vp.isFadeOutActive = !vp.isFadeOutActive;\r\n\r\n return Promise.resolve();\r\n }\r\n}\r\n\r\n/** Sets the default tile size modifier used for all viewports that don't explicitly override it.\r\n * @beta\r\n */\r\nexport class DefaultTileSizeModifierTool extends Tool {\r\n public static override toolId = \"DefaultTileSizeMod\";\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n /** This method runs the tool, setting the default tile size modifier used for all viewports that don't explicitly override it.\r\n * @param modifier the tile size modifier to use; if undefined, do not set modifier\r\n */\r\n public override async run(modifier?: number): Promise<boolean> {\r\n if (undefined !== modifier)\r\n IModelApp.tileAdmin.defaultTileSizeModifier = modifier;\r\n\r\n return true;\r\n }\r\n\r\n /** Executes this tool's run method with args[0] containing `modifier`.\r\n * @see [[run]]\r\n */\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n return this.run(Number.parseFloat(args[0]));\r\n }\r\n}\r\n\r\n/** Sets or clears the tile size modifier override for the selected viewport.\r\n * @beta\r\n */\r\nexport class ViewportTileSizeModifierTool extends Tool {\r\n public static override toolId = \"ViewportTileSizeMod\";\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n /** This method runs the tool, setting the tile size modifier used for the selected viewport.\r\n * @param modifier the tile size modifier to use; if undefined, reset the modifier\r\n */\r\n public override async run(modifier?: number): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp)\r\n vp.setTileSizeModifier(modifier);\r\n\r\n return true;\r\n }\r\n\r\n /** Executes this tool's run method with args[0] containing the `modifier` argument or the string \"reset\" in order to reset the modifier.\r\n * @see [[run]]\r\n */\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n const arg = args[0].toLowerCase();\r\n const modifier = \"reset\" === arg ? undefined : Number.parseFloat(args[0]);\r\n return this.run(modifier);\r\n }\r\n}\r\n\r\n/** This tool adds a reality model to the viewport.\r\n * @beta\r\n */\r\nexport class ViewportAddRealityModel extends Tool {\r\n public static override toolId = \"ViewportAddRealityModel\";\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return 1; }\r\n\r\n /** This method runs the tool, adding a reality model to the viewport\r\n * @param url the URL which points to the reality model tileset\r\n */\r\n public override async run(url: string): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (undefined !== vp)\r\n vp.displayStyle.attachRealityModel({ tilesetUrl: url });\r\n\r\n return true;\r\n }\r\n\r\n /** Executes this tool's run method with args[0] containing the `url` argument.\r\n * @see [[run]]\r\n */\r\n public override async parseAndRun(...args: string[]): Promise<boolean> {\r\n return this.run(args[0]);\r\n }\r\n}\r\n\r\n/** Changes the `allow3dManipulations` flag for the selected viewport if the viewport is displaying a `ViewState3d`.\r\n * @beta\r\n */\r\nexport class Toggle3dManipulationsTool extends ViewportToggleTool {\r\n public static override toolId = \"Toggle3dManipulations\";\r\n\r\n protected override async toggle(vp: Viewport, allow?: boolean): Promise<void> {\r\n if (!vp.view.is3d())\r\n return Promise.resolve();\r\n\r\n if (undefined === allow)\r\n allow = !vp.view.allow3dManipulations();\r\n\r\n if (allow !== vp.view.allow3dManipulations()) {\r\n vp.view.setAllow3dManipulations(allow);\r\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\r\n IModelApp.toolAdmin.startDefaultTool();\r\n }\r\n\r\n return Promise.resolve();\r\n }\r\n}\r\n\r\n/** Toggles display of view attachments in sheet views.\r\n * @beta\r\n */\r\nexport class ToggleViewAttachmentsTool extends ViewportToggleTool {\r\n public static override toolId = \"ToggleViewAttachments\";\r\n\r\n protected override async toggle(vp: Viewport, enable?: boolean): Promise<void> {\r\n if (undefined === enable || enable !== vp.wantViewAttachments)\r\n vp.wantViewAttachments = !vp.wantViewAttachments;\r\n\r\n return Promise.resolve();\r\n }\r\n}\r\n\r\n/** Toggle display of view attachment boundaries in sheet views.\r\n * @beta\r\n */\r\nexport class ToggleViewAttachmentBoundariesTool extends ViewportToggleTool {\r\n public static override toolId = \"ToggleViewAttachmentBoundaries\";\r\n\r\n protected override async toggle(vp: Viewport, enable?: boolean): Promise<void> {\r\n if (undefined === enable || enable !== vp.wantViewAttachmentBoundaries)\r\n vp.wantViewAttachmentBoundaries = !vp.wantViewAttachmentBoundaries;\r\n\r\n return Promise.resolve();\r\n }\r\n}\r\n\r\n/** Toggle display of view attachment clip shapes in sheet views.\r\n * @beta\r\n */\r\nexport class ToggleViewAttachmentClipShapesTool extends ViewportToggleTool {\r\n public static override toolId = \"ToggleViewAttachmentClipShapes\";\r\n\r\n protected override async toggle(vp: Viewport, enable?: boolean): Promise<void> {\r\n if (undefined === enable || enable !== vp.wantViewAttachmentClipShapes)\r\n vp.wantViewAttachmentClipShapes = !vp.wantViewAttachmentClipShapes;\r\n\r\n return Promise.resolve();\r\n }\r\n}\r\n\r\n/** Toggles display of 2d graphics in a [DrawingViewState]($frontend). This setting affects all drawing views until it is reset.\r\n * @beta\r\n */\r\nexport class ToggleDrawingGraphicsTool extends ViewportToggleTool {\r\n public static override toolId = \"ToggleDrawingGraphics\";\r\n\r\n protected override async toggle(vp: Viewport, enable?: boolean): Promise<void> {\r\n if (undefined === enable || enable !== DrawingViewState.hideDrawingGraphics) {\r\n DrawingViewState.hideDrawingGraphics = !DrawingViewState.hideDrawingGraphics;\r\n vp.invalidateScene();\r\n }\r\n\r\n return Promise.resolve();\r\n }\r\n}\r\n\r\n/** Toggles whether a [SectionDrawing]($backend)'s spatial view is always displayed along with the 2d graphics by a [DrawingViewState]($frontend), even\r\n * if it otherwise would not be. This setting affects all section drawing views until it is reset.\r\n * @beta\r\n */\r\nexport class ToggleSectionDrawingSpatialViewTool extends ViewportToggleTool {\r\n public static override toolId = \"ToggleSectionDrawingSpatialView\";\r\n\r\n protected async toggle(vp: Viewport, enable?: boolean): Promise<void> {\r\n if (undefined === enable || enable !== DrawingViewState.alwaysDisplaySpatialView) {\r\n DrawingViewState.alwaysDisplaySpatialView = !DrawingViewState.alwaysDisplaySpatialView;\r\n if (vp.view instanceof DrawingViewState) {\r\n // Force the view to update its section drawing attachment.\r\n const view = vp.view.clone();\r\n await view.changeViewedModel(view.baseModelId);\r\n await view.load();\r\n vp.changeView(view);\r\n }\r\n }\r\n }\r\n}\r\n\r\n/** Change the camera settings of the selected viewport.\r\n * @beta\r\n */\r\nexport class ChangeCameraTool extends Tool {\r\n public static override get minArgs() { return 1; }\r\n public static override get maxArgs() { return 2; }\r\n public static override toolId = \"ChangeCamera\";\r\n\r\n public override async run(camera?: Camera): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (camera && vp && vp.view.is3d()) {\r\n const view = vp.view.clone();\r\n view.camera.setFrom(camera);\r\n vp.changeView(view);\r\n }\r\n\r\n return true;\r\n }\r\n\r\n public override async parseAndRun(...inArgs: string[]): Promise<boolean> {\r\n const vp = IModelApp.viewManager.selectedView;\r\n if (!vp || !vp.view.is3d())\r\n return false;\r\n\r\n const camera = vp.view.camera.clone();\r\n const args = parseArgs(inArgs);\r\n const lens = args.getFloat(\"l\");\r\n if (undefined !== lens)\r\n camera.lens.setDegrees(lens);\r\n\r\n const focusDist = args.getFloat(\"d\");\r\n if (undefined !== focusDist)\r\n camera.focusDist = focusDist;\r\n\r\n return this.run(camera);\r\n }\r\n}\r\n"]}
@@ -0,0 +1,24 @@
1
+ /** @packageDocumentation
2
+ * @module Tools
3
+ */
4
+ /** Represents parsed arguments as name-value pairs.
5
+ * @see [[parseArgs]]
6
+ * @beta
7
+ */
8
+ export interface ToolArgs {
9
+ /** Find the value associated with the first argument that begins with the specified prefix, case-insensitively; or undefined if no such argument exists. */
10
+ get(namePrefix: string): string | undefined;
11
+ /** Convert the value associated with the first argument beginning with the specified prefix to an integer; return undefined if not found or not an integer. */
12
+ getInteger(namePrefix: string): number | undefined;
13
+ /** Convert the value associated with the first argument beginning with the specified prefix to a boolean, where "1" indicates true and "0" indicates false. */
14
+ getBoolean(namePrefix: string): boolean | undefined;
15
+ /** Convert the value associated with the first argument beginning with the specified prefix to a float; return undefined if not found or not a float. */
16
+ getFloat(namePrefix: string): number | undefined;
17
+ }
18
+ /** Given a list of arguments, parse the arguments into name-value pairs.
19
+ * Each input string is expected to be of the format "name=value".
20
+ * Argument names are converted to lower-case; values are left untouched.
21
+ * @beta
22
+ */
23
+ export declare function parseArgs(args: string[]): ToolArgs;
24
+ //# sourceMappingURL=parseArgs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseArgs.d.ts","sourceRoot":"","sources":["../../src/tools/parseArgs.ts"],"names":[],"mappings":"AAKA;;GAEG;AAEH;;;GAGG;AACH,MAAM,WAAW,QAAQ;IACvB,4JAA4J;IAC5J,GAAG,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;IAC5C,+JAA+J;IAC/J,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;IACnD,+JAA+J;IAC/J,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS,CAAC;IACpD,yJAAyJ;IACzJ,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC;CAClD;AAED;;;;GAIG;AACH,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,QAAQ,CA8ClD"}
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.parseArgs = void 0;
8
+ /** Given a list of arguments, parse the arguments into name-value pairs.
9
+ * Each input string is expected to be of the format "name=value".
10
+ * Argument names are converted to lower-case; values are left untouched.
11
+ * @beta
12
+ */
13
+ function parseArgs(args) {
14
+ const map = new Map();
15
+ for (const arg of args) {
16
+ const parts = arg.split("=");
17
+ if (2 === parts.length)
18
+ map.set(parts[0].toLowerCase(), parts[1]);
19
+ }
20
+ const findArgValue = (name) => {
21
+ name = name.toLowerCase();
22
+ for (const key of map.keys())
23
+ if (key.startsWith(name))
24
+ return map.get(key);
25
+ return undefined;
26
+ };
27
+ return {
28
+ get: (name) => findArgValue(name),
29
+ getBoolean: (name) => {
30
+ const val = findArgValue(name);
31
+ if (undefined !== val && (val === "0" || val === "1"))
32
+ return val === "1";
33
+ return undefined;
34
+ },
35
+ getInteger: (name) => {
36
+ const val = findArgValue(name);
37
+ if (undefined === val)
38
+ return undefined;
39
+ const num = Number.parseInt(val, 10);
40
+ return Number.isNaN(num) ? undefined : num;
41
+ },
42
+ getFloat: (name) => {
43
+ const val = findArgValue(name);
44
+ if (undefined === val)
45
+ return undefined;
46
+ const num = Number.parseFloat(val);
47
+ return Number.isNaN(num) ? undefined : num;
48
+ },
49
+ };
50
+ }
51
+ exports.parseArgs = parseArgs;
52
+ //# sourceMappingURL=parseArgs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseArgs.js","sourceRoot":"","sources":["../../src/tools/parseArgs.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAqB/F;;;;GAIG;AACH,SAAgB,SAAS,CAAC,IAAc;IACtC,MAAM,GAAG,GAAG,IAAI,GAAG,EAAkB,CAAC;IACtC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;QACtB,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC7B,IAAI,CAAC,KAAK,KAAK,CAAC,MAAM;YACpB,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;KAC7C;IAED,MAAM,YAAY,GAAG,CAAC,IAAY,EAAE,EAAE;QACpC,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAC1B,KAAK,MAAM,GAAG,IAAI,GAAG,CAAC,IAAI,EAAE;YAC1B,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC;gBACtB,OAAO,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAExB,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC;IAEF,OAAO;QACL,GAAG,EAAE,CAAC,IAAY,EAAE,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC;QAEzC,UAAU,EAAE,CAAC,IAAY,EAAE,EAAE;YAC3B,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;YAC/B,IAAI,SAAS,KAAK,GAAG,IAAI,CAAC,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,GAAG,CAAC;gBACnD,OAAO,GAAG,KAAK,GAAG,CAAC;YAErB,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,UAAU,EAAE,CAAC,IAAY,EAAE,EAAE;YAC3B,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;YAC/B,IAAI,SAAS,KAAK,GAAG;gBACnB,OAAO,SAAS,CAAC;YAEnB,MAAM,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACrC,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;QAC7C,CAAC;QAED,QAAQ,EAAE,CAAC,IAAY,EAAE,EAAE;YACzB,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;YAC/B,IAAI,SAAS,KAAK,GAAG;gBACnB,OAAO,SAAS,CAAC;YAEnB,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YACnC,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;QAC7C,CAAC;KACF,CAAC;AACJ,CAAC;AA9CD,8BA8CC","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\n/** Represents parsed arguments as name-value pairs.\r\n * @see [[parseArgs]]\r\n * @beta\r\n */\r\nexport interface ToolArgs {\r\n /** Find the value associated with the first argument that begins with the specified prefix, case-insensitively; or undefined if no such argument exists. */\r\n get(namePrefix: string): string | undefined;\r\n /** Convert the value associated with the first argument beginning with the specified prefix to an integer; return undefined if not found or not an integer. */\r\n getInteger(namePrefix: string): number | undefined;\r\n /** Convert the value associated with the first argument beginning with the specified prefix to a boolean, where \"1\" indicates true and \"0\" indicates false. */\r\n getBoolean(namePrefix: string): boolean | undefined;\r\n /** Convert the value associated with the first argument beginning with the specified prefix to a float; return undefined if not found or not a float. */\r\n getFloat(namePrefix: string): number | undefined;\r\n}\r\n\r\n/** Given a list of arguments, parse the arguments into name-value pairs.\r\n * Each input string is expected to be of the format \"name=value\".\r\n * Argument names are converted to lower-case; values are left untouched.\r\n * @beta\r\n */\r\nexport function parseArgs(args: string[]): ToolArgs {\r\n const map = new Map<string, string>();\r\n for (const arg of args) {\r\n const parts = arg.split(\"=\");\r\n if (2 === parts.length)\r\n map.set(parts[0].toLowerCase(), parts[1]);\r\n }\r\n\r\n const findArgValue = (name: string) => {\r\n name = name.toLowerCase();\r\n for (const key of map.keys())\r\n if (key.startsWith(name))\r\n return map.get(key);\r\n\r\n return undefined;\r\n };\r\n\r\n return {\r\n get: (name: string) => findArgValue(name),\r\n\r\n getBoolean: (name: string) => {\r\n const val = findArgValue(name);\r\n if (undefined !== val && (val === \"0\" || val === \"1\"))\r\n return val === \"1\";\r\n\r\n return undefined;\r\n },\r\n\r\n getInteger: (name: string) => {\r\n const val = findArgValue(name);\r\n if (undefined === val)\r\n return undefined;\r\n\r\n const num = Number.parseInt(val, 10);\r\n return Number.isNaN(num) ? undefined : num;\r\n },\r\n\r\n getFloat: (name: string) => {\r\n const val = findArgValue(name);\r\n if (undefined === val)\r\n return undefined;\r\n\r\n const num = Number.parseFloat(val);\r\n return Number.isNaN(num) ? undefined : num;\r\n },\r\n };\r\n}\r\n"]}
@@ -0,0 +1,9 @@
1
+ /** @packageDocumentation
2
+ * @module Utilities
3
+ */
4
+ /** Parses a string case-insensitively returning true for "ON" or "TRUE", false for "OFF" or "FALSE" and undefined otherwise.
5
+ * Used by various tools which take such arguments.
6
+ * @beta
7
+ */
8
+ export declare function parseBoolean(arg: string | undefined): boolean | undefined;
9
+ //# sourceMappingURL=parseBoolean.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseBoolean.d.ts","sourceRoot":"","sources":["../../src/tools/parseBoolean.ts"],"names":[],"mappings":"AAKA;;GAEG;AAEH;;;GAGG;AACH,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,CAWzE"}
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.parseBoolean = void 0;
8
+ /** @packageDocumentation
9
+ * @module Utilities
10
+ */
11
+ /** Parses a string case-insensitively returning true for "ON" or "TRUE", false for "OFF" or "FALSE" and undefined otherwise.
12
+ * Used by various tools which take such arguments.
13
+ * @beta
14
+ */
15
+ function parseBoolean(arg) {
16
+ if (undefined === arg)
17
+ return undefined;
18
+ switch (arg.toLowerCase()) {
19
+ case "on": return true;
20
+ case "true": return true;
21
+ case "off": return false;
22
+ case "false": return false;
23
+ default: return undefined;
24
+ }
25
+ }
26
+ exports.parseBoolean = parseBoolean;
27
+ //# sourceMappingURL=parseBoolean.js.map