Contextualtabs - harborsiem/WinForms-Ribbon GitHub Wiki

ContextualTabs

Support for Contextual Tabs. The result of this post is a yet another sample, “14-ContextualTabs”, found on the project site.

ContextualTabs

What are contextual tabs? Contextual tabs are additional tabs that appear when you enable their context. For example, in word, when you select a table in your document, you get two additional tabs (Design and Layout) with commands relevant only to tables.

The basic working unit is a TabGroup, which is a group of contextual tabs with the same context. A TabGroup has a property named ContextAvailable (Property Identifier: UI_PKEY_ContextAvailable) which can have the following values:

  • Active – context is currently available and the tab group should be active (= “selected”)

  • Available – context is currently available (tabs are not necessarily active).

  • NotAvailable – context is currently not available.

More details on this subject can be found at Displaying Contextual Tabs on MSDN.

Using ContextualTabs – Ribbon Markup Following is the views section for defining contextual tabs. The commands section is straightforward.

<Application.Views>
  <Ribbon>
    <Ribbon.ContextualTabs>
      <TabGroup CommandName=‘cmdTabGroupTableTools‘>
        <Tab CommandName=‘cmdTabDesign‘>
          <Group CommandName=‘cmdGroupDesign‘ SizeDefinition=‘ThreeButtons‘>
            <Button CommandName=‘cmdButtonDesign1‘ />
            <Button CommandName=‘cmdButtonDesign2‘ />
            <Button CommandName=‘cmdButtonDesign3‘ />
          </Group>
        </Tab>
        <Tab CommandName=‘cmdTabLayout‘>
          <Group CommandName=‘cmdGroupLayout‘ SizeDefinition=‘TwoButtons‘>
            <Button CommandName=‘cmdButtonLayout1‘ />
            <Button CommandName=‘cmdButtonLayout2‘ />
          </Group>
        </Tab>
      </TabGroup>
    </Ribbon.ContextualTabs>
    <Ribbon.Tabs>
      <Tab CommandName=‘cmdTabMain‘>
        <Group CommandName=‘cmdGroupMain‘ SizeDefinition=‘TwoButtons‘>
          <Button CommandName=‘cmdButtonSelect‘ />
          <Button CommandName=‘cmdButtonUnselect‘ />
        </Group>
      </Tab>
    </Ribbon.Tabs>
  </Ribbon>
</Application.Views>

Here we define a single TabGroup for “Table Tools”, with two contextual tabs, “Design” and “Layout”. Each tab has some buttons in it. In addition, we define in the main tab two buttons that we will use to set and unset the “Table Tools” context.

Using ContextualTabs – Code Behind Following is an example of setting the context for a TabGroup thus making it visible.

partial class RibbonItems
{
    public void Init()
    {
        ButtonSelect.Click += new EventHandler<EventArgs>(_buttonSelect_ExecuteEvent);
        ButtonUnselect.Click += new EventHandler<EventArgs>(_buttonUnselect_ExecuteEvent);
    }

    void _buttonSelect_ExecuteEvent(object sender, EventArgs e)
    {
        if (TabGroupTableTools.ContextAvailable != ContextAvailability.Active)
            TabGroupTableTools.ContextAvailable = ContextAvailability.Active;
    }

    void _buttonUnselect_ExecuteEvent(object sender, EventArgs e)
    {
        if (TabGroupTableTools.ContextAvailable != ContextAvailability.NotAvailable)
            TabGroupTableTools.ContextAvailable = ContextAvailability.NotAvailable;
    }
}

Here we just register to the ribbon buttons Click events and set the context of the TabGroup accordingly. Of course, in a real application you might use a more sophisticated logic for setting the context.

⚠️ **GitHub.com Fallback** ⚠️