@itwin/appui-abstract 3.6.0-dev.54 → 3.6.0-dev.55

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 (307) hide show
  1. package/lib/cjs/appui-abstract/BaseUiItemsProvider.d.ts +30 -30
  2. package/lib/cjs/appui-abstract/BaseUiItemsProvider.js +79 -79
  3. package/lib/cjs/appui-abstract/BaseUiItemsProvider.js.map +1 -1
  4. package/lib/cjs/appui-abstract/UiAdmin.d.ts +221 -221
  5. package/lib/cjs/appui-abstract/UiAdmin.js +224 -224
  6. package/lib/cjs/appui-abstract/UiAdmin.js.map +1 -1
  7. package/lib/cjs/appui-abstract/UiItemsManager.d.ts +110 -110
  8. package/lib/cjs/appui-abstract/UiItemsManager.js +199 -199
  9. package/lib/cjs/appui-abstract/UiItemsManager.js.map +1 -1
  10. package/lib/cjs/appui-abstract/UiItemsProvider.d.ts +27 -27
  11. package/lib/cjs/appui-abstract/UiItemsProvider.js +10 -10
  12. package/lib/cjs/appui-abstract/UiItemsProvider.js.map +1 -1
  13. package/lib/cjs/appui-abstract/backstage/BackstageItem.d.ts +83 -83
  14. package/lib/cjs/appui-abstract/backstage/BackstageItem.js +64 -64
  15. package/lib/cjs/appui-abstract/backstage/BackstageItem.js.map +1 -1
  16. package/lib/cjs/appui-abstract/backstage/BackstageItemsManager.d.ts +38 -38
  17. package/lib/cjs/appui-abstract/backstage/BackstageItemsManager.js +133 -133
  18. package/lib/cjs/appui-abstract/backstage/BackstageItemsManager.js.map +1 -1
  19. package/lib/cjs/appui-abstract/common/KeyboardKey.d.ts +51 -51
  20. package/lib/cjs/appui-abstract/common/KeyboardKey.js +63 -63
  21. package/lib/cjs/appui-abstract/common/KeyboardKey.js.map +1 -1
  22. package/lib/cjs/appui-abstract/content/ContentLayoutProps.d.ts +62 -62
  23. package/lib/cjs/appui-abstract/content/ContentLayoutProps.js +9 -9
  24. package/lib/cjs/appui-abstract/content/ContentLayoutProps.js.map +1 -1
  25. package/lib/cjs/appui-abstract/content/StandardContentLayouts.d.ts +19 -19
  26. package/lib/cjs/appui-abstract/content/StandardContentLayouts.js +108 -108
  27. package/lib/cjs/appui-abstract/content/StandardContentLayouts.js.map +1 -1
  28. package/lib/cjs/appui-abstract/dialogs/DialogItem.d.ts +76 -76
  29. package/lib/cjs/appui-abstract/dialogs/DialogItem.js +67 -67
  30. package/lib/cjs/appui-abstract/dialogs/DialogItem.js.map +1 -1
  31. package/lib/cjs/appui-abstract/dialogs/UiDataProvider.d.ts +55 -55
  32. package/lib/cjs/appui-abstract/dialogs/UiDataProvider.js +66 -66
  33. package/lib/cjs/appui-abstract/dialogs/UiDataProvider.js.map +1 -1
  34. package/lib/cjs/appui-abstract/dialogs/UiLayoutDataProvider.d.ts +97 -97
  35. package/lib/cjs/appui-abstract/dialogs/UiLayoutDataProvider.js +175 -175
  36. package/lib/cjs/appui-abstract/dialogs/UiLayoutDataProvider.js.map +1 -1
  37. package/lib/cjs/appui-abstract/items/AbstractItemProps.d.ts +53 -53
  38. package/lib/cjs/appui-abstract/items/AbstractItemProps.js +9 -9
  39. package/lib/cjs/appui-abstract/items/AbstractItemProps.js.map +1 -1
  40. package/lib/cjs/appui-abstract/items/AbstractMenuItemProps.d.ts +20 -20
  41. package/lib/cjs/appui-abstract/items/AbstractMenuItemProps.js +9 -9
  42. package/lib/cjs/appui-abstract/items/AbstractMenuItemProps.js.map +1 -1
  43. package/lib/cjs/appui-abstract/items/AbstractToolbarProps.d.ts +13 -13
  44. package/lib/cjs/appui-abstract/items/AbstractToolbarProps.js +9 -9
  45. package/lib/cjs/appui-abstract/items/AbstractToolbarProps.js.map +1 -1
  46. package/lib/cjs/appui-abstract/items/BadgeType.d.ts +14 -14
  47. package/lib/cjs/appui-abstract/items/BadgeType.js +22 -22
  48. package/lib/cjs/appui-abstract/items/BadgeType.js.map +1 -1
  49. package/lib/cjs/appui-abstract/items/ConditionalBooleanValue.d.ts +27 -27
  50. package/lib/cjs/appui-abstract/items/ConditionalBooleanValue.js +60 -60
  51. package/lib/cjs/appui-abstract/items/ConditionalBooleanValue.js.map +1 -1
  52. package/lib/cjs/appui-abstract/items/ConditionalStringValue.d.ts +29 -29
  53. package/lib/cjs/appui-abstract/items/ConditionalStringValue.js +62 -62
  54. package/lib/cjs/appui-abstract/items/ConditionalStringValue.js.map +1 -1
  55. package/lib/cjs/appui-abstract/items/ProvidedItem.d.ts +10 -10
  56. package/lib/cjs/appui-abstract/items/ProvidedItem.js +9 -9
  57. package/lib/cjs/appui-abstract/items/ProvidedItem.js.map +1 -1
  58. package/lib/cjs/appui-abstract/items/RelativePosition.d.ts +18 -18
  59. package/lib/cjs/appui-abstract/items/RelativePosition.js +26 -26
  60. package/lib/cjs/appui-abstract/items/RelativePosition.js.map +1 -1
  61. package/lib/cjs/appui-abstract/items/StageUsage.d.ts +15 -15
  62. package/lib/cjs/appui-abstract/items/StageUsage.js +23 -23
  63. package/lib/cjs/appui-abstract/items/StageUsage.js.map +1 -1
  64. package/lib/cjs/appui-abstract/notification/MessagePresenter.d.ts +42 -42
  65. package/lib/cjs/appui-abstract/notification/MessagePresenter.js +24 -24
  66. package/lib/cjs/appui-abstract/notification/MessagePresenter.js.map +1 -1
  67. package/lib/cjs/appui-abstract/notification/MessageSeverity.d.ts +15 -15
  68. package/lib/cjs/appui-abstract/notification/MessageSeverity.js +23 -23
  69. package/lib/cjs/appui-abstract/notification/MessageSeverity.js.map +1 -1
  70. package/lib/cjs/appui-abstract/properties/Description.d.ts +127 -127
  71. package/lib/cjs/appui-abstract/properties/Description.js +196 -196
  72. package/lib/cjs/appui-abstract/properties/Description.js.map +1 -1
  73. package/lib/cjs/appui-abstract/properties/EditorParams.d.ts +260 -260
  74. package/lib/cjs/appui-abstract/properties/EditorParams.js +106 -106
  75. package/lib/cjs/appui-abstract/properties/EditorParams.js.map +1 -1
  76. package/lib/cjs/appui-abstract/properties/PrimitiveTypes.d.ts +60 -60
  77. package/lib/cjs/appui-abstract/properties/PrimitiveTypes.js +9 -9
  78. package/lib/cjs/appui-abstract/properties/PrimitiveTypes.js.map +1 -1
  79. package/lib/cjs/appui-abstract/properties/Record.d.ts +57 -57
  80. package/lib/cjs/appui-abstract/properties/Record.js +78 -78
  81. package/lib/cjs/appui-abstract/properties/Record.js.map +1 -1
  82. package/lib/cjs/appui-abstract/properties/StandardEditorNames.d.ts +22 -22
  83. package/lib/cjs/appui-abstract/properties/StandardEditorNames.js +30 -30
  84. package/lib/cjs/appui-abstract/properties/StandardEditorNames.js.map +1 -1
  85. package/lib/cjs/appui-abstract/properties/StandardTypeNames.d.ts +30 -30
  86. package/lib/cjs/appui-abstract/properties/StandardTypeNames.js +39 -39
  87. package/lib/cjs/appui-abstract/properties/StandardTypeNames.js.map +1 -1
  88. package/lib/cjs/appui-abstract/properties/Value.d.ts +49 -49
  89. package/lib/cjs/appui-abstract/properties/Value.js +20 -20
  90. package/lib/cjs/appui-abstract/properties/Value.js.map +1 -1
  91. package/lib/cjs/appui-abstract/quantity/BaseQuantityDescription.d.ts +22 -22
  92. package/lib/cjs/appui-abstract/quantity/BaseQuantityDescription.js +48 -48
  93. package/lib/cjs/appui-abstract/quantity/BaseQuantityDescription.js.map +1 -1
  94. package/lib/cjs/appui-abstract/statusbar/StatusBarItem.d.ts +116 -116
  95. package/lib/cjs/appui-abstract/statusbar/StatusBarItem.js +81 -81
  96. package/lib/cjs/appui-abstract/statusbar/StatusBarItem.js.map +1 -1
  97. package/lib/cjs/appui-abstract/statusbar/StatusBarItemsManager.d.ts +39 -39
  98. package/lib/cjs/appui-abstract/statusbar/StatusBarItemsManager.js +135 -135
  99. package/lib/cjs/appui-abstract/statusbar/StatusBarItemsManager.js.map +1 -1
  100. package/lib/cjs/appui-abstract/toolbars/ToolbarItem.d.ts +118 -118
  101. package/lib/cjs/appui-abstract/toolbars/ToolbarItem.js +62 -62
  102. package/lib/cjs/appui-abstract/toolbars/ToolbarItem.js.map +1 -1
  103. package/lib/cjs/appui-abstract/toolbars/ToolbarItemsManager.d.ts +45 -45
  104. package/lib/cjs/appui-abstract/toolbars/ToolbarItemsManager.js +235 -235
  105. package/lib/cjs/appui-abstract/toolbars/ToolbarItemsManager.js.map +1 -1
  106. package/lib/cjs/appui-abstract/utils/IconSpecUtilities.d.ts +29 -29
  107. package/lib/cjs/appui-abstract/utils/IconSpecUtilities.js +51 -51
  108. package/lib/cjs/appui-abstract/utils/IconSpecUtilities.js.map +1 -1
  109. package/lib/cjs/appui-abstract/utils/PointProps.d.ts +10 -10
  110. package/lib/cjs/appui-abstract/utils/PointProps.js +9 -9
  111. package/lib/cjs/appui-abstract/utils/PointProps.js.map +1 -1
  112. package/lib/cjs/appui-abstract/utils/UiError.d.ts +12 -12
  113. package/lib/cjs/appui-abstract/utils/UiError.js +22 -22
  114. package/lib/cjs/appui-abstract/utils/UiError.js.map +1 -1
  115. package/lib/cjs/appui-abstract/utils/UiEvent.d.ts +9 -9
  116. package/lib/cjs/appui-abstract/utils/UiEvent.js +17 -17
  117. package/lib/cjs/appui-abstract/utils/UiEvent.js.map +1 -1
  118. package/lib/cjs/appui-abstract/utils/UiEventDispatcher.d.ts +46 -46
  119. package/lib/cjs/appui-abstract/utils/UiEventDispatcher.js +131 -131
  120. package/lib/cjs/appui-abstract/utils/UiEventDispatcher.js.map +1 -1
  121. package/lib/cjs/appui-abstract/utils/callbacks.d.ts +20 -20
  122. package/lib/cjs/appui-abstract/utils/callbacks.js +9 -9
  123. package/lib/cjs/appui-abstract/utils/callbacks.js.map +1 -1
  124. package/lib/cjs/appui-abstract/utils/filter/charCode.d.ts +416 -416
  125. package/lib/cjs/appui-abstract/utils/filter/charCode.js +6 -6
  126. package/lib/cjs/appui-abstract/utils/filter/charCode.js.map +1 -1
  127. package/lib/cjs/appui-abstract/utils/filter/filters.d.ts +98 -98
  128. package/lib/cjs/appui-abstract/utils/filter/filters.js +709 -709
  129. package/lib/cjs/appui-abstract/utils/filter/filters.js.map +1 -1
  130. package/lib/cjs/appui-abstract/utils/filter/map.d.ts +59 -59
  131. package/lib/cjs/appui-abstract/utils/filter/map.js +404 -404
  132. package/lib/cjs/appui-abstract/utils/filter/map.js.map +1 -1
  133. package/lib/cjs/appui-abstract/utils/filter/strings.d.ts +20 -20
  134. package/lib/cjs/appui-abstract/utils/filter/strings.js +78 -78
  135. package/lib/cjs/appui-abstract/utils/filter/strings.js.map +1 -1
  136. package/lib/cjs/appui-abstract/utils/isLetter.d.ts +9 -9
  137. package/lib/cjs/appui-abstract/utils/isLetter.js +19 -19
  138. package/lib/cjs/appui-abstract/utils/isLetter.js.map +1 -1
  139. package/lib/cjs/appui-abstract/utils/misc.d.ts +11 -11
  140. package/lib/cjs/appui-abstract/utils/misc.js +36 -36
  141. package/lib/cjs/appui-abstract/utils/misc.js.map +1 -1
  142. package/lib/cjs/appui-abstract/widget/AbstractWidgetProps.d.ts +83 -83
  143. package/lib/cjs/appui-abstract/widget/AbstractWidgetProps.js +9 -9
  144. package/lib/cjs/appui-abstract/widget/AbstractWidgetProps.js.map +1 -1
  145. package/lib/cjs/appui-abstract/widget/StagePanel.d.ts +32 -32
  146. package/lib/cjs/appui-abstract/widget/StagePanel.js +42 -42
  147. package/lib/cjs/appui-abstract/widget/StagePanel.js.map +1 -1
  148. package/lib/cjs/appui-abstract/widget/WidgetState.d.ts +18 -18
  149. package/lib/cjs/appui-abstract/widget/WidgetState.js +26 -26
  150. package/lib/cjs/appui-abstract/widget/WidgetState.js.map +1 -1
  151. package/lib/cjs/appui-abstract.d.ts +105 -105
  152. package/lib/cjs/appui-abstract.js +121 -121
  153. package/lib/cjs/appui-abstract.js.map +1 -1
  154. package/lib/esm/appui-abstract/BaseUiItemsProvider.d.ts +30 -30
  155. package/lib/esm/appui-abstract/BaseUiItemsProvider.js +75 -75
  156. package/lib/esm/appui-abstract/BaseUiItemsProvider.js.map +1 -1
  157. package/lib/esm/appui-abstract/UiAdmin.d.ts +221 -221
  158. package/lib/esm/appui-abstract/UiAdmin.js +219 -219
  159. package/lib/esm/appui-abstract/UiAdmin.js.map +1 -1
  160. package/lib/esm/appui-abstract/UiItemsManager.d.ts +110 -110
  161. package/lib/esm/appui-abstract/UiItemsManager.js +195 -195
  162. package/lib/esm/appui-abstract/UiItemsManager.js.map +1 -1
  163. package/lib/esm/appui-abstract/UiItemsProvider.d.ts +27 -27
  164. package/lib/esm/appui-abstract/UiItemsProvider.js +9 -9
  165. package/lib/esm/appui-abstract/UiItemsProvider.js.map +1 -1
  166. package/lib/esm/appui-abstract/backstage/BackstageItem.d.ts +83 -83
  167. package/lib/esm/appui-abstract/backstage/BackstageItem.js +58 -58
  168. package/lib/esm/appui-abstract/backstage/BackstageItem.js.map +1 -1
  169. package/lib/esm/appui-abstract/backstage/BackstageItemsManager.d.ts +38 -38
  170. package/lib/esm/appui-abstract/backstage/BackstageItemsManager.js +129 -129
  171. package/lib/esm/appui-abstract/backstage/BackstageItemsManager.js.map +1 -1
  172. package/lib/esm/appui-abstract/common/KeyboardKey.d.ts +51 -51
  173. package/lib/esm/appui-abstract/common/KeyboardKey.js +59 -59
  174. package/lib/esm/appui-abstract/common/KeyboardKey.js.map +1 -1
  175. package/lib/esm/appui-abstract/content/ContentLayoutProps.d.ts +62 -62
  176. package/lib/esm/appui-abstract/content/ContentLayoutProps.js +8 -8
  177. package/lib/esm/appui-abstract/content/ContentLayoutProps.js.map +1 -1
  178. package/lib/esm/appui-abstract/content/StandardContentLayouts.d.ts +19 -19
  179. package/lib/esm/appui-abstract/content/StandardContentLayouts.js +104 -104
  180. package/lib/esm/appui-abstract/content/StandardContentLayouts.js.map +1 -1
  181. package/lib/esm/appui-abstract/dialogs/DialogItem.d.ts +76 -76
  182. package/lib/esm/appui-abstract/dialogs/DialogItem.js +63 -63
  183. package/lib/esm/appui-abstract/dialogs/DialogItem.js.map +1 -1
  184. package/lib/esm/appui-abstract/dialogs/UiDataProvider.d.ts +55 -55
  185. package/lib/esm/appui-abstract/dialogs/UiDataProvider.js +61 -61
  186. package/lib/esm/appui-abstract/dialogs/UiDataProvider.js.map +1 -1
  187. package/lib/esm/appui-abstract/dialogs/UiLayoutDataProvider.d.ts +97 -97
  188. package/lib/esm/appui-abstract/dialogs/UiLayoutDataProvider.js +170 -170
  189. package/lib/esm/appui-abstract/dialogs/UiLayoutDataProvider.js.map +1 -1
  190. package/lib/esm/appui-abstract/items/AbstractItemProps.d.ts +53 -53
  191. package/lib/esm/appui-abstract/items/AbstractItemProps.js +8 -8
  192. package/lib/esm/appui-abstract/items/AbstractItemProps.js.map +1 -1
  193. package/lib/esm/appui-abstract/items/AbstractMenuItemProps.d.ts +20 -20
  194. package/lib/esm/appui-abstract/items/AbstractMenuItemProps.js +8 -8
  195. package/lib/esm/appui-abstract/items/AbstractMenuItemProps.js.map +1 -1
  196. package/lib/esm/appui-abstract/items/AbstractToolbarProps.d.ts +13 -13
  197. package/lib/esm/appui-abstract/items/AbstractToolbarProps.js +8 -8
  198. package/lib/esm/appui-abstract/items/AbstractToolbarProps.js.map +1 -1
  199. package/lib/esm/appui-abstract/items/BadgeType.d.ts +14 -14
  200. package/lib/esm/appui-abstract/items/BadgeType.js +19 -19
  201. package/lib/esm/appui-abstract/items/BadgeType.js.map +1 -1
  202. package/lib/esm/appui-abstract/items/ConditionalBooleanValue.d.ts +27 -27
  203. package/lib/esm/appui-abstract/items/ConditionalBooleanValue.js +56 -56
  204. package/lib/esm/appui-abstract/items/ConditionalBooleanValue.js.map +1 -1
  205. package/lib/esm/appui-abstract/items/ConditionalStringValue.d.ts +29 -29
  206. package/lib/esm/appui-abstract/items/ConditionalStringValue.js +58 -58
  207. package/lib/esm/appui-abstract/items/ConditionalStringValue.js.map +1 -1
  208. package/lib/esm/appui-abstract/items/ProvidedItem.d.ts +10 -10
  209. package/lib/esm/appui-abstract/items/ProvidedItem.js +8 -8
  210. package/lib/esm/appui-abstract/items/ProvidedItem.js.map +1 -1
  211. package/lib/esm/appui-abstract/items/RelativePosition.d.ts +18 -18
  212. package/lib/esm/appui-abstract/items/RelativePosition.js +23 -23
  213. package/lib/esm/appui-abstract/items/RelativePosition.js.map +1 -1
  214. package/lib/esm/appui-abstract/items/StageUsage.d.ts +15 -15
  215. package/lib/esm/appui-abstract/items/StageUsage.js +20 -20
  216. package/lib/esm/appui-abstract/items/StageUsage.js.map +1 -1
  217. package/lib/esm/appui-abstract/notification/MessagePresenter.d.ts +42 -42
  218. package/lib/esm/appui-abstract/notification/MessagePresenter.js +21 -21
  219. package/lib/esm/appui-abstract/notification/MessagePresenter.js.map +1 -1
  220. package/lib/esm/appui-abstract/notification/MessageSeverity.d.ts +15 -15
  221. package/lib/esm/appui-abstract/notification/MessageSeverity.js +20 -20
  222. package/lib/esm/appui-abstract/notification/MessageSeverity.js.map +1 -1
  223. package/lib/esm/appui-abstract/properties/Description.d.ts +127 -127
  224. package/lib/esm/appui-abstract/properties/Description.js +192 -192
  225. package/lib/esm/appui-abstract/properties/Description.js.map +1 -1
  226. package/lib/esm/appui-abstract/properties/EditorParams.d.ts +260 -260
  227. package/lib/esm/appui-abstract/properties/EditorParams.js +97 -97
  228. package/lib/esm/appui-abstract/properties/EditorParams.js.map +1 -1
  229. package/lib/esm/appui-abstract/properties/PrimitiveTypes.d.ts +60 -60
  230. package/lib/esm/appui-abstract/properties/PrimitiveTypes.js +8 -8
  231. package/lib/esm/appui-abstract/properties/PrimitiveTypes.js.map +1 -1
  232. package/lib/esm/appui-abstract/properties/Record.d.ts +57 -57
  233. package/lib/esm/appui-abstract/properties/Record.js +74 -74
  234. package/lib/esm/appui-abstract/properties/Record.js.map +1 -1
  235. package/lib/esm/appui-abstract/properties/StandardEditorNames.d.ts +22 -22
  236. package/lib/esm/appui-abstract/properties/StandardEditorNames.js +27 -27
  237. package/lib/esm/appui-abstract/properties/StandardEditorNames.js.map +1 -1
  238. package/lib/esm/appui-abstract/properties/StandardTypeNames.d.ts +30 -30
  239. package/lib/esm/appui-abstract/properties/StandardTypeNames.js +36 -36
  240. package/lib/esm/appui-abstract/properties/StandardTypeNames.js.map +1 -1
  241. package/lib/esm/appui-abstract/properties/Value.d.ts +49 -49
  242. package/lib/esm/appui-abstract/properties/Value.js +17 -17
  243. package/lib/esm/appui-abstract/properties/Value.js.map +1 -1
  244. package/lib/esm/appui-abstract/quantity/BaseQuantityDescription.d.ts +22 -22
  245. package/lib/esm/appui-abstract/quantity/BaseQuantityDescription.js +44 -44
  246. package/lib/esm/appui-abstract/quantity/BaseQuantityDescription.js.map +1 -1
  247. package/lib/esm/appui-abstract/statusbar/StatusBarItem.d.ts +116 -116
  248. package/lib/esm/appui-abstract/statusbar/StatusBarItem.js +74 -74
  249. package/lib/esm/appui-abstract/statusbar/StatusBarItem.js.map +1 -1
  250. package/lib/esm/appui-abstract/statusbar/StatusBarItemsManager.d.ts +39 -39
  251. package/lib/esm/appui-abstract/statusbar/StatusBarItemsManager.js +131 -131
  252. package/lib/esm/appui-abstract/statusbar/StatusBarItemsManager.js.map +1 -1
  253. package/lib/esm/appui-abstract/toolbars/ToolbarItem.d.ts +118 -118
  254. package/lib/esm/appui-abstract/toolbars/ToolbarItem.js +58 -58
  255. package/lib/esm/appui-abstract/toolbars/ToolbarItem.js.map +1 -1
  256. package/lib/esm/appui-abstract/toolbars/ToolbarItemsManager.d.ts +45 -45
  257. package/lib/esm/appui-abstract/toolbars/ToolbarItemsManager.js +231 -231
  258. package/lib/esm/appui-abstract/toolbars/ToolbarItemsManager.js.map +1 -1
  259. package/lib/esm/appui-abstract/utils/IconSpecUtilities.d.ts +29 -29
  260. package/lib/esm/appui-abstract/utils/IconSpecUtilities.js +47 -47
  261. package/lib/esm/appui-abstract/utils/IconSpecUtilities.js.map +1 -1
  262. package/lib/esm/appui-abstract/utils/PointProps.d.ts +10 -10
  263. package/lib/esm/appui-abstract/utils/PointProps.js +8 -8
  264. package/lib/esm/appui-abstract/utils/PointProps.js.map +1 -1
  265. package/lib/esm/appui-abstract/utils/UiError.d.ts +12 -12
  266. package/lib/esm/appui-abstract/utils/UiError.js +18 -18
  267. package/lib/esm/appui-abstract/utils/UiError.js.map +1 -1
  268. package/lib/esm/appui-abstract/utils/UiEvent.d.ts +9 -9
  269. package/lib/esm/appui-abstract/utils/UiEvent.js +13 -13
  270. package/lib/esm/appui-abstract/utils/UiEvent.js.map +1 -1
  271. package/lib/esm/appui-abstract/utils/UiEventDispatcher.d.ts +46 -46
  272. package/lib/esm/appui-abstract/utils/UiEventDispatcher.js +126 -126
  273. package/lib/esm/appui-abstract/utils/UiEventDispatcher.js.map +1 -1
  274. package/lib/esm/appui-abstract/utils/callbacks.d.ts +20 -20
  275. package/lib/esm/appui-abstract/utils/callbacks.js +8 -8
  276. package/lib/esm/appui-abstract/utils/callbacks.js.map +1 -1
  277. package/lib/esm/appui-abstract/utils/filter/charCode.d.ts +416 -416
  278. package/lib/esm/appui-abstract/utils/filter/charCode.js +5 -5
  279. package/lib/esm/appui-abstract/utils/filter/charCode.js.map +1 -1
  280. package/lib/esm/appui-abstract/utils/filter/filters.d.ts +98 -98
  281. package/lib/esm/appui-abstract/utils/filter/filters.js +694 -694
  282. package/lib/esm/appui-abstract/utils/filter/filters.js.map +1 -1
  283. package/lib/esm/appui-abstract/utils/filter/map.d.ts +59 -59
  284. package/lib/esm/appui-abstract/utils/filter/map.js +399 -399
  285. package/lib/esm/appui-abstract/utils/filter/map.js.map +1 -1
  286. package/lib/esm/appui-abstract/utils/filter/strings.d.ts +20 -20
  287. package/lib/esm/appui-abstract/utils/filter/strings.js +70 -70
  288. package/lib/esm/appui-abstract/utils/filter/strings.js.map +1 -1
  289. package/lib/esm/appui-abstract/utils/isLetter.d.ts +9 -9
  290. package/lib/esm/appui-abstract/utils/isLetter.js +15 -15
  291. package/lib/esm/appui-abstract/utils/isLetter.js.map +1 -1
  292. package/lib/esm/appui-abstract/utils/misc.d.ts +11 -11
  293. package/lib/esm/appui-abstract/utils/misc.js +31 -31
  294. package/lib/esm/appui-abstract/utils/misc.js.map +1 -1
  295. package/lib/esm/appui-abstract/widget/AbstractWidgetProps.d.ts +83 -83
  296. package/lib/esm/appui-abstract/widget/AbstractWidgetProps.js +8 -8
  297. package/lib/esm/appui-abstract/widget/AbstractWidgetProps.js.map +1 -1
  298. package/lib/esm/appui-abstract/widget/StagePanel.d.ts +32 -32
  299. package/lib/esm/appui-abstract/widget/StagePanel.js +39 -39
  300. package/lib/esm/appui-abstract/widget/StagePanel.js.map +1 -1
  301. package/lib/esm/appui-abstract/widget/WidgetState.d.ts +18 -18
  302. package/lib/esm/appui-abstract/widget/WidgetState.js +23 -23
  303. package/lib/esm/appui-abstract/widget/WidgetState.js.map +1 -1
  304. package/lib/esm/appui-abstract.d.ts +105 -105
  305. package/lib/esm/appui-abstract.js +109 -109
  306. package/lib/esm/appui-abstract.js.map +1 -1
  307. package/package.json +5 -5
