Codejock Forums Homepage
Forum Home Forum Home > Codejock Products > ActiveX COM > Command Bars
  New Posts New Posts RSS Feed - (SOLVED) MessageBar Colour & Xaml Events
  FAQ FAQ  Forum Search   Events   Register Register  Login Login

(SOLVED) MessageBar Colour & Xaml Events

 Post Reply Post Reply
Author
Message
Xander75 View Drop Down
Senior Member
Senior Member
Avatar

Joined: 26 April 2007
Status: Offline
Points: 353
Post Options Post Options   Thanks (0) Thanks(0)   Quote Xander75 Quote  Post ReplyReply Direct Link To This Post Topic: (SOLVED) MessageBar Colour & Xaml Events
    Posted: 06 October 2014 at 10:19am
Hi,

I have recently found a method that allows me to override the basic colour of the MessageBar and therefore do what I want colour wise.



As you can see the default Codejock AddButton method doesn't update with the colour, so I wrote my own xaml to do the same, so I get the following:



The xaml utilises the "MouseLeftButtonUp" event to call the "MessageBarEvent", which looks like "MouseLeftButtonUp='MessageBarEvent'".

Does anyone know of a way to get this event to fire? Any help is appreciated.

See below for the code I used to get the MessageBar to fully change its colour, which is in C#.Net but easily adaptable to VB6. I haven't copied the method "MessageBarEvent" as all this does is fire a message box if I can ever get it to work!!

I have tried using the Button xaml code and I still am met with being unable to fire the event from that also.
public void MessageBarDisplay(string message, string title, MessageBarType type = MessageBarType.Information)
{
    // Encode the < (less than) and > (greater than) symbols for the XAML below
    message = message.Replace("&", "&amp;");
    message = message.Replace("'", "&apos;");
    message = message.Replace("<", "&lt;");
    message = message.Replace(">", "&gt;");
    message = message.Replace("\"", "&quot;");

    // Variables used for the message layout
    int image = 0;
    string button = String.Empty;
    string colour = String.Empty;
    string imageSource = String.Empty;
    string textMessage = String.Empty;
    string textTitle = String.Empty;

    // Determine the passed MessageBarType and retrieve the correct details
    switch (type)
    {
        case MessageBarType.Error:
            colour = "#FFB6B8";
            image = ID.IMAGE_ERROR;
            break;

        case MessageBarType.Information:
            image = ID.IMAGE_INFORMATION;
            break;

        case MessageBarType.Success:
            colour = "#D4FFD6";
            image = ID.IMAGE_SUCCESS;
            break;

        case MessageBarType.Warning:
            colour = "#FFFFA8";
            image = ID.IMAGE_WARNING;
            break;
    }

    // Build the desired message layout using xaml
    if (colour != String.Empty)
        colour = "Background='" + colour + "' Height='32' Width='" + this.ClientSize.Width.ToString() + "'";

    if (image > 0)
        imageSource = "<Image Margin='5,0,0,0' Source='" + image + @"'/>";

    if (message != String.Empty)
        textMessage = "<TextBlock Padding='10, 0, 0, 0' VerticalAlignment='Center' Name='TextMessage'>" + message + @"</TextBlock>";

    if (title != String.Empty)
        textTitle = "<TextBlock Padding='3, 0, 0, 0' VerticalAlignment='Center' Name='TextTitle'><Bold>" + title + @":</Bold></TextBlock>";

    if (type == MessageBarType.Error)
    {
        button = @"<Page.Resources>
                        <Style TargetType='Border'>
                            <Setter Property='BorderThickness' Value='1' />
                            <Setter Property='Cursor' Value='Hand' />
                            <Style.Triggers>
                                <Trigger Property='IsMouseOver' Value='False'>
                                    <Trigger.Setters>
                                        <Setter Property='Background' Value='#FFB6B8' />
                                        <Setter Property='BorderBrush' Value='#728EAC' />
                                    </Trigger.Setters>
                                </Trigger>
                                <Trigger Property='IsMouseOver' Value='True'>
                                    <Trigger.Setters>
                                        <Setter Property='Background' Value='#FFE7A2' />
                                        <Setter Property='BorderBrush' Value='#FFBD69' />
                                    </Trigger.Setters>
                                </Trigger>
                            </Style.Triggers>
                        </Style>
                    </Page.Resources>

                    <Border Focusable='True' Height='24' HorizontalAlignment='Right' Margin='0, 0, 12, 0' MouseLeftButtonUp='MessageBarEvent' Width='100'>
                        <TextBlock Cursor='Hand' VerticalAlignment='Center' HorizontalAlignment='Center'>Send Screenshot</TextBlock>
                    </Border>";
    }
           
    // Add the layout to the MessageBar's Message area
    messageBar.Message = @" 
    <DockPanel " + colour + @" Margin='-4,0,-4,0'>
                " + imageSource + @"
                " + textTitle + @"
                " + textMessage + @"
                " + button + @"
    </DockPanel>";
           
    messageBar.Visible = true;
}



