Skip to content

Commands

Amit Shuster edited this page Jul 12, 2020 · 4 revisions

Context menu and Options menu

Power BI visuals have two menus: Context and Option.

Open the Options by clicking the icon (indicated by three dots) in the top-right corner of the visual. When open, you'll see options for that visual. image

Open the Context menu by right clicking on the data. When open, you'll see the commands available for the visual. image

Both menus can be extended for each visual by using command extensions. Add personalized actions available to your users that enhance your apps experience. To extend the menus, define and pass an extension object in settings object in embed configuration.

    var embedConfig = {
        ...
        settings: {
            extensions: [...]
        }
    };

In addition, both menus built-in commands display can be personalized. To control the built-in commands display option, define and pass a command object in embed configuration settings.

    var embedConfig = {
        ...
        settings: {
            commands: [...]
        }
    };

To learn more, see Embed Configuration Details.

Use the updateSettings method to update the added items when the report is loaded. To learn more, see Update Settings.

Menu commands extension

Extensions interfaces

    export type Extensions = IExtension[];
    
    export interface IExtension {
        command?: ICommandExtension;
    }
    
    export interface IExtensionItem {
        name: string;
        extend: IExtensionPoints;
    }
    
    export interface ICommandExtension extends IExtensionItem {
        title: string;
        icon?: string;
        selector?: CommandExtensionSelector;
    }
    
    export interface IExtensionPoints {
      visualContextMenu?: IMenuExtension;
      visualOptionsMenu?: IMenuExtension;
    }
    
    export interface IExtensionPoint {
    }
    
    export interface IMenuExtension extends IExtensionPoint {
        title?: string;
        icon?: string;
        menuLocation?: MenuLocation;
    }

UML Diagram

image

How it works

  1. Define an Extensions array which contains the commands you want to include for report visuals. For each command, define:
  • Command name
  • Text
  • Icon
  • Extension points. These are points you want to attach the command to. Currently, two extension points are supported: visual context menu and visual options menu. You can decide to attach the command to just one or both. Each extension point can be customized with different text and icons.
    extensions: [
        
        {
            command: {
                name: "command name",
                title: "command title",
                icon: "...AAABJRU5ErkJggg==",
                extend:
                {
                    visualContextMenu: {
                        title: "context menu title",
                    },
                    visualOptionsMenu: {
                        title: "options menu title",
                    }
                }
            }
        }
        
    ]
  1. Pass the Extensions object in settings object in report load, as shown in the full code example below.

  2. When app end-users click a menu item added by the extension array, the commandTriggered event is raised.

  3. Listen on the commandTriggered event by using report.on and implement an event handler.

    report.on("commandTriggered", function(event) {
        // Handler code
    });

Full code example

    // Get models. models contains enums that can be used.
    var models = window['powerbi-client'].models;
    
    var embedConfiguration = {
        type: 'report',
        id: '5dac7a4a-4452-46b3-99f6-a25915e0fe55',
        embedUrl: 'https://app.powerbi.com/reportEmbed',
        tokenType: models.TokenType.Aad,
        accessToken: 'e4...rf',
        settings: {
            extensions: [
                {
                    command: {
                        name: "command name",
                        title: "command title",
                        icon: "...AAABJRU5ErkJggg==",
                        extend:
                        {
                            visualContextMenu: {
                                title: "context menu title",
                            },
                            visualOptionsMenu: {
                                title: "options menu title",
                            }
                        }
                    }
                }
            ]
        }
    };
     
    // Get a reference to the embedded report HTML element
    var embedContainer = document.getElementById('embedContainer');
     
    // Embed the report and display it within the div container.
    var report = powerbi.embed(embedContainer, embedConfiguration);
     
    // Report.on will add an event handler to commandTriggered event which prints to console window.
    report.on("commandTriggered", function(command) {
        console.log(command);
    });

Valid Base64 icon example

""

Controling the menu item location

You can now control the location of the menu command extension, by using the menuLocation property. The menu command extension can be placed at the top or at the bottom of the menu.

Note: When adding more than one command to the top of the menu, the last command added will be at the top.

image

For example, using the code below you can set the options menu command extension at the top of the menu, and the context menu command at the bottom of the menu (default).

extensions: [        
    {
        command: {
            name: "command name",
            title: "command title",
            icon: "...AAABJRU5ErkJggg==",
            extend:
            {
                visualContextMenu: {
                    title: "context menu title",
                    menuLocation: models.MenuLocation.Bottom
                },
                visualOptionsMenu: {
                    title: "options menu title",
                    menuLocation: models.MenuLocation.Top
                }
            }
        }
    }
]

Built-in commands

By using commands configuration in Power BI Embedded, you can control the display of the built-in commands, per visual.

For each built-in command you can choose between three display options:

  • Enabled - The command will appear if it is available for the visual.
  • Disabled - The command will appear if it is available for the visual, but, it will be grayed out (and the user will not be able to click the command).
  • Hidden - The command will not appear.
    commands: [
        {
            exportData: {
                displayOption: models.CommandDisplayOption.Enabled,
            },
            drill: {
                displayOption: models.CommandDisplayOption.Disabled,
            }
        }
    ]

Commands interfaces

    export type VisualCommandSelector = IVisualSelector | IVisualTypeSelector;

    export enum CommandDisplayOption {
      Enabled,
      Disabled,
      Hidden
    }
    
    export interface ICommandSettings {
      displayOption: CommandDisplayOption;
      selector?: VisualCommandSelector;
    }
    
    export interface ICommandsSettings {
      copy?: ICommandSettings;
      drill?: ICommandSettings;
      drillthrough?: ICommandSettings;
      expandCollapse?: ICommandSettings;
      exportData?: ICommandSettings;
      includeExclude?: ICommandSettings;
      removeVisual?: ICommandSettings;
      search?: ICommandSettings;
      seeData?: ICommandSettings;
      sort?: ICommandSettings;
      spotlight?: ICommandSettings;
    }

Selectors

Selectors are the way to indicate on which objects the settings are applicable. The selector is optional, and when it doesn't appear, it means the settings are applicable for all the visuals in the report. Both menu commands extensions and built-in commands display support selectors. You will find more details about selectors in this page.