@@ -1 +1 @@
1
- {"version":3,"file":"UiItemsManager.js","sourceRoot":"","sources":["../../../src/appui-abstract/UiItemsManager.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/* eslint-disable deprecation/deprecation */\n/** @packageDocumentation\n * @module UiItemsProvider\n */\n\nimport { BeEvent, Logger, MarkRequired } from \"@itwin/core-bentley\";\nimport { BackstageItem } from \"./backstage/BackstageItem\";\nimport { CommonStatusBarItem } from \"./statusbar/StatusBarItem\";\nimport { CommonToolbarItem, ToolbarOrientation, ToolbarUsage } from \"./toolbars/ToolbarItem\";\nimport { AbstractWidgetProps } from \"./widget/AbstractWidgetProps\";\nimport { AbstractZoneLocation, StagePanelLocation, StagePanelSection } from \"./widget/StagePanel\";\nimport { loggerCategory } from \"./utils/misc\";\nimport { UiItemsProvider } from \"./UiItemsProvider\";\n\n/** Action taken by the application on item provided by a UiItemsProvider\n * @public @deprecated this was only used by the previously removed UiItemsArbiter.\n */\nexport enum UiItemsApplicationAction {\n /** Allow the change to the item */\n Allow,\n /** Disallow the change to the item */\n Disallow,\n /** Update the item during the change */\n Update,\n}\n\n/** UIProvider Registered Event Args interface.\n * @public\n */\nexport interface UiItemProviderRegisteredEventArgs {\n providerId: string;\n}\n\n/** UiItemProviderOverrides allows the application that registers a provider to limit when it is allowed to provide items\n * @public\n */\nexport interface AllowedUiItemProviderOverrides {\n /** allows providerId to be overridden in the items manager for cases where the same provider needs to provide different content to different stages\n * @beta\n */\n providerId?: string;\n /** if specified then the current stage's Usage will be compared before allowing any items to be provided\n * @beta\n */\n stageUsages?: string[];\n /** if specified then the current stage's Id will be compared before allowing any items to be provided\n * @beta\n */\n stageIds?: string[];\n}\n\n/** Allowed overrides applied to a UiItemsProvider the application that registers a provider to limit when it is allowed to provide items.\n * Note that if an override `providerId` is specified then either `stageIds` or `stageUsages` must be defined to limit when the provider's\n * items are allowed.\n * @public\n */\nexport type UiItemProviderOverrides = MarkRequired<AllowedUiItemProviderOverrides, \"providerId\" | \"stageUsages\"> |\n MarkRequired<AllowedUiItemProviderOverrides, \"providerId\" | \"stageIds\"> | // eslint-disable-line @typescript-eslint/indent\n MarkRequired<AllowedUiItemProviderOverrides, \"stageIds\"> | // eslint-disable-line @typescript-eslint/indent\n MarkRequired<AllowedUiItemProviderOverrides, \"stageUsages\"> | // eslint-disable-line @typescript-eslint/indent\n MarkRequired<AllowedUiItemProviderOverrides, \"providerId\" | \"stageUsages\" | \"stageIds\">; // eslint-disable-line @typescript-eslint/indent\n\n/** Interface that defines an instance of a UiItemsProvider and its application specified overrides.\n * @beta\n */\ninterface UiItemProviderEntry {\n provider: UiItemsProvider;\n overrides?: UiItemProviderOverrides;\n}\n\n/**\n * Controls registering of UiItemsProviders and calls the provider's methods when populating different parts of the User Interface.\n * @public\n */\nexport class UiItemsManager {\n private static _registeredUiItemsProviders: Map<string, UiItemProviderEntry> = new Map<string, UiItemProviderEntry>();\n\n /** For use in unit testing\n * @internal */\n public static clearAllProviders() {\n UiItemsManager._registeredUiItemsProviders.clear();\n }\n\n /** Event raised any time a UiProvider is registered or unregistered. */\n public static readonly onUiProviderRegisteredEvent = new BeEvent<(ev: UiItemProviderRegisteredEventArgs) => void>();\n\n /** Return number of registered UiProvider. */\n public static get registeredProviderIds() {\n const ids = [...UiItemsManager._registeredUiItemsProviders.keys()];\n return ids;\n }\n\n /** Return true if there is any registered UiProvider. */\n public static get hasRegisteredProviders(): boolean {\n return this._registeredUiItemsProviders.size > 0;\n }\n\n /**\n * Retrieves a previously loaded UiItemsProvider.\n * @param providerId id of the UiItemsProvider to get\n */\n public static getUiItemsProvider(providerId: string): UiItemsProvider | undefined {\n return UiItemsManager._registeredUiItemsProviders.get(providerId)?.provider;\n }\n\n private static sendRegisteredEvent(ev: UiItemProviderRegisteredEventArgs) {\n UiItemsManager.onUiProviderRegisteredEvent.raiseEvent(ev);\n }\n\n /**\n * Registers a UiItemsProvider with the UiItemsManager.\n * @param uiProvider the UI items provider to register.\n */\n public static register(uiProvider: UiItemsProvider, overrides?: UiItemProviderOverrides): void {\n const providerId = overrides?.providerId ?? uiProvider.id;\n\n if (UiItemsManager.getUiItemsProvider(providerId)) {\n Logger.logInfo(loggerCategory(this), `UiItemsProvider (${providerId}) is already loaded`);\n } else {\n UiItemsManager._registeredUiItemsProviders.set(providerId, { provider: uiProvider, overrides });\n Logger.logInfo(loggerCategory(this), `UiItemsProvider ${uiProvider.id} registered as ${providerId} `);\n\n UiItemsManager.sendRegisteredEvent({ providerId } as UiItemProviderRegisteredEventArgs);\n }\n }\n\n /** Remove a specific UiItemsProvider from the list of available providers. */\n public static unregister(uiProviderId: string): void {\n const provider = UiItemsManager.getUiItemsProvider(uiProviderId);\n if (!provider)\n return;\n\n provider.onUnregister && provider.onUnregister();\n\n UiItemsManager._registeredUiItemsProviders.delete(uiProviderId);\n Logger.logInfo(loggerCategory(this), `UiItemsProvider (${uiProviderId}) unloaded`);\n\n // trigger a refresh of the ui\n UiItemsManager.sendRegisteredEvent({ providerId: uiProviderId } as UiItemProviderRegisteredEventArgs);\n }\n\n private static allowItemsFromProvider(entry: UiItemProviderEntry, stageId?: string, stageUsage?: string) {\n // istanbul ignore else\n const overrides = entry.overrides;\n if (undefined !== stageId && overrides?.stageIds && !(overrides.stageIds.some((value: string) => value === stageId)))\n return false;\n if (undefined !== stageUsage && overrides?.stageUsages && !(overrides.stageUsages.some((value: string) => value === stageUsage)))\n return false;\n return true;\n }\n\n /** Called when the application is populating a toolbar so that any registered UiItemsProvider can add tool buttons that either either execute\n * an action or specify a registered ToolId into toolbar.\n * @param stageId a string identifier the active stage.\n * @param stageUsage the StageUsage of the active stage.\n * @param toolbarUsage usage of the toolbar\n * @param toolbarOrientation orientation of the toolbar\n * @returns an array of error messages. The array will be empty if the load is successful, otherwise it is a list of one or more problems.\n */\n public static getToolbarButtonItems(stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage,\n toolbarOrientation: ToolbarOrientation, stageAppData?: any): CommonToolbarItem[] {\n const buttonItems: CommonToolbarItem[] = [];\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\n return buttonItems;\n\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\n const uiProvider = entry.provider;\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\n // istanbul ignore else\n if (uiProvider.provideToolbarButtonItems && this.allowItemsFromProvider(entry, stageId, stageUsage)) {\n uiProvider.provideToolbarButtonItems(stageId, stageUsage, toolbarUsage, toolbarOrientation, stageAppData)\n .forEach((spec: CommonToolbarItem) => {\n // ignore duplicate ids\n if (-1 === buttonItems.findIndex((existingItem)=> spec.id === existingItem.id ))\n buttonItems.push({ ...spec, providerId });\n });\n }\n });\n\n return buttonItems;\n }\n\n /** Called when the application is populating the statusbar so that any registered UiItemsProvider can add status fields\n * @param stageId a string identifier the active stage.\n * @param stageUsage the StageUsage of the active stage.\n * @returns An array of CommonStatusBarItem that will be used to create controls for the status bar.\n */\n public static getStatusBarItems(stageId: string, stageUsage: string, stageAppData?: any): CommonStatusBarItem[] {\n const statusBarItems: CommonStatusBarItem[] = [];\n\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\n return statusBarItems;\n\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\n const uiProvider = entry.provider;\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\n\n // istanbul ignore else\n if (uiProvider.provideStatusBarItems && this.allowItemsFromProvider(entry, stageId, stageUsage)) {\n uiProvider.provideStatusBarItems(stageId, stageUsage, stageAppData)\n .forEach((item: CommonStatusBarItem) => {\n // ignore duplicate ids\n if (-1 === statusBarItems.findIndex((existingItem)=> item.id === existingItem.id ))\n statusBarItems.push({ ...item, providerId });\n });\n }\n });\n\n return statusBarItems;\n }\n\n /** Called when the application is populating the statusbar so that any registered UiItemsProvider can add status fields\n * @returns An array of BackstageItem that will be used to create controls for the backstage menu.\n */\n public static getBackstageItems(): BackstageItem[] {\n const backstageItems: BackstageItem[] = [];\n\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\n return backstageItems;\n\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\n const uiProvider = entry.provider;\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\n\n // istanbul ignore else\n if (uiProvider.provideBackstageItems) { // Note: We do not call this.allowItemsFromProvider here as backstage items\n uiProvider.provideBackstageItems() // should not be considered stage specific. If they need to be hidden\n .forEach((item: BackstageItem) => { // the isHidden property should be set to a ConditionalBooleanValue\n // ignore duplicate ids\n if (-1 === backstageItems.findIndex((existingItem)=> item.id === existingItem.id ))\n backstageItems.push({ ...item, providerId });\n });\n }\n });\n return backstageItems;\n }\n\n /** Called when the application is populating the Stage Panels so that any registered UiItemsProvider can add widgets\n * @param stageId a string identifier the active stage.\n * @param stageUsage the StageUsage of the active stage.\n * @param location the location within the stage.\n * @param section the section within location.\n * @returns An array of AbstractWidgetProps that will be used to create widgets.\n */\n public static getWidgets(stageId: string, stageUsage: string, location: StagePanelLocation, section?: StagePanelSection, zoneLocation?: AbstractZoneLocation, stageAppData?: any): ReadonlyArray<AbstractWidgetProps> {\n const widgets: AbstractWidgetProps[] = [];\n\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\n return widgets;\n\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\n const uiProvider = entry.provider;\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\n\n // istanbul ignore else\n if (uiProvider.provideWidgets && this.allowItemsFromProvider(entry, stageId, stageUsage)) {\n uiProvider.provideWidgets(stageId, stageUsage, location, section, zoneLocation, stageAppData)\n .forEach((widget: AbstractWidgetProps) => {\n // ignore duplicate ids\n if (-1 === widgets.findIndex((existingItem)=> widget.id === existingItem.id ))\n widgets.push({ ...widget, providerId });\n });\n }\n });\n return widgets;\n }\n\n}\n"]}
1
+ {"version":3,"file":"UiItemsManager.js","sourceRoot":"","sources":["../../../src/appui-abstract/UiItemsManager.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/* eslint-disable deprecation/deprecation */\r\n/** @packageDocumentation\r\n * @module UiItemsProvider\r\n */\r\n\r\nimport { BeEvent, Logger, MarkRequired } from \"@itwin/core-bentley\";\r\nimport { BackstageItem } from \"./backstage/BackstageItem\";\r\nimport { CommonStatusBarItem } from \"./statusbar/StatusBarItem\";\r\nimport { CommonToolbarItem, ToolbarOrientation, ToolbarUsage } from \"./toolbars/ToolbarItem\";\r\nimport { AbstractWidgetProps } from \"./widget/AbstractWidgetProps\";\r\nimport { AbstractZoneLocation, StagePanelLocation, StagePanelSection } from \"./widget/StagePanel\";\r\nimport { loggerCategory } from \"./utils/misc\";\r\nimport { UiItemsProvider } from \"./UiItemsProvider\";\r\n\r\n/** Action taken by the application on item provided by a UiItemsProvider\r\n * @public @deprecated this was only used by the previously removed UiItemsArbiter.\r\n */\r\nexport enum UiItemsApplicationAction {\r\n /** Allow the change to the item */\r\n Allow,\r\n /** Disallow the change to the item */\r\n Disallow,\r\n /** Update the item during the change */\r\n Update,\r\n}\r\n\r\n/** UIProvider Registered Event Args interface.\r\n * @public\r\n */\r\nexport interface UiItemProviderRegisteredEventArgs {\r\n providerId: string;\r\n}\r\n\r\n/** UiItemProviderOverrides allows the application that registers a provider to limit when it is allowed to provide items\r\n * @public\r\n */\r\nexport interface AllowedUiItemProviderOverrides {\r\n /** allows providerId to be overridden in the items manager for cases where the same provider needs to provide different content to different stages\r\n * @beta\r\n */\r\n providerId?: string;\r\n /** if specified then the current stage's Usage will be compared before allowing any items to be provided\r\n * @beta\r\n */\r\n stageUsages?: string[];\r\n /** if specified then the current stage's Id will be compared before allowing any items to be provided\r\n * @beta\r\n */\r\n stageIds?: string[];\r\n}\r\n\r\n/** Allowed overrides applied to a UiItemsProvider the application that registers a provider to limit when it is allowed to provide items.\r\n * Note that if an override `providerId` is specified then either `stageIds` or `stageUsages` must be defined to limit when the provider's\r\n * items are allowed.\r\n * @public\r\n */\r\nexport type UiItemProviderOverrides = MarkRequired<AllowedUiItemProviderOverrides, \"providerId\" | \"stageUsages\"> |\r\n MarkRequired<AllowedUiItemProviderOverrides, \"providerId\" | \"stageIds\"> | // eslint-disable-line @typescript-eslint/indent\r\n MarkRequired<AllowedUiItemProviderOverrides, \"stageIds\"> | // eslint-disable-line @typescript-eslint/indent\r\n MarkRequired<AllowedUiItemProviderOverrides, \"stageUsages\"> | // eslint-disable-line @typescript-eslint/indent\r\n MarkRequired<AllowedUiItemProviderOverrides, \"providerId\" | \"stageUsages\" | \"stageIds\">; // eslint-disable-line @typescript-eslint/indent\r\n\r\n/** Interface that defines an instance of a UiItemsProvider and its application specified overrides.\r\n * @beta\r\n */\r\ninterface UiItemProviderEntry {\r\n provider: UiItemsProvider;\r\n overrides?: UiItemProviderOverrides;\r\n}\r\n\r\n/**\r\n * Controls registering of UiItemsProviders and calls the provider's methods when populating different parts of the User Interface.\r\n * @public\r\n */\r\nexport class UiItemsManager {\r\n private static _registeredUiItemsProviders: Map<string, UiItemProviderEntry> = new Map<string, UiItemProviderEntry>();\r\n\r\n /** For use in unit testing\r\n * @internal */\r\n public static clearAllProviders() {\r\n UiItemsManager._registeredUiItemsProviders.clear();\r\n }\r\n\r\n /** Event raised any time a UiProvider is registered or unregistered. */\r\n public static readonly onUiProviderRegisteredEvent = new BeEvent<(ev: UiItemProviderRegisteredEventArgs) => void>();\r\n\r\n /** Return number of registered UiProvider. */\r\n public static get registeredProviderIds() {\r\n const ids = [...UiItemsManager._registeredUiItemsProviders.keys()];\r\n return ids;\r\n }\r\n\r\n /** Return true if there is any registered UiProvider. */\r\n public static get hasRegisteredProviders(): boolean {\r\n return this._registeredUiItemsProviders.size > 0;\r\n }\r\n\r\n /**\r\n * Retrieves a previously loaded UiItemsProvider.\r\n * @param providerId id of the UiItemsProvider to get\r\n */\r\n public static getUiItemsProvider(providerId: string): UiItemsProvider | undefined {\r\n return UiItemsManager._registeredUiItemsProviders.get(providerId)?.provider;\r\n }\r\n\r\n private static sendRegisteredEvent(ev: UiItemProviderRegisteredEventArgs) {\r\n UiItemsManager.onUiProviderRegisteredEvent.raiseEvent(ev);\r\n }\r\n\r\n /**\r\n * Registers a UiItemsProvider with the UiItemsManager.\r\n * @param uiProvider the UI items provider to register.\r\n */\r\n public static register(uiProvider: UiItemsProvider, overrides?: UiItemProviderOverrides): void {\r\n const providerId = overrides?.providerId ?? uiProvider.id;\r\n\r\n if (UiItemsManager.getUiItemsProvider(providerId)) {\r\n Logger.logInfo(loggerCategory(this), `UiItemsProvider (${providerId}) is already loaded`);\r\n } else {\r\n UiItemsManager._registeredUiItemsProviders.set(providerId, { provider: uiProvider, overrides });\r\n Logger.logInfo(loggerCategory(this), `UiItemsProvider ${uiProvider.id} registered as ${providerId} `);\r\n\r\n UiItemsManager.sendRegisteredEvent({ providerId } as UiItemProviderRegisteredEventArgs);\r\n }\r\n }\r\n\r\n /** Remove a specific UiItemsProvider from the list of available providers. */\r\n public static unregister(uiProviderId: string): void {\r\n const provider = UiItemsManager.getUiItemsProvider(uiProviderId);\r\n if (!provider)\r\n return;\r\n\r\n provider.onUnregister && provider.onUnregister();\r\n\r\n UiItemsManager._registeredUiItemsProviders.delete(uiProviderId);\r\n Logger.logInfo(loggerCategory(this), `UiItemsProvider (${uiProviderId}) unloaded`);\r\n\r\n // trigger a refresh of the ui\r\n UiItemsManager.sendRegisteredEvent({ providerId: uiProviderId } as UiItemProviderRegisteredEventArgs);\r\n }\r\n\r\n private static allowItemsFromProvider(entry: UiItemProviderEntry, stageId?: string, stageUsage?: string) {\r\n // istanbul ignore else\r\n const overrides = entry.overrides;\r\n if (undefined !== stageId && overrides?.stageIds && !(overrides.stageIds.some((value: string) => value === stageId)))\r\n return false;\r\n if (undefined !== stageUsage && overrides?.stageUsages && !(overrides.stageUsages.some((value: string) => value === stageUsage)))\r\n return false;\r\n return true;\r\n }\r\n\r\n /** Called when the application is populating a toolbar so that any registered UiItemsProvider can add tool buttons that either either execute\r\n * an action or specify a registered ToolId into toolbar.\r\n * @param stageId a string identifier the active stage.\r\n * @param stageUsage the StageUsage of the active stage.\r\n * @param toolbarUsage usage of the toolbar\r\n * @param toolbarOrientation orientation of the toolbar\r\n * @returns an array of error messages. The array will be empty if the load is successful, otherwise it is a list of one or more problems.\r\n */\r\n public static getToolbarButtonItems(stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage,\r\n toolbarOrientation: ToolbarOrientation, stageAppData?: any): CommonToolbarItem[] {\r\n const buttonItems: CommonToolbarItem[] = [];\r\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\r\n return buttonItems;\r\n\r\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\r\n const uiProvider = entry.provider;\r\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\r\n // istanbul ignore else\r\n if (uiProvider.provideToolbarButtonItems && this.allowItemsFromProvider(entry, stageId, stageUsage)) {\r\n uiProvider.provideToolbarButtonItems(stageId, stageUsage, toolbarUsage, toolbarOrientation, stageAppData)\r\n .forEach((spec: CommonToolbarItem) => {\r\n // ignore duplicate ids\r\n if (-1 === buttonItems.findIndex((existingItem)=> spec.id === existingItem.id ))\r\n buttonItems.push({ ...spec, providerId });\r\n });\r\n }\r\n });\r\n\r\n return buttonItems;\r\n }\r\n\r\n /** Called when the application is populating the statusbar so that any registered UiItemsProvider can add status fields\r\n * @param stageId a string identifier the active stage.\r\n * @param stageUsage the StageUsage of the active stage.\r\n * @returns An array of CommonStatusBarItem that will be used to create controls for the status bar.\r\n */\r\n public static getStatusBarItems(stageId: string, stageUsage: string, stageAppData?: any): CommonStatusBarItem[] {\r\n const statusBarItems: CommonStatusBarItem[] = [];\r\n\r\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\r\n return statusBarItems;\r\n\r\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\r\n const uiProvider = entry.provider;\r\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\r\n\r\n // istanbul ignore else\r\n if (uiProvider.provideStatusBarItems && this.allowItemsFromProvider(entry, stageId, stageUsage)) {\r\n uiProvider.provideStatusBarItems(stageId, stageUsage, stageAppData)\r\n .forEach((item: CommonStatusBarItem) => {\r\n // ignore duplicate ids\r\n if (-1 === statusBarItems.findIndex((existingItem)=> item.id === existingItem.id ))\r\n statusBarItems.push({ ...item, providerId });\r\n });\r\n }\r\n });\r\n\r\n return statusBarItems;\r\n }\r\n\r\n /** Called when the application is populating the statusbar so that any registered UiItemsProvider can add status fields\r\n * @returns An array of BackstageItem that will be used to create controls for the backstage menu.\r\n */\r\n public static getBackstageItems(): BackstageItem[] {\r\n const backstageItems: BackstageItem[] = [];\r\n\r\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\r\n return backstageItems;\r\n\r\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\r\n const uiProvider = entry.provider;\r\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\r\n\r\n // istanbul ignore else\r\n if (uiProvider.provideBackstageItems) { // Note: We do not call this.allowItemsFromProvider here as backstage items\r\n uiProvider.provideBackstageItems() // should not be considered stage specific. If they need to be hidden\r\n .forEach((item: BackstageItem) => { // the isHidden property should be set to a ConditionalBooleanValue\r\n // ignore duplicate ids\r\n if (-1 === backstageItems.findIndex((existingItem)=> item.id === existingItem.id ))\r\n backstageItems.push({ ...item, providerId });\r\n });\r\n }\r\n });\r\n return backstageItems;\r\n }\r\n\r\n /** Called when the application is populating the Stage Panels so that any registered UiItemsProvider can add widgets\r\n * @param stageId a string identifier the active stage.\r\n * @param stageUsage the StageUsage of the active stage.\r\n * @param location the location within the stage.\r\n * @param section the section within location.\r\n * @returns An array of AbstractWidgetProps that will be used to create widgets.\r\n */\r\n public static getWidgets(stageId: string, stageUsage: string, location: StagePanelLocation, section?: StagePanelSection, zoneLocation?: AbstractZoneLocation, stageAppData?: any): ReadonlyArray<AbstractWidgetProps> {\r\n const widgets: AbstractWidgetProps[] = [];\r\n\r\n if (0 === UiItemsManager._registeredUiItemsProviders.size)\r\n return widgets;\r\n\r\n UiItemsManager._registeredUiItemsProviders.forEach((entry: UiItemProviderEntry) => {\r\n const uiProvider = entry.provider;\r\n const providerId = entry.overrides?.providerId ?? uiProvider.id;\r\n\r\n // istanbul ignore else\r\n if (uiProvider.provideWidgets && this.allowItemsFromProvider(entry, stageId, stageUsage)) {\r\n uiProvider.provideWidgets(stageId, stageUsage, location, section, zoneLocation, stageAppData)\r\n .forEach((widget: AbstractWidgetProps) => {\r\n // ignore duplicate ids\r\n if (-1 === widgets.findIndex((existingItem)=> widget.id === existingItem.id ))\r\n widgets.push({ ...widget, providerId });\r\n });\r\n }\r\n });\r\n return widgets;\r\n }\r\n\r\n}\r\n"]}
@@ -1,28 +1,28 @@
1
- /** @packageDocumentation
2
- * @module UiItemsProvider
3
- */
4
- import { BackstageItem } from "./backstage/BackstageItem";
5
- import { CommonStatusBarItem } from "./statusbar/StatusBarItem";
6
- import { CommonToolbarItem, ToolbarOrientation, ToolbarUsage } from "./toolbars/ToolbarItem";
7
- import { AbstractWidgetProps } from "./widget/AbstractWidgetProps";
8
- import { AbstractZoneLocation, StagePanelLocation, StagePanelSection } from "./widget/StagePanel";
9
- /** Describes interface of objects that want to provide UI component to the running IModelApp.
10
- * @public
11
- */
12
- export interface UiItemsProvider {
13
- /** id of provider */
14
- readonly id: string;
15
- /** UiItemsManager calls following method to get items to populate specific toolbars */
16
- provideToolbarButtonItems?: (stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage, toolbarOrientation: ToolbarOrientation, stageAppData?: any) => CommonToolbarItem[];
17
- /** UiItemsManager calls following method to augment base statusbar for stages that allow it. */
18
- provideStatusBarItems?: (stageId: string, stageUsage: string, stageAppData?: any) => CommonStatusBarItem[];
19
- /** UiItemsManager calls following method to augment backstage items. */
20
- provideBackstageItems?: () => BackstageItem[];
21
- /** UiItemsManager calls following method to augment Widget lists.
22
- * @note Returned widgets must provide unique `AbstractWidgetProps["id"]` to correctly save/restore App layout.
23
- */
24
- provideWidgets?: (stageId: string, stageUsage: string, location: StagePanelLocation, section?: StagePanelSection, zoneLocation?: AbstractZoneLocation, stageAppData?: any) => ReadonlyArray<AbstractWidgetProps>;
25
- /** Function called when the provider is unregistered via `ItemsManager.unregister` to allow provider to do cleanup. */
26
- onUnregister?: () => void;
27
- }
1
+ /** @packageDocumentation
2
+ * @module UiItemsProvider
3
+ */
4
+ import { BackstageItem } from "./backstage/BackstageItem";
5
+ import { CommonStatusBarItem } from "./statusbar/StatusBarItem";
6
+ import { CommonToolbarItem, ToolbarOrientation, ToolbarUsage } from "./toolbars/ToolbarItem";
7
+ import { AbstractWidgetProps } from "./widget/AbstractWidgetProps";
8
+ import { AbstractZoneLocation, StagePanelLocation, StagePanelSection } from "./widget/StagePanel";
9
+ /** Describes interface of objects that want to provide UI component to the running IModelApp.
10
+ * @public
11
+ */
12
+ export interface UiItemsProvider {
13
+ /** id of provider */
14
+ readonly id: string;
15
+ /** UiItemsManager calls following method to get items to populate specific toolbars */
16
+ provideToolbarButtonItems?: (stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage, toolbarOrientation: ToolbarOrientation, stageAppData?: any) => CommonToolbarItem[];
17
+ /** UiItemsManager calls following method to augment base statusbar for stages that allow it. */
18
+ provideStatusBarItems?: (stageId: string, stageUsage: string, stageAppData?: any) => CommonStatusBarItem[];
19
+ /** UiItemsManager calls following method to augment backstage items. */
20
+ provideBackstageItems?: () => BackstageItem[];
21
+ /** UiItemsManager calls following method to augment Widget lists.
22
+ * @note Returned widgets must provide unique `AbstractWidgetProps["id"]` to correctly save/restore App layout.
23
+ */
24
+ provideWidgets?: (stageId: string, stageUsage: string, location: StagePanelLocation, section?: StagePanelSection, zoneLocation?: AbstractZoneLocation, stageAppData?: any) => ReadonlyArray<AbstractWidgetProps>;
25
+ /** Function called when the provider is unregistered via `ItemsManager.unregister` to allow provider to do cleanup. */
26
+ onUnregister?: () => void;
27
+ }
28
28
  //# sourceMappingURL=UiItemsProvider.d.ts.map
