multiple ribbons with the same ribbonID

N

Nikolas

Hi,

is it possible to have different Ribbons on an Outlook mail item depending
on their message class? I see that the Ribbon is loaded only once when a mail
item is loaded the first time. Whenever you load another mail item the ribbon
stays the same and it just invalidates the controls.

My aim is to have a custom group in different positions on the ribbon
depending on the message class of the mail item.

Thanks in advance
 
K

Ken Slovak - [MVP - Outlook]

The XML is loaded only once per each Inspector type (Mail.Compose,
Mail.Read, etc.).

Your choices probably boil down to creating a huge ribbon with everything
you want everywhere and making various controls visible and invisible
depending on the Inspector, or using one or more <dynamicMenu> setups where
the XML would be loaded each time and supplied on the fly.
 
N

Nikolas

Hi Ken,

Thanks for your suggestion (created two custom groups in the ribbon and I
toggle their visibility). Everything looked to work fine apart from an issue
with the refresh of the Ribbon. It looks like the Ribbon doesn't refresh
everytime a new inspector (of the same type (ex. Mail.Compose) is created and
displayed. I put a breakpoint in the callback functions that determine the
visibility of the buttons in the custom Ribbon groups (depending on the
Message Class of the Mail Item) and randomly ignores some calls. I tried
putting calls of the function InvalidateControl("MyRibbonGroupName") to the
function that creates the Inspector but this didnt solve my problem.

Any suggestions would appreciated.

Nikolas
 
K

Ken Slovak - [MVP - Outlook]

It's a matter of timing most likely. I've had to deal with two different
timing problems related to ribbons and Inspectors.

The first time an Inspector is instantiated for a ribbon the Ribbon_OnLoad
function hasn't fired yet. So any ribbon references aren't valid. What I do
is set up a dummy Office.IRibbonUI object at module level, knowing it's a
dummy that first time around and will be null (Nothing) until Ribbon_OnLoad
fires.

I have a module level Office.IRibbonUI object in each Inspector wrapper
class that is null for the first Inspector. After that the ribbon object is
valid and the class ribbon object is instantiated when I add the new
Inspector to my wrapper class collection.

In Ribbon_OnLoad I iterate the Inspectors wrapper class collection and
instantiate each ribbon object in each wrapper class.

To take care of the second problem I call the invalidate code in the
Inspector Activate event that fires within my Inspector wrapper class. I can
either call InvalidateControl or if I want everything to be refreshed I can
call Ribbon.Invalidate, which invalidates everything.

See if that helps.

It works in my addin templates for my book. I've used it so far with VB6,
VB.NET, C#, VSTO/VB.NET and VSTO/C# addin templates.
 
K

Ken Slovak - [MVP - Outlook]

Nothing is exposed to help you with this, unfortunately. One of the many
things that were ignored during the beta that we pleaded with MS to make
available.

What you have to do is create your own categorization code. You can use the
MessageClass or Class of an item to get a general handle on what type of
item it is. For "Microsoft.Outlook.Mail.Read" you can check for EntryID = ""
and that tells you it's a new item (before it is saved). If on opening it
has no EntryID it's a "Compose" mode item. If it has an EntryID it's a
"Read" mode item. You can further check for Re: or Fwd: in the subject and
for ConversationIndex and ConversationTopic to see if it's a forward or
reply or whatever.

If you check for MessageClass make sure to check for the start of the
MessageClass so you catch custom MessageClass items also.

From there you can also check for the existence of various ribbon tabs in
the existing item to help see what's what. For that of course you have to
make up a list of what's there for different types of open items. Of course
you can't assume that a tab isn't there just because it's not visible. For
example, in Mail.Read there's an Insert tab that's not visible until you use
Message tab, Other Actions, Edit Message when the Insert tab becomes
visible.

It's a bit of a mess actually.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Top