Learning > ui > abstract > Ui Items Provider Edit this page UiItemsProvider The UiItemsProvider classes and interfaces are used for specifying UI items to be provided at runtime. Items provided at runtime may be inserted into a Toolbar, StatusBar or Backstage. Widgets may also be provided at runtime. UiItemsProvider Interface Below is an excerpt from the UiItemsProvider interface that shows the primary methods that an application or extension would want to implement to add items to different areas of the User Interface. export interface UiItemsProvider { readonly id: string; provideToolbarButtonItems?: (stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage, toolbarOrientation: ToolbarOrientation) => CommonToolbarItem[]; provideStatusBarItems?: (stageId: string, stageUsage: string) => CommonStatusBarItem[]; provideBackstageItems?: () => BackstageItem[]; provideWidgets?: (stageId: string, stageUsage: string, location: StagePanelLocation, section?: StagePanelSection) => ReadonlyArray<AbstractWidgetProps>; } UiItemsProvider Example The code excerpt below is an example taken from imodeljs\test-apps\ui-test-app that shows a class that implements the UiItemsProvider interface. class TestUiProvider implements UiItemsProvider { public readonly id = "TestUiProvider"; public provideToolbarButtonItems(_stageId: string, stageUsage: string, toolbarUsage: ToolbarUsage, toolbarOrientation: ToolbarOrientation): CommonToolbarItem[] { if (stageUsage === StageUsage.General && toolbarUsage === ToolbarUsage.ContentManipulation && toolbarOrientation === ToolbarOrientation.Horizontal) { const simpleActionSpec = ToolbarItemUtilities.createActionButton("simple-test-action-tool", 200, "icon-developer", "simple-test-action-tool", (): void => { console.log("Got Here!"); }); const isHiddenCondition = new ConditionalBooleanValue((): boolean => SampleAppIModelApp.getTestProperty() === "HIDE", [SampleAppUiActionId.setTestProperty]); const childActionSpec = ToolbarItemUtilities.createActionButton("child-test-action-tool", 210, "icon-developer", "child-test-action-tool", (): void => { console.log("Got Here!"); }, { isHidden: isHiddenCondition }); const nestedActionSpec = ToolbarItemUtilities.createActionButton("nested-test-action-tool", 220, "icon-developer", "test action tool (nested)", (): void => { console.log("Got Here!"); }); const groupSpec = ToolbarItemUtilities.createGroupButton("test-tool-group", 230, "icon-developer", "test group", [childActionSpec, simpleActionSpec], { badgeType: BadgeType.TechnicalPreview, parentToolGroupId: "tool-formatting-setting" }); return [simpleActionSpec, nestedActionSpec, groupSpec]; } return []; } public provideStatusBarItems(_stageId: string, stageUsage: string): CommonStatusBarItem[] { const statusBarItems: CommonStatusBarItem[] = []; const ShadowToggle = withStatusFieldProps(ShadowField); if (stageUsage === StageUsage.General) { statusBarItems.push( AbstractStatusBarItemUtilities.createActionItem("PluginTest:StatusBarItem1", StatusBarSection.Center, 100, "icon-developer", "test status bar from plugin", () => { console.log("Got Here!"); })); const isHidden = new ConditionalBooleanValue(() => !SampleExtensionStateManager.isExtensionUiVisible, [SampleExtensionStateManager.SET_EXTENSION_UI_VISIBLE]); const statusBarItem = AbstractStatusBarItemUtilities.createLabelItem("PluginTest:StatusBarLabel1", StatusBarSection.Center, 100, "icon-hand-2", "Hello", undefined, { isHidden }); statusBarItems.push(statusBarItem); const labelCondition = new ConditionalStringValue(() => SampleExtensionStateManager.isExtensionUiVisible ? "Click to Hide" : "Click to Show", [SampleExtensionStateManager.SET_EXTENSION_UI_VISIBLE]); const iconCondition = new ConditionalStringValue(() => SampleExtensionStateManager.isExtensionUiVisible ? "icon-visibility-hide-2" : "icon-visibility", [SampleExtensionStateManager.SET_EXTENSION_UI_VISIBLE]); statusBarItems.push( AbstractStatusBarItemUtilities.createActionItem("PluginTest:StatusBarItem2", StatusBarSection.Center, 110, iconCondition, labelCondition, () => { SampleExtensionStateManager.isExtensionUiVisible = !SampleExtensionStateManager.isExtensionUiVisible; })); // add entry that supplies react component statusBarItems.push(StatusBarItemUtilities.createStatusBarItem("ShadowToggle", StatusBarSection.Right, 5, <ShadowToggle />)); } return statusBarItems; } public provideWidgets(stageId: string, _stageUsage: string, location: StagePanelLocation, _section?: StagePanelSection | undefined): ReadonlyArray<AbstractWidgetProps> { const widgets: AbstractWidgetProps[] = []; if (stageId === "ViewsFrontstage" && location === StagePanelLocation.Right) { widgets.push({ id: "addonWidget", getWidgetContent: () => <FillCentered>Addon Widget in panel</FillCentered>, }); } return widgets; } } UiItemsManager Class The UiItemsManager class has a few responsibilities, Used to register UiItemsProviders Informs listeners that the list of registered UiItemsProviders has changed when a provider is registered or unregistered. Provides a set of methods to retrieve item definitions from all registered UiItemProviders. Below is an example of registering the TestUiProvider defined above. UiItemsManager.register( new TestUiProvider()); UiItemsArbiter The UiItemsArbiter class is used by the application to arbitrate or negotiate between the application and a UiItemsProvider. The application can either allow, disallow or update provided items from a UiItemsProvider. These actions are defined by UiItemsApplicationAction. The application implements the UiItemsApplication and provides one or more of the following optional functions to validate items: validateToolbarButtonItem - Validate and optionally update a Toolbar button item validateStatusBarItem - Validate and optionally update a StatusBar item validateBackstageItem - Validate and optionally update a Backstage item validateWidget - Validate and optionally update a Widget To setup for arbitration, the application sets the UiItemsArbiter.uiItemsApplication member, which may only be set once: UiItemsArbiter.uiItemsApplication = new ExampleUiItemsApplication(); A UiItemsProvider can listen for the actions taken by the application by defining the following optional methods: onToolbarButtonItemArbiterChange - Called if the application changes the Toolbar button item onStatusBarItemArbiterChange - Called if the application changes the StatusBar item onBackstageItemArbiterChange - Called if the application changes the Backstage item onWidgetArbiterChange - Called if the application changes the Widget Examples The following examples show how an application can allow, disallow and update a Toolbar item. Allowing a Toolbar Item class ExampleUiItemsApplication implements UiItemsApplication { public validateToolbarButtonItem(item: CommonToolbarItem): { updatedItem: CommonToolbarItem, action: UiItemsApplicationAction } { return { updatedItem: item, action: UiItemsApplicationAction.Allow }; } } Disallowing a Toolbar Item class ExampleUiItemsApplication implements UiItemsApplication { public validateToolbarButtonItem(item: CommonToolbarItem): { updatedItem: CommonToolbarItem, action: UiItemsApplicationAction } { let action = UiItemsApplicationAction.Allow; if (item.id === "test2") action = UiItemsApplicationAction.Disallow; return { updatedItem: item, action }; } } Updating a Toolbar Item class ExampleUiItemsApplication implements UiItemsApplication { public validateToolbarButtonItem(item: CommonToolbarItem): { updatedItem: CommonToolbarItem, action: UiItemsApplicationAction } { let action = UiItemsApplicationAction.Allow; let updatedItem = item; if (item.id === "test2") { action = UiItemsApplicationAction.Update; updatedItem = { ...item, itemPriority: 1000 }; } return { updatedItem, action }; } } API Reference UiItemsProvider Last Updated: 12 June, 2024