@@ -1,11 +1,11 @@
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
- /* eslint-disable deprecation/deprecation */
7
- /** @packageDocumentation
8
- * @module UiItemsProvider
9
- */
10
- Object.defineProperty(exports, "__esModule", { value: true });
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
+ /* eslint-disable deprecation/deprecation */
7
+ /** @packageDocumentation
8
+ * @module UiItemsProvider
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
11
  //# sourceMappingURL=UiItemsProvider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"UiItemsProvider.js","sourceRoot":"","sources":["../../../src/appui-abstract/UiItemsProvider.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F,4CAA4C;AAC5C;;GAEG","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/* eslint-disable deprecation/deprecation */\n/** @packageDocumentation\n * @module UiItemsProvider\n */\n\nimport { BackstageItem } from \"./backstage/BackstageItem\";\nimport { CommonStatusBarItem } from \"./statusbar/StatusBarItem\";\nimport { CommonToolbarItem, ToolbarOrientation, ToolbarUsage } from \"./toolbars/ToolbarItem\";\nimport { AbstractWidgetProps } from \"./widget/AbstractWidgetProps\";\nimport { AbstractZoneLocation, StagePanelLocation, StagePanelSection } from \"./widget/StagePanel\";\n\n/** Describes interface of objects that want to provide UI component to the running IModelApp.\n * @public\n */\nexport interface UiItemsProvider {\n /** id of provider */\n readonly id: string;\n\n /** UiItemsManager calls following method to get items to populate specific toolbars */\n provideToolbarButtonItems?: (stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage, toolbarOrientation: ToolbarOrientation, stageAppData?: any) => CommonToolbarItem[];\n /** UiItemsManager calls following method to augment base statusbar for stages that allow it. */\n provideStatusBarItems?: (stageId: string, stageUsage: string, stageAppData?: any) => CommonStatusBarItem[];\n /** UiItemsManager calls following method to augment backstage items. */\n provideBackstageItems?: () => BackstageItem[];\n /** UiItemsManager calls following method to augment Widget lists.\n * @note Returned widgets must provide unique `AbstractWidgetProps[\"id\"]` to correctly save/restore App layout.\n */\n provideWidgets?: (stageId: string, stageUsage: string, location: StagePanelLocation, section?: StagePanelSection,\n zoneLocation?: AbstractZoneLocation, stageAppData?: any) => ReadonlyArray<AbstractWidgetProps>;\n /** Function called when the provider is unregistered via `ItemsManager.unregister` to allow provider to do cleanup. */\n onUnregister?: () => void;\n}\n"]}