Product: Xtreme SuitePro (ActiveX) v15.3.1
Platform: Windows 7 64-bit (SP1) Professional Edition
Languages: C#.Net using Visual Studio 2012 & Visual Basic 6.0 (SP6)
Back to Top
Willowmaster View Drop Down
Senior Member
Senior Member
Avatar

Joined: 12 July 2010
Location: Netherlands
Status: Offline
Points: 180
Post Options Post Options   Thanks (0) Thanks(0)   Quote Willowmaster Quote  Post ReplyReply Direct Link To This Post Posted: 06 October 2014 at 11:32am
                    <Style.Triggers>
                       
<EventTrigger RoutedEvent="MouseEnter">
                           
<EventTrigger.Actions>
                               
<BeginStoryboard>
                                   
<Storyboard>
                                       
<DoubleAnimation Duration="0:0:0.300" Storyboard.TargetProperty="FontSize" To="28" />
                                   
</Storyboard>
                               
</BeginStoryboard>
                           
</EventTrigger.Actions>
                       
</EventTrigger>
This is XAML code found on the internet (http://www.wpf-tutorial.com/styles/trigger-datatrigger-event-trigger/). I'm not sure if this works with CodeJock.
Product: Xtreme SuitePro (ActiveX) version 15.3.1

Platform: Windows XP (32bit) - SP 3 (on VMWare)

Language: Visual Basic 6.0



Back to Top
Xander75 View Drop Down
Senior Member
Senior Member
Avatar

Joined: 26 April 2007
Status: Offline
Points: 353
Post Options Post Options   Thanks (0) Thanks(0)   Quote Xander75 Quote  Post ReplyReply Direct Link To This Post Posted: 07 October 2014 at 3:57am
@ Willowmaster,

Thanks for trying to help, but the Codejock Xaml does not work with the EventTrigger Cry

I'm thinking I will be unable to get this to work, good news is the colour works perfect but I would like to be able to use the buttons too.

Anyone from Codejock able to help?
Product: Xtreme SuitePro (ActiveX) v15.3.1
Platform: Windows 7 64-bit (SP1) Professional Edition
Languages: C#.Net using Visual Studio 2012 & Visual Basic 6.0 (SP6)
Back to Top
Willowmaster View Drop Down
Senior Member
Senior Member
Avatar

Joined: 12 July 2010
Location: Netherlands
Status: Offline
Points: 180
Post Options Post Options   Thanks (0) Thanks(0)   Quote Willowmaster Quote  Post ReplyReply Direct Link To This Post Posted: 07 October 2014 at 6:40am

Tried to generate a TextBox in code and add a handler but that doesn't work either. Could it be that you need to wrap it in an element that can receive events and that will route events to the TextBox element?

Product: Xtreme SuitePro (ActiveX) version 15.3.1

Platform: Windows XP (32bit) - SP 3 (on VMWare)

Language: Visual Basic 6.0



Back to Top
Willowmaster View Drop Down
Senior Member
Senior Member
Avatar

Joined: 12 July 2010
Location: Netherlands
Status: Offline
Points: 180
Post Options Post Options   Thanks (0) Thanks(0)   Quote Willowmaster Quote  Post ReplyReply Direct Link To This Post Posted: 07 October 2014 at 6:58am
You could add a hyperlink to the TextBox. Not ideal but it can be clicked.
Product: Xtreme SuitePro (ActiveX) version 15.3.1

Platform: Windows XP (32bit) - SP 3 (on VMWare)

Language: Visual Basic 6.0



Back to Top
Willowmaster View Drop Down
Senior Member
Senior Member
Avatar

Joined: 12 July 2010
Location: Netherlands
Status: Offline
Points: 180
Post Options Post Options   Thanks (0) Thanks(0)   Quote Willowmaster Quote  Post ReplyReply Direct Link To This Post Posted: 07 October 2014 at 7:04am
Think I'm on to something. To receive events you need to set the Form as a handler to the Markup control like this: MarkupLabel1.MarkupContext.SetHandler Me
Product: Xtreme SuitePro (ActiveX) version 15.3.1

Platform: Windows XP (32bit) - SP 3 (on VMWare)

Language: Visual Basic 6.0



Back to Top
Xander75 View Drop Down
Senior Member
Senior Member
Avatar

Joined: 26 April 2007
Status: Offline
Points: 353
Post Options Post Options   Thanks (0) Thanks(0)   Quote Xander75 Quote  Post ReplyReply Direct Link To This Post Posted: 07 October 2014 at 8:15am
Yeah I thought about that method as I had worked with the MarkupLabel in the past, but as this was the MessageBar it doesn't work the same way.

Is there a way to replace the MessageBar with the MarkupLabel? If that's doable then I would use the MarkupLabel instead, I have tried to do this but wasn't sure how to get this to replace the MessageBar.

PS. I have this built in an MDI application, which is why I am unsure as to how I would position the MarkupLabel between the CommandBars and Workspace.
Product: Xtreme SuitePro (ActiveX) v15.3.1
Platform: Windows 7 64-bit (SP1) Professional Edition
Languages: C#.Net using Visual Studio 2012 & Visual Basic 6.0 (SP6)
Back to Top
Xander75 View Drop Down
Senior Member
Senior Member
Avatar

Joined: 26 April 2007
Status: Offline
Points: 353
Post Options Post Options   Thanks (0) Thanks(0)   Quote Xander75 Quote  Post ReplyReply Direct Link To This Post Posted: 08 December 2014 at 8:13am
@ Willowmaster and anyone else...

As you had suggested and I had originally thought about, I ended up doing this with the MarkupLabel. The code is pretty much the same as above, the only difference now is that I also add the xaml code into the MarkupLabel then reposition the MarkupLabel to sit over the top of the MessageBar.

I did however have to use the following code to get the MarkupLabel to accept the click event...

using System.Runtime.InteropServices;

// ComVisible & ClassInterface required for the MarkupLabel for detecting click events
[ComVisible(true), ClassInterface(ClassInterfaceType.AutoDispatch)]
public partial class frmMain : Form
{

    // This is the MarkupLabel's Close button event, which is referenced in the MessageBar class
    [ComVisible(true)]
    public void CloseEvent(XtremeMarkup.MarkupObject Sender, XtremeMarkup.MarkupRoutedEventArgs Args)
    {
        MessageBar.Clear();
    }

    private void CreateMessageBar()
    {
        messageBar = CommandBars.MessageBar;
        CommandBars.GlobalSettings.Icons.AddIcons(ImageManager.Icons);

        // Required to bind the MarkupLabel "messageBarLabel" to the Form to accept click events
        messageBarLabel.MarkupContext.SetHandler(this);
        messageBarLabel.Icons = (XtremeMarkup.ImageManagerIcons)ImageManager.Icons;

        MessageBar.messageBar = messageBar;
        MessageBar.parent = this;
    }

}



Product: Xtreme SuitePro (ActiveX) v15.3.1
Platform: Windows 7 64-bit (SP1) Professional Edition
Languages: C#.Net using Visual Studio 2012 & Visual Basic 6.0 (SP6)
Back to Top
Willowmaster View Drop Down
Senior Member
Senior Member
Avatar

Joined: 12 July 2010
Location: Netherlands
Status: Offline
Points: 180
Post Options Post Options   Thanks (0) Thanks(0)   Quote Willowmaster Quote  Post ReplyReply Direct Link To This Post Posted: 15 December 2014 at 7:14am
Thanks for posting your solution!
Product: Xtreme SuitePro (ActiveX) version 15.3.1

Platform: Windows XP (32bit) - SP 3 (on VMWare)

Language: Visual Basic 6.0



Back to Top
 Post Reply Post Reply
  Share Topic   

Forum Jump Forum Permissions View Drop Down

Forum Software by Web Wiz Forums® version 12.04
Copyright ©2001-2021 Web Wiz Ltd.

This page was generated in 0.188 seconds.