1
+ {"version":3,"file":"UiItemsProvider.js","sourceRoot":"","sources":["../../../src/appui-abstract/UiItemsProvider.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F,4CAA4C;AAC5C;;GAEG","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/* eslint-disable deprecation/deprecation */\r\n/** @packageDocumentation\r\n * @module UiItemsProvider\r\n */\r\n\r\nimport { BackstageItem } from \"./backstage/BackstageItem\";\r\nimport { CommonStatusBarItem } from \"./statusbar/StatusBarItem\";\r\nimport { CommonToolbarItem, ToolbarOrientation, ToolbarUsage } from \"./toolbars/ToolbarItem\";\r\nimport { AbstractWidgetProps } from \"./widget/AbstractWidgetProps\";\r\nimport { AbstractZoneLocation, StagePanelLocation, StagePanelSection } from \"./widget/StagePanel\";\r\n\r\n/** Describes interface of objects that want to provide UI component to the running IModelApp.\r\n * @public\r\n */\r\nexport interface UiItemsProvider {\r\n /** id of provider */\r\n readonly id: string;\r\n\r\n /** UiItemsManager calls following method to get items to populate specific toolbars */\r\n provideToolbarButtonItems?: (stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage, toolbarOrientation: ToolbarOrientation, stageAppData?: any) => CommonToolbarItem[];\r\n /** UiItemsManager calls following method to augment base statusbar for stages that allow it. */\r\n provideStatusBarItems?: (stageId: string, stageUsage: string, stageAppData?: any) => CommonStatusBarItem[];\r\n /** UiItemsManager calls following method to augment backstage items. */\r\n provideBackstageItems?: () => BackstageItem[];\r\n /** UiItemsManager calls following method to augment Widget lists.\r\n * @note Returned widgets must provide unique `AbstractWidgetProps[\"id\"]` to correctly save/restore App layout.\r\n */\r\n provideWidgets?: (stageId: string, stageUsage: string, location: StagePanelLocation, section?: StagePanelSection,\r\n zoneLocation?: AbstractZoneLocation, stageAppData?: any) => ReadonlyArray<AbstractWidgetProps>;\r\n /** Function called when the provider is unregistered via `ItemsManager.unregister` to allow provider to do cleanup. */\r\n onUnregister?: () => void;\r\n}\r\n"]}
@@ -1,84 +1,84 @@
1
- /** @packageDocumentation
2
- * @module Backstage
3
- */
4
- import { BadgeType } from "../items/BadgeType";
5
- import { ConditionalBooleanValue } from "../items/ConditionalBooleanValue";
6
- import { ConditionalStringValue } from "../items/ConditionalStringValue";
7
- import { ProvidedItem } from "../items/ProvidedItem";
8
- /** Used to specify the item type added to the backstage menu.
9
- * @public
10
- */
11
- export declare enum BackstageItemType {
12
- /** Item that executes an action function */
13
- ActionItem = 1,
14
- /** Item that activate a stage. */
15
- StageLauncher = 2
16
- }
17
- /** Describes the data needed to insert a button into the backstage menu.
18
- * @public
19
- */
20
- export interface CommonBackstageItem extends ProvidedItem {
21
- /** can be used by application to store miscellaneous data. */
22
- applicationData?: any;
23
- /** Describes badge. Renders no badge if not specified. */
24
- readonly badgeType?: BadgeType;
25
- /** Specifies the item's grouping value. Items are sorted by group and then item priority. When
26
- * group priority changes a separator is inserted. It is recommended using values 10 through 100, incrementing by 10. This
27
- * allows extensions enough gaps to insert their own groups.
28
- */
29
- readonly groupPriority: number;
30
- /** Name of icon WebFont entry or if specifying an imported SVG symbol use "webSvg:" prefix to imported symbol Id. */
31
- readonly icon?: string | ConditionalStringValue;
32
- /** Required unique id of the item. To ensure uniqueness it is suggested that a namespace prefix of the extension name be used. */
33
- readonly id: string;
34
- /** optional data to be used by item implementor. */
35
- readonly internalData?: Map<string, any>;
36
- /** Describes if the item is visible or hidden. The default is for the item to be visible. */
37
- readonly isHidden?: boolean | ConditionalBooleanValue;
38
- /** Describes if the item is enabled or disabled. The default is for the item to be enabled. */
39
- readonly isDisabled?: boolean | ConditionalBooleanValue;
40
- /** Priority within a group (recommend using values 1 through 100). */
41
- readonly itemPriority: number;
42
- /** Label. */
43
- readonly label: string | ConditionalStringValue;
44
- /** Subtitle. */
45
- readonly subtitle?: string | ConditionalStringValue;
46
- /** Tooltip. */
47
- readonly tooltip?: string | ConditionalStringValue;
48
- /** Describes if the item is active. The default is for the item to be active if stageId matches activeFrontstageId */
49
- readonly isActive?: boolean | ConditionalBooleanValue;
50
- }
51
- /** Describes the data needed to insert an action button into the backstage menu.
52
- * @public
53
- */
54
- export interface BackstageActionItem extends CommonBackstageItem {
55
- readonly execute: () => void;
56
- }
57
- /** Describes the data needed to insert an action button into the backstage menu.
58
- * @public
59
- */
60
- export interface BackstageStageLauncher extends CommonBackstageItem {
61
- readonly stageId: string;
62
- }
63
- /** Describes the data needed to insert a button into the backstage menu.
64
- * @public
65
- */
66
- export declare type BackstageItem = BackstageActionItem | BackstageStageLauncher;
67
- /** BackstageActionItem type guard.
68
- * @public
69
- */
70
- export declare const isActionItem: (item: BackstageItem) => item is BackstageActionItem;
71
- /** BackstageStageLauncher type guard.
72
- * @public
73
- */
74
- export declare const isStageLauncher: (item: BackstageItem) => item is BackstageStageLauncher;
75
- /** Utilities for creating and maintaining backstage items
76
- * @public
77
- */
78
- export declare class BackstageItemUtilities {
79
- /** Creates a stage launcher backstage item */
80
- static createStageLauncher: (frontstageId: string, groupPriority: number, itemPriority: number, label: string | ConditionalStringValue, subtitle?: string | ConditionalStringValue | undefined, icon?: string | ConditionalStringValue | undefined, overrides?: Partial<BackstageStageLauncher> | undefined) => BackstageStageLauncher;
81
- /** Creates an action backstage item */
82
- static createActionItem: (itemId: string, groupPriority: number, itemPriority: number, execute: () => void, label: string | ConditionalStringValue, subtitle?: string | ConditionalStringValue | undefined, icon?: string | ConditionalStringValue | undefined, overrides?: Partial<BackstageActionItem> | undefined) => BackstageActionItem;
83
- }
1
+ /** @packageDocumentation
2
+ * @module Backstage
3
+ */
4
+ import { BadgeType } from "../items/BadgeType";
5
+ import { ConditionalBooleanValue } from "../items/ConditionalBooleanValue";
6
+ import { ConditionalStringValue } from "../items/ConditionalStringValue";
7
+ import { ProvidedItem } from "../items/ProvidedItem";
8
+ /** Used to specify the item type added to the backstage menu.
9
+ * @public
10
+ */
11
+ export declare enum BackstageItemType {
12
+ /** Item that executes an action function */
13
+ ActionItem = 1,
14
+ /** Item that activate a stage. */
15
+ StageLauncher = 2
16
+ }
17
+ /** Describes the data needed to insert a button into the backstage menu.
18
+ * @public
19
+ */
20
+ export interface CommonBackstageItem extends ProvidedItem {
21
+ /** can be used by application to store miscellaneous data. */
22
+ applicationData?: any;
23
+ /** Describes badge. Renders no badge if not specified. */
24
+ readonly badgeType?: BadgeType;
25
+ /** Specifies the item's grouping value. Items are sorted by group and then item priority. When
26
+ * group priority changes a separator is inserted. It is recommended using values 10 through 100, incrementing by 10. This
27
+ * allows extensions enough gaps to insert their own groups.
28
+ */
29
+ readonly groupPriority: number;
30
+ /** Name of icon WebFont entry or if specifying an imported SVG symbol use "webSvg:" prefix to imported symbol Id. */
31
+ readonly icon?: string | ConditionalStringValue;
32
+ /** Required unique id of the item. To ensure uniqueness it is suggested that a namespace prefix of the extension name be used. */
33
+ readonly id: string;
34
+ /** optional data to be used by item implementor. */
35
+ readonly internalData?: Map<string, any>;
36
+ /** Describes if the item is visible or hidden. The default is for the item to be visible. */
37
+ readonly isHidden?: boolean | ConditionalBooleanValue;
38
+ /** Describes if the item is enabled or disabled. The default is for the item to be enabled. */
39
+ readonly isDisabled?: boolean | ConditionalBooleanValue;
40
+ /** Priority within a group (recommend using values 1 through 100). */
41
+ readonly itemPriority: number;
42
+ /** Label. */
43
+ readonly label: string | ConditionalStringValue;
44
+ /** Subtitle. */
45
+ readonly subtitle?: string | ConditionalStringValue;
46
+ /** Tooltip. */
47
+ readonly tooltip?: string | ConditionalStringValue;
48
+ /** Describes if the item is active. The default is for the item to be active if stageId matches activeFrontstageId */
49
+ readonly isActive?: boolean | ConditionalBooleanValue;
50
+ }
51
+ /** Describes the data needed to insert an action button into the backstage menu.
52
+ * @public
53
+ */
54
+ export interface BackstageActionItem extends CommonBackstageItem {
55
+ readonly execute: () => void;
56
+ }
57
+ /** Describes the data needed to insert an action button into the backstage menu.
58
+ * @public
59
+ */
60
+ export interface BackstageStageLauncher extends CommonBackstageItem {
61
+ readonly stageId: string;
62
+ }
63
+ /** Describes the data needed to insert a button into the backstage menu.
64
+ * @public
65
+ */
66
+ export declare type BackstageItem = BackstageActionItem | BackstageStageLauncher;
67
+ /** BackstageActionItem type guard.
68
+ * @public
69
+ */
70
+ export declare const isActionItem: (item: BackstageItem) => item is BackstageActionItem;
71
+ /** BackstageStageLauncher type guard.
72
+ * @public
73
+ */
74
+ export declare const isStageLauncher: (item: BackstageItem) => item is BackstageStageLauncher;
75
+ /** Utilities for creating and maintaining backstage items
76
+ * @public
77
+ */
78
+ export declare class BackstageItemUtilities {
79
+ /** Creates a stage launcher backstage item */
80
+ static createStageLauncher: (frontstageId: string, groupPriority: number, itemPriority: number, label: string | ConditionalStringValue, subtitle?: string | ConditionalStringValue | undefined, icon?: string | ConditionalStringValue | undefined, overrides?: Partial<BackstageStageLauncher> | undefined) => BackstageStageLauncher;
81
+ /** Creates an action backstage item */
82
+ static createActionItem: (itemId: string, groupPriority: number, itemPriority: number, execute: () => void, label: string | ConditionalStringValue, subtitle?: string | ConditionalStringValue | undefined, icon?: string | ConditionalStringValue | undefined, overrides?: Partial<BackstageActionItem> | undefined) => BackstageActionItem;
83
+ }
84
84
  //# sourceMappingURL=BackstageItem.d.ts.map
@@ -1,65 +1,65 @@
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
- /** @packageDocumentation
7
- * @module Backstage
8
- */
9
- Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.BackstageItemUtilities = exports.isStageLauncher = exports.isActionItem = exports.BackstageItemType = void 0;
11
- /** Used to specify the item type added to the backstage menu.
12
- * @public
13
- */
14
- var BackstageItemType;
15
- (function (BackstageItemType) {
16
- /** Item that executes an action function */
17
- BackstageItemType[BackstageItemType["ActionItem"] = 1] = "ActionItem";
18
- /** Item that activate a stage. */
19
- BackstageItemType[BackstageItemType["StageLauncher"] = 2] = "StageLauncher";
20
- })(BackstageItemType = exports.BackstageItemType || (exports.BackstageItemType = {}));
21
- /** BackstageActionItem type guard.
22
- * @public
23
- */
24
- const isActionItem = (item) => {
25
- return item.execute !== undefined;
26
- };
27
- exports.isActionItem = isActionItem;
28
- /** BackstageStageLauncher type guard.
29
- * @public
30
- */
31
- const isStageLauncher = (item) => {
32
- return item.stageId !== undefined;
33
- };
34
- exports.isStageLauncher = isStageLauncher;
35
- /** Utilities for creating and maintaining backstage items
36
- * @public
37
- */
38
- class BackstageItemUtilities {
39
- }
40
- exports.BackstageItemUtilities = BackstageItemUtilities;
41
- /** Creates a stage launcher backstage item */
42
- BackstageItemUtilities.createStageLauncher = (frontstageId, groupPriority, itemPriority, label, subtitle, icon, overrides) => ({
43
- groupPriority,
44
- icon,
45
- internalData: overrides === null || overrides === void 0 ? void 0 : overrides.internalData,
46
- id: frontstageId,
47
- itemPriority,
48
- label,
49
- stageId: frontstageId,
50
- subtitle,
51
- ...overrides,
52
- });
53
- /** Creates an action backstage item */
54
- BackstageItemUtilities.createActionItem = (itemId, groupPriority, itemPriority, execute, label, subtitle, icon, overrides) => ({
55
- execute,
56
- groupPriority,
57
- icon,
58
- internalData: overrides === null || overrides === void 0 ? void 0 : overrides.internalData,
59
- id: itemId,
60
- itemPriority,
61
- label,
62
- subtitle,
63
- ...overrides,
64
- });
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
+ /** @packageDocumentation
7
+ * @module Backstage
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.BackstageItemUtilities = exports.isStageLauncher = exports.isActionItem = exports.BackstageItemType = void 0;
11
+ /** Used to specify the item type added to the backstage menu.
12
+ * @public
13
+ */
14
+ var BackstageItemType;
15
+ (function (BackstageItemType) {
16
+ /** Item that executes an action function */
17
+ BackstageItemType[BackstageItemType["ActionItem"] = 1] = "ActionItem";
18
+ /** Item that activate a stage. */
19
+ BackstageItemType[BackstageItemType["StageLauncher"] = 2] = "StageLauncher";
20
+ })(BackstageItemType = exports.BackstageItemType || (exports.BackstageItemType = {}));
21
+ /** BackstageActionItem type guard.
22
+ * @public
23
+ */
24
+ const isActionItem = (item) => {
25
+ return item.execute !== undefined;
26
+ };
27
+ exports.isActionItem = isActionItem;
28
+ /** BackstageStageLauncher type guard.
29
+ * @public
30
+ */
31
+ const isStageLauncher = (item) => {
32
+ return item.stageId !== undefined;
33
+ };
34
+ exports.isStageLauncher = isStageLauncher;
35
+ /** Utilities for creating and maintaining backstage items
36
+ * @public
37
+ */
38
+ class BackstageItemUtilities {
39
+ }
40
+ exports.BackstageItemUtilities = BackstageItemUtilities;
41
+ /** Creates a stage launcher backstage item */
42
+ BackstageItemUtilities.createStageLauncher = (frontstageId, groupPriority, itemPriority, label, subtitle, icon, overrides) => ({
43
+ groupPriority,
44
+ icon,
45
+ internalData: overrides === null || overrides === void 0 ? void 0 : overrides.internalData,
46
+ id: frontstageId,
47
+ itemPriority,
48
+ label,
49
+ stageId: frontstageId,
50
+ subtitle,
51
+ ...overrides,
52
+ });
53
+ /** Creates an action backstage item */
54
+ BackstageItemUtilities.createActionItem = (itemId, groupPriority, itemPriority, execute, label, subtitle, icon, overrides) => ({
55
+ execute,
56
+ groupPriority,
57
+ icon,
58
+ internalData: overrides === null || overrides === void 0 ? void 0 : overrides.internalData,
59
+ id: itemId,
60
+ itemPriority,
61
+ label,
62
+ subtitle,
63
+ ...overrides,
64
+ });
65
65
  //# sourceMappingURL=BackstageItem.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"BackstageItem.js","sourceRoot":"","sources":["../../../../src/appui-abstract/backstage/BackstageItem.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F;;GAEG;;;AAOH;;GAEG;AACH,IAAY,iBAKX;AALD,WAAY,iBAAiB;IAC3B,4CAA4C;IAC5C,qEAAc,CAAA;IACd,kCAAkC;IAClC,2EAAiB,CAAA;AACnB,CAAC,EALW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAK5B;AAwDD;;GAEG;AACI,MAAM,YAAY,GAAG,CAAC,IAAmB,EAA+B,EAAE;IAC/E,OAAQ,IAA4B,CAAC,OAAO,KAAK,SAAS,CAAC;AAC7D,CAAC,CAAC;AAFW,QAAA,YAAY,gBAEvB;AAEF;;GAEG;AACI,MAAM,eAAe,GAAG,CAAC,IAAmB,EAAkC,EAAE;IACrF,OAAQ,IAA+B,CAAC,OAAO,KAAK,SAAS,CAAC;AAChE,CAAC,CAAC;AAFW,QAAA,eAAe,mBAE1B;AAEF;;GAEG;AACH,MAAa,sBAAsB;;AAAnC,wDAgCC;AA/BC,8CAA8C;AAChC,0CAAmB,GAAG,CAClC,YAAoB,EAAE,aAAqB,EAAE,YAAoB,EAAE,KAAsC,EACzG,QAA0C,EAAE,IAAsC,EAAE,SAA2C,EACvG,EAAE,CAAC,CAAC;IAC5B,aAAa;IACb,IAAI;IACJ,YAAY,EAAE,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,YAAY;IACrC,EAAE,EAAE,YAAY;IAChB,YAAY;IACZ,KAAK;IACL,OAAO,EAAE,YAAY;IACrB,QAAQ;IACR,GAAG,SAAS;CACb,CAAC,CAAC;AAEH,uCAAuC;AACzB,uCAAgB,GAAG,CAC/B,MAAc,EAAE,aAAqB,EAAE,YAAoB,EAAE,OAAmB,EAAE,KAAsC,EACxH,QAA0C,EAAE,IAAsC,EAAE,SAAwC,EACvG,EAAE,CAAC,CAAC;IACzB,OAAO;IACP,aAAa;IACb,IAAI;IACJ,YAAY,EAAE,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,YAAY;IACrC,EAAE,EAAE,MAAM;IACV,YAAY;IACZ,KAAK;IACL,QAAQ;IACR,GAAG,SAAS;CACb,CAAC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Backstage\n */\n\nimport { BadgeType } from \"../items/BadgeType\";\nimport { ConditionalBooleanValue } from \"../items/ConditionalBooleanValue\";\nimport { ConditionalStringValue } from \"../items/ConditionalStringValue\";\nimport { ProvidedItem } from \"../items/ProvidedItem\";\n\n/** Used to specify the item type added to the backstage menu.\n * @public\n */\nexport enum BackstageItemType {\n /** Item that executes an action function */\n ActionItem = 1,\n /** Item that activate a stage. */\n StageLauncher = 2,\n}\n\n/** Describes the data needed to insert a button into the backstage menu.\n * @public\n */\nexport interface CommonBackstageItem extends ProvidedItem {\n /** can be used by application to store miscellaneous data. */\n applicationData?: any;\n /** Describes badge. Renders no badge if not specified. */\n readonly badgeType?: BadgeType;\n /** Specifies the item's grouping value. Items are sorted by group and then item priority. When\n * group priority changes a separator is inserted. It is recommended using values 10 through 100, incrementing by 10. This\n * allows extensions enough gaps to insert their own groups.\n */\n readonly groupPriority: number;\n /** Name of icon WebFont entry or if specifying an imported SVG symbol use \"webSvg:\" prefix to imported symbol Id. */\n readonly icon?: string | ConditionalStringValue;\n /** Required unique id of the item. To ensure uniqueness it is suggested that a namespace prefix of the extension name be used. */\n readonly id: string;\n /** optional data to be used by item implementor. */\n readonly internalData?: Map<string, any>;\n /** Describes if the item is visible or hidden. The default is for the item to be visible. */\n readonly isHidden?: boolean | ConditionalBooleanValue;\n /** Describes if the item is enabled or disabled. The default is for the item to be enabled. */\n readonly isDisabled?: boolean | ConditionalBooleanValue;\n /** Priority within a group (recommend using values 1 through 100). */\n readonly itemPriority: number;\n /** Label. */\n readonly label: string | ConditionalStringValue;\n /** Subtitle. */\n readonly subtitle?: string | ConditionalStringValue;\n /** Tooltip. */\n readonly tooltip?: string | ConditionalStringValue;\n /** Describes if the item is active. The default is for the item to be active if stageId matches activeFrontstageId */\n readonly isActive?: boolean | ConditionalBooleanValue;\n}\n\n/** Describes the data needed to insert an action button into the backstage menu.\n * @public\n */\nexport interface BackstageActionItem extends CommonBackstageItem {\n readonly execute: () => void;\n}\n\n/** Describes the data needed to insert an action button into the backstage menu.\n * @public\n */\nexport interface BackstageStageLauncher extends CommonBackstageItem {\n readonly stageId: string;\n}\n\n/** Describes the data needed to insert a button into the backstage menu.\n * @public\n */\nexport type BackstageItem = BackstageActionItem | BackstageStageLauncher;\n\n/** BackstageActionItem type guard.\n * @public\n */\nexport const isActionItem = (item: BackstageItem): item is BackstageActionItem => {\n return (item as BackstageActionItem).execute !== undefined;\n};\n\n/** BackstageStageLauncher type guard.\n * @public\n */\nexport const isStageLauncher = (item: BackstageItem): item is BackstageStageLauncher => {\n return (item as BackstageStageLauncher).stageId !== undefined;\n};\n\n/** Utilities for creating and maintaining backstage items\n * @public\n */\nexport class BackstageItemUtilities {\n /** Creates a stage launcher backstage item */\n public static createStageLauncher = (\n frontstageId: string, groupPriority: number, itemPriority: number, label: string | ConditionalStringValue,\n subtitle?: string | ConditionalStringValue, icon?: string | ConditionalStringValue, overrides?: Partial<BackstageStageLauncher>\n ): BackstageStageLauncher => ({\n groupPriority,\n icon,\n internalData: overrides?.internalData,\n id: frontstageId,\n itemPriority,\n label,\n stageId: frontstageId,\n subtitle,\n ...overrides,\n });\n\n /** Creates an action backstage item */\n public static createActionItem = (\n itemId: string, groupPriority: number, itemPriority: number, execute: () => void, label: string | ConditionalStringValue,\n subtitle?: string | ConditionalStringValue, icon?: string | ConditionalStringValue, overrides?: Partial<BackstageActionItem>\n ): BackstageActionItem => ({\n execute,\n groupPriority,\n icon,\n internalData: overrides?.internalData,\n id: itemId,\n itemPriority,\n label,\n subtitle,\n ...overrides,\n });\n}\n"]}
1
+ {"version":3,"file":"BackstageItem.js","sourceRoot":"","sources":["../../../../src/appui-abstract/backstage/BackstageItem.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F;;GAEG;;;AAOH;;GAEG;AACH,IAAY,iBAKX;AALD,WAAY,iBAAiB;IAC3B,4CAA4C;IAC5C,qEAAc,CAAA;IACd,kCAAkC;IAClC,2EAAiB,CAAA;AACnB,CAAC,EALW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAK5B;AAwDD;;GAEG;AACI,MAAM,YAAY,GAAG,CAAC,IAAmB,EAA+B,EAAE;IAC/E,OAAQ,IAA4B,CAAC,OAAO,KAAK,SAAS,CAAC;AAC7D,CAAC,CAAC;AAFW,QAAA,YAAY,gBAEvB;AAEF;;GAEG;AACI,MAAM,eAAe,GAAG,CAAC,IAAmB,EAAkC,EAAE;IACrF,OAAQ,IAA+B,CAAC,OAAO,KAAK,SAAS,CAAC;AAChE,CAAC,CAAC;AAFW,QAAA,eAAe,mBAE1B;AAEF;;GAEG;AACH,MAAa,sBAAsB;;AAAnC,wDAgCC;AA/BC,8CAA8C;AAChC,0CAAmB,GAAG,CAClC,YAAoB,EAAE,aAAqB,EAAE,YAAoB,EAAE,KAAsC,EACzG,QAA0C,EAAE,IAAsC,EAAE,SAA2C,EACvG,EAAE,CAAC,CAAC;IAC5B,aAAa;IACb,IAAI;IACJ,YAAY,EAAE,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,YAAY;IACrC,EAAE,EAAE,YAAY;IAChB,YAAY;IACZ,KAAK;IACL,OAAO,EAAE,YAAY;IACrB,QAAQ;IACR,GAAG,SAAS;CACb,CAAC,CAAC;AAEH,uCAAuC;AACzB,uCAAgB,GAAG,CAC/B,MAAc,EAAE,aAAqB,EAAE,YAAoB,EAAE,OAAmB,EAAE,KAAsC,EACxH,QAA0C,EAAE,IAAsC,EAAE,SAAwC,EACvG,EAAE,CAAC,CAAC;IACzB,OAAO;IACP,aAAa;IACb,IAAI;IACJ,YAAY,EAAE,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,YAAY;IACrC,EAAE,EAAE,MAAM;IACV,YAAY;IACZ,KAAK;IACL,QAAQ;IACR,GAAG,SAAS;CACb,CAAC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Backstage\r\n */\r\n\r\nimport { BadgeType } from \"../items/BadgeType\";\r\nimport { ConditionalBooleanValue } from \"../items/ConditionalBooleanValue\";\r\nimport { ConditionalStringValue } from \"../items/ConditionalStringValue\";\r\nimport { ProvidedItem } from \"../items/ProvidedItem\";\r\n\r\n/** Used to specify the item type added to the backstage menu.\r\n * @public\r\n */\r\nexport enum BackstageItemType {\r\n /** Item that executes an action function */\r\n ActionItem = 1,\r\n /** Item that activate a stage. */\r\n StageLauncher = 2,\r\n}\r\n\r\n/** Describes the data needed to insert a button into the backstage menu.\r\n * @public\r\n */\r\nexport interface CommonBackstageItem extends ProvidedItem {\r\n /** can be used by application to store miscellaneous data. */\r\n applicationData?: any;\r\n /** Describes badge. Renders no badge if not specified. */\r\n readonly badgeType?: BadgeType;\r\n /** Specifies the item's grouping value. Items are sorted by group and then item priority. When\r\n * group priority changes a separator is inserted. It is recommended using values 10 through 100, incrementing by 10. This\r\n * allows extensions enough gaps to insert their own groups.\r\n */\r\n readonly groupPriority: number;\r\n /** Name of icon WebFont entry or if specifying an imported SVG symbol use \"webSvg:\" prefix to imported symbol Id. */\r\n readonly icon?: string | ConditionalStringValue;\r\n /** Required unique id of the item. To ensure uniqueness it is suggested that a namespace prefix of the extension name be used. */\r\n readonly id: string;\r\n /** optional data to be used by item implementor. */\r\n readonly internalData?: Map<string, any>;\r\n /** Describes if the item is visible or hidden. The default is for the item to be visible. */\r\n readonly isHidden?: boolean | ConditionalBooleanValue;\r\n /** Describes if the item is enabled or disabled. The default is for the item to be enabled. */\r\n readonly isDisabled?: boolean | ConditionalBooleanValue;\r\n /** Priority within a group (recommend using values 1 through 100). */\r\n readonly itemPriority: number;\r\n /** Label. */\r\n readonly label: string | ConditionalStringValue;\r\n /** Subtitle. */\r\n readonly subtitle?: string | ConditionalStringValue;\r\n /** Tooltip. */\r\n readonly tooltip?: string | ConditionalStringValue;\r\n /** Describes if the item is active. The default is for the item to be active if stageId matches activeFrontstageId */\r\n readonly isActive?: boolean | ConditionalBooleanValue;\r\n}\r\n\r\n/** Describes the data needed to insert an action button into the backstage menu.\r\n * @public\r\n */\r\nexport interface BackstageActionItem extends CommonBackstageItem {\r\n readonly execute: () => void;\r\n}\r\n\r\n/** Describes the data needed to insert an action button into the backstage menu.\r\n * @public\r\n */\r\nexport interface BackstageStageLauncher extends CommonBackstageItem {\r\n readonly stageId: string;\r\n}\r\n\r\n/** Describes the data needed to insert a button into the backstage menu.\r\n * @public\r\n */\r\nexport type BackstageItem = BackstageActionItem | BackstageStageLauncher;\r\n\r\n/** BackstageActionItem type guard.\r\n * @public\r\n */\r\nexport const isActionItem = (item: BackstageItem): item is BackstageActionItem => {\r\n return (item as BackstageActionItem).execute !== undefined;\r\n};\r\n\r\n/** BackstageStageLauncher type guard.\r\n * @public\r\n */\r\nexport const isStageLauncher = (item: BackstageItem): item is BackstageStageLauncher => {\r\n return (item as BackstageStageLauncher).stageId !== undefined;\r\n};\r\n\r\n/** Utilities for creating and maintaining backstage items\r\n * @public\r\n */\r\nexport class BackstageItemUtilities {\r\n /** Creates a stage launcher backstage item */\r\n public static createStageLauncher = (\r\n frontstageId: string, groupPriority: number, itemPriority: number, label: string | ConditionalStringValue,\r\n subtitle?: string | ConditionalStringValue, icon?: string | ConditionalStringValue, overrides?: Partial<BackstageStageLauncher>\r\n ): BackstageStageLauncher => ({\r\n groupPriority,\r\n icon,\r\n internalData: overrides?.internalData,\r\n id: frontstageId,\r\n itemPriority,\r\n label,\r\n stageId: frontstageId,\r\n subtitle,\r\n ...overrides,\r\n });\r\n\r\n /** Creates an action backstage item */\r\n public static createActionItem = (\r\n itemId: string, groupPriority: number, itemPriority: number, execute: () => void, label: string | ConditionalStringValue,\r\n subtitle?: string | ConditionalStringValue, icon?: string | ConditionalStringValue, overrides?: Partial<BackstageActionItem>\r\n ): BackstageActionItem => ({\r\n execute,\r\n groupPriority,\r\n icon,\r\n internalData: overrides?.internalData,\r\n id: itemId,\r\n itemPriority,\r\n label,\r\n subtitle,\r\n ...overrides,\r\n });\r\n}\r\n"]}
@@ -1,39 +1,39 @@
1
- /** @packageDocumentation
2
- * @module Backstage
3
- */
4
- import { BeEvent } from "@itwin/core-bentley";
5
- import { BackstageItem } from "./BackstageItem";
6
- /** Arguments of [[BackstageItemsManager.onChanged]] event.
7
- * @internal
8
- */
9
- export interface BackstageItemsChangedArgs {
10
- readonly items: ReadonlyArray<BackstageItem>;
11
- }
12
- /**
13
- * Controls backstage items.
14
- * @internal
15
- */
16
- export declare class BackstageItemsManager {
17
- private _items;
18
- constructor(items?: ReadonlyArray<BackstageItem>);
19
- private loadItemsInternal;
20
- /** load items but do not fire onItemsChanged
21
- * @internal
22
- */
23
- loadItems(items: ReadonlyArray<BackstageItem>): void;
24
- /** Event raised when backstage items are changed.
25
- * @internal
26
- */
27
- readonly onItemsChanged: BeEvent<(args: BackstageItemsChangedArgs) => void>;
28
- get items(): ReadonlyArray<BackstageItem>;
29
- set items(items: ReadonlyArray<BackstageItem>);
30
- /** @internal */
31
- add(itemOrItems: BackstageItem | ReadonlyArray<BackstageItem>): void;
32
- /** @internal */
33
- remove(itemIdOrItemIds: BackstageItem["id"] | ReadonlyArray<BackstageItem["id"]>): void;
34
- /** @internal */
35
- static getSyncIdsOfInterest(items: readonly BackstageItem[]): string[];
36
- private internalRefreshAffectedItems;
37
- refreshAffectedItems(eventIds: Set<string>): void;
38
- }
1
+ /** @packageDocumentation
2
+ * @module Backstage
3
+ */
4
+ import { BeEvent } from "@itwin/core-bentley";
5
+ import { BackstageItem } from "./BackstageItem";
6
+ /** Arguments of [[BackstageItemsManager.onChanged]] event.
7
+ * @internal
8
+ */
9
+ export interface BackstageItemsChangedArgs {
10
+ readonly items: ReadonlyArray<BackstageItem>;
11
+ }
12
+ /**
13
+ * Controls backstage items.
14
+ * @internal
15
+ */
16
+ export declare class BackstageItemsManager {
17
+ private _items;
18
+ constructor(items?: ReadonlyArray<BackstageItem>);
19
+ private loadItemsInternal;
20
+ /** load items but do not fire onItemsChanged
21
+ * @internal
22
+ */
23
+ loadItems(items: ReadonlyArray<BackstageItem>): void;
24
+ /** Event raised when backstage items are changed.
25
+ * @internal
26
+ */
27
+ readonly onItemsChanged: BeEvent<(args: BackstageItemsChangedArgs) => void>;
28
+ get items(): ReadonlyArray<BackstageItem>;
29
+ set items(items: ReadonlyArray<BackstageItem>);
30
+ /** @internal */
31
+ add(itemOrItems: BackstageItem | ReadonlyArray<BackstageItem>): void;
32
+ /** @internal */
33
+ remove(itemIdOrItemIds: BackstageItem["id"] | ReadonlyArray<BackstageItem["id"]>): void;
34
+ /** @internal */
35
+ static getSyncIdsOfInterest(items: readonly BackstageItem[]): string[];
36
+ private internalRefreshAffectedItems;
37
+ refreshAffectedItems(eventIds: Set<string>): void;
38
+ }
39
39
  //# sourceMappingURL=BackstageItemsManager.d.ts.map