also, disable the call do BindColumns in
[mono.git] / mcs / class / Managed.Windows.Forms / System.Windows.Forms / NotifyIcon.cs
index ce274ec9fe4908a568e3c636a2201c13ed3d201d..7e0f7abd78da649ca3392dff82d56ca4a297e6bd 100644 (file)
@@ -33,10 +33,14 @@ using System.Drawing;
 
 namespace System.Windows.Forms {
        [DefaultProperty("Text")]
+#if NET_2_0
+       [DefaultEvent("MouseDoubleClick")]
+#else
        [DefaultEvent("MouseDown")]
-       [Designer ("System.Windows.Forms.Design.NotifyIconDesigner, " + Consts.AssemblySystem_Design, (string)null)]
+#endif
+       [Designer ("System.Windows.Forms.Design.NotifyIconDesigner, " + Consts.AssemblySystem_Design, "System.ComponentModel.Design.IDesigner")]
        [ToolboxItemFilter("System.Windows.Forms", ToolboxItemFilterType.Allow)]
-       public sealed class NotifyIcon : System.ComponentModel.Component {
+       public sealed class NotifyIcon : Component {
                #region Local Variables
                private ContextMenu             context_menu;
                private Icon                    icon;
@@ -49,7 +53,7 @@ namespace System.Windows.Forms {
                #endregion      // Local Variables
 
                #region NotifyIconWindow Class
-               internal class NotifyIconWindow : Control {
+               internal class NotifyIconWindow : Form {
                        NotifyIcon      owner;
                        Rectangle       rect;
 
@@ -58,9 +62,10 @@ namespace System.Windows.Forms {
                                is_visible = false;
                                rect = new Rectangle(0, 0, 1, 1);
 
-                               CreateControl();
+                               FormBorderStyle = FormBorderStyle.None;
+
+                               //CreateControl();
 
-                               Paint += new PaintEventHandler(HandlePaint);
                                SizeChanged += new EventHandler(HandleSizeChanged);
 
                                // Events that need to be sent to our parent
@@ -70,142 +75,140 @@ namespace System.Windows.Forms {
                                MouseUp +=new MouseEventHandler(HandleMouseUp);
                                MouseMove +=new MouseEventHandler(HandleMouseMove);
                                ContextMenu = owner.context_menu;
-                       }\r
-\r
-                       protected override CreateParams CreateParams {\r
-                               get {\r
-                                       CreateParams cp;\r
-\r
-                                       cp = base.CreateParams;\r
-\r
-                                       cp.Parent = IntPtr.Zero;\r
-                                       cp.Style = (int)WindowStyles.WS_POPUP;\r
-                                       cp.Style |= (int)WindowStyles.WS_CLIPSIBLINGS;\r
-\r
-                                       cp.ExStyle = (int)(WindowStyles.WS_EX_TOOLWINDOW);
-\r
-                                       return cp;\r
-                               }\r
-                       }\r
-\r
-                       protected override void WndProc(ref Message m) {\r
-                               switch((Msg)m.Msg) {\r
-                                       case Msg.WM_USER: {\r
-                                               switch ((Msg)m.LParam.ToInt32()) {\r
-                                                       case Msg.WM_LBUTTONDOWN: {\r
-                                                               HandleMouseDown(this, new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
-                                                               return;\r
-                                                       }\r
-\r
-                                                       case Msg.WM_LBUTTONUP: {\r
-                                                               HandleMouseUp(this, new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
-                                                               HandleClick(this, EventArgs.Empty);\r
-                                                               return;\r
-                                                       }\r
-\r
-                                                       case Msg.WM_LBUTTONDBLCLK: {\r
-                                                               HandleDoubleClick(this, EventArgs.Empty);\r
-                                                               return;\r
-                                                       }\r
-\r
-                                                       case Msg.WM_MOUSEMOVE: {\r
-                                                               HandleMouseMove(this, new MouseEventArgs(MouseButtons.None, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
-                                                               return;\r
-                                                       }\r
-\r
-                                                       case Msg.WM_RBUTTONDOWN: {\r
-                                                               HandleMouseDown(this, new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
-                                                               return;\r
-                                                       }\r
-\r
-                                                       case Msg.WM_RBUTTONUP: {\r
-                                                               HandleMouseUp(this, new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
-                                                               HandleClick(this, EventArgs.Empty);\r
-                                                               return;\r
-                                                       }\r
-\r
-                                                       case Msg.WM_RBUTTONDBLCLK: {\r
-                                                               HandleDoubleClick(this, EventArgs.Empty);\r
-                                                               return;\r
-                                                       }\r
-                                               }\r
-                                               return;\r
-                                       }\r
-                               }\r
-                               base.WndProc (ref m);\r
-                       }\r
-\r
-                       internal void CalculateIconRect() {\r
-                               if (owner != null && owner.icon != null) {\r
-                                       int             x;
-                                       int             y;
-                                       int             size;\r
-\r
-                                       // Icons are always square. Try to center them in the window\r
-                                       if (ClientRectangle.Width < ClientRectangle.Height) {\r
-                                               size = ClientRectangle.Width;\r
-                                       } else {\r
-                                               size = ClientRectangle.Height;\r
-                                       }\r
-                                       x = this.ClientRectangle.Width / 2 - size / 2;\r
-                                       y = this.ClientRectangle.Height / 2 - size / 2;\r
-                                       rect = new Rectangle(x, y, size, size);\r
-\r
-                                       // Force our window to be square\r
-                                       if (Width != size) {\r
-                                               this.Width = size;\r
-                                       }\r
-\r
-                                       if (Height != size) {\r
-                                               this.Height = size;\r
-                                       }\r
-                               }\r
-                       }\r
-\r
-                       private void HandlePaint(object sender, PaintEventArgs e) {\r
-                               if (owner.icon != null) {\r
-                                       e.Graphics.DrawImage(owner.icon_bitmap, rect);\r
-\r
-                               }\r
-                       }\r
-\r
-                       private void HandleSizeChanged(object sender, EventArgs e) {\r
-                               CalculateIconRect();\r
-                       }\r
-\r
-                       private void HandleClick(object sender, EventArgs e) {\r
-                               if (owner.Click != null) {\r
-                                       owner.Click(owner, e);\r
-                               }\r
-                       }\r
-\r
-                       private void HandleDoubleClick(object sender, EventArgs e) {\r
-                               if (owner.DoubleClick != null) {\r
-                                       owner.DoubleClick(owner, e);\r
-                               }\r
-                       }\r
-\r
-                       private void HandleMouseDown(object sender, MouseEventArgs e) {\r
-                               if (owner.MouseDown != null) {\r
-                                       owner.MouseDown(owner, e);\r
-                               }\r
-                       }\r
-
-                       private void HandleMouseUp(object sender, MouseEventArgs e) {\r
-                               if (owner.context_menu != null) {\r
-                                       owner.context_menu.Show(this, new Point(e.X, e.Y));\r
-                               }\r
-\r
-                               if (owner.MouseUp != null) {\r
-                                       owner.MouseUp(owner, e);\r
-                               }\r
-                       }\r
-\r
-                       private void HandleMouseMove(object sender, MouseEventArgs e) {\r
-                               if (owner.MouseMove != null) {\r
-                                       owner.MouseMove(owner, e);\r
-                               }\r
-                       }\r
+                       }
+
+                       protected override CreateParams CreateParams {
+                               get {
+                                       CreateParams cp;
+
+                                       cp = base.CreateParams;
+
+                                       cp.Parent = IntPtr.Zero;
+                                       cp.Style = (int)WindowStyles.WS_POPUP;
+                                       cp.Style |= (int)WindowStyles.WS_CLIPSIBLINGS;
+
+                                       cp.ExStyle = (int)(WindowExStyles.WS_EX_TOOLWINDOW);
+
+                                       return cp;
+                               }
+                       }
+
+                       protected override void WndProc(ref Message m) {
+                               switch((Msg)m.Msg) {
+                                               //
+                                               //  NotifyIcon does CONTEXTMENU on mouse up, not down
+                                               //  so we swallow the message here, and handle it on our own
+                                               // 
+                                       case Msg.WM_CONTEXTMENU:
+                                               return;
+
+                                       case Msg.WM_USER: {
+                                               switch ((Msg)m.LParam.ToInt32()) {
+                                                       case Msg.WM_LBUTTONDOWN: {
+                                                               owner.OnMouseDown (new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+                                                               return;
+                                                       }
+
+                                                       case Msg.WM_LBUTTONUP: {
+                                                               owner.OnMouseUp (new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+                                                               owner.OnClick (EventArgs.Empty);
+                                                               return;
+                                                       }
+
+                                                       case Msg.WM_LBUTTONDBLCLK: {
+                                                               owner.OnDoubleClick (EventArgs.Empty);
+                                                               return;
+                                                       }
+
+                                                       case Msg.WM_MOUSEMOVE: {
+                                                               owner.OnMouseMove (new MouseEventArgs(MouseButtons.None, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+                                                               return;
+                                                       }
+
+                                                       case Msg.WM_RBUTTONDOWN: {
+                                                               owner.OnMouseDown (new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+                                                               return;
+                                                       }
+
+                                                       case Msg.WM_RBUTTONUP: {
+                                                               owner.OnMouseUp (new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+                                                               owner.OnClick (EventArgs.Empty);
+                                                               return;
+                                                       }
+
+                                                       case Msg.WM_RBUTTONDBLCLK: {
+                                                               owner.OnDoubleClick (EventArgs.Empty);
+                                                               return;
+                                                       }
+                                               }
+                                               return;
+                                       }
+                               }
+                               base.WndProc (ref m);
+                       }
+
+                       internal void CalculateIconRect() {
+                               int             x;
+                               int             y;
+                               int             size;
+
+                               // Icons are always square. Try to center them in the window
+                               if (ClientRectangle.Width < ClientRectangle.Height) {
+                                       size = ClientRectangle.Width;
+                               } else {
+                                       size = ClientRectangle.Height;
+                               }
+                               x = this.ClientRectangle.Width / 2 - size / 2;
+                               y = this.ClientRectangle.Height / 2 - size / 2;
+                               rect = new Rectangle(x, y, size, size);
+
+                               Bounds = new Rectangle (0, 0, size, size);
+                       }
+
+                       internal override void OnPaintInternal (PaintEventArgs e) {
+                               if (owner.icon != null) {
+                                       e.Graphics.FillRectangle(ThemeEngine.Current.ResPool.GetSolidBrush(SystemColors.Window), rect);
+                                       e.Graphics.DrawImage(owner.icon_bitmap,
+                                                            rect,
+                                                            new Rectangle (0, 0, owner.icon_bitmap.Width, owner.icon_bitmap.Height),
+                                                            GraphicsUnit.Pixel);
+
+                               }
+                       }
+
+                       internal void InternalRecreateHandle () {
+                               base.RecreateHandle ();
+                       }
+
+
+                       private void HandleSizeChanged(object sender, EventArgs e) {
+                               owner.Recalculate ();
+                       }
+
+                       private void HandleClick (object sender, EventArgs e)
+                       {
+                               owner.OnClick (e);
+                       }
+
+                       private void HandleDoubleClick (object sender, EventArgs e)
+                       {
+                               owner.OnDoubleClick (e);
+                       }
+
+                       private void HandleMouseDown (object sender, MouseEventArgs e)
+                       {
+                               owner.OnMouseDown (e);
+                       }
+
+                       private void HandleMouseUp (object sender, MouseEventArgs e)
+                       {
+                               owner.OnMouseUp (e);
+                       }
+
+                       private void HandleMouseMove (object sender, MouseEventArgs e)
+                       {
+                               owner.OnMouseMove (e);
+                       }
                }
                #endregion      // NotifyIconWindow Class
 
@@ -220,27 +223,66 @@ namespace System.Windows.Forms {
                #endregion      // Public Constructors
 
                #region Private Methods
-               private void ShowSystray(bool property_changed) {
-                       if (property_changed) {
-                               window.CalculateIconRect();
-                       }
+               private void OnClick (EventArgs e)
+               {
+                       EventHandler eh = (EventHandler)(Events [ClickEvent]);
+                       if (eh != null)
+                               eh (this, e);
+               }
 
-                       if (systray_active) {
-                               if (property_changed) {
-                                       UpdateSystray();
-                               }
-                               return;
-                       }
+               private void OnDoubleClick (EventArgs e)
+               {
+                       EventHandler eh = (EventHandler)(Events [DoubleClickEvent]);
+                       if (eh != null)
+                               eh (this, e);
+               }
 
-                       if (icon != null) {
-                               icon_bitmap = icon.ToBitmap();
-                       }
+               private void OnMouseDown (MouseEventArgs e)
+               {
+                       MouseEventHandler eh = (MouseEventHandler)(Events [MouseDownEvent]);
+                       if (eh != null)
+                               eh (this, e);
+               }
+
+               private void OnMouseUp (MouseEventArgs e)
+               {
+                       if ((e.Button & MouseButtons.Right) == MouseButtons.Right && context_menu != null)
+                               context_menu.Show (window, new Point(e.X, e.Y));
+
+                       MouseEventHandler eh = (MouseEventHandler)(Events [MouseUpEvent]);
+                       if (eh != null)
+                               eh (this, e);
+               }
+
+               private void OnMouseMove (MouseEventArgs e)
+               {
+                       MouseEventHandler eh = (MouseEventHandler)(Events [MouseMoveEvent]);
+                       if (eh != null)
+                               eh (this, e);
+               }
+
+               private void Recalculate () 
+               {
+                       window.CalculateIconRect ();
+
+                       if (systray_active)
+                               UpdateSystray ();
+               }
 
+               private void ShowSystray()
+               {
                        systray_active = true;
+
+                       if (icon == null)
+                               return;
+
+                       icon_bitmap = icon.ToBitmap();
+
                        XplatUI.SystrayAdd(window.Handle, text, icon, out tooltip);
                }
 
-               private void HideSystray() {
+               private void HideSystray()
+               {
                        if (!systray_active) {
                                return;
                        }
@@ -249,7 +291,8 @@ namespace System.Windows.Forms {
                        XplatUI.SystrayRemove(window.Handle, ref tooltip);
                }
 
-               private void UpdateSystray() {
+               private void UpdateSystray()
+               {
                        if (icon_bitmap != null) {
                                icon_bitmap.Dispose();
                        }
@@ -265,6 +308,9 @@ namespace System.Windows.Forms {
 
                #region Public Instance Properties
                [DefaultValue(null)]
+#if NET_2_0
+               [Browsable (false)]
+#endif
                public ContextMenu ContextMenu {
                        get {
                                return context_menu;
@@ -287,16 +333,23 @@ namespace System.Windows.Forms {
 
                        set {
                                if (icon != value) {
-                                       if (icon != null) {
-                                               icon.Dispose();
-                                       }
                                        icon = value;
-                                       ShowSystray(true);
+                                       if (text == string.Empty && icon == null) {
+                                               HideSystray ();
+                                       }
+                                       else {
+                                               Recalculate ();
+                                       }
                                }
                        }
                }
 
-               [Localizable(true)]
+#if NET_2_0
+               [DefaultValue ("")]
+               [Editor ("System.ComponentModel.Design.MultilineStringEditor, " + Consts.AssemblySystem_Design,
+                        typeof (System.Drawing.Design.UITypeEditor))]
+#endif
+               [Localizable (true)]
                public string Text {
                        get {
                                return text;
@@ -311,7 +364,7 @@ namespace System.Windows.Forms {
                                        if (text == string.Empty && icon == null) {
                                                HideSystray();
                                        } else {
-                                               ShowSystray(true);
+                                               Recalculate ();
                                        }
                                }
                        }
@@ -332,7 +385,7 @@ namespace System.Windows.Forms {
                                        window.is_visible = value;
 
                                        if (visible) {
-                                               ShowSystray(false);
+                                               ShowSystray ();
                                        } else {
                                                HideSystray();
                                        }
@@ -342,29 +395,61 @@ namespace System.Windows.Forms {
                #endregion      // Public Instance Properties
 
                #region Protected Instance Methods
-               protected override void Dispose(bool disposing) {\r
-                       if (icon != null) {\r
-                               icon.Dispose();\r
-                       }\r
-\r
-                       if (icon_bitmap != null) {\r
-                               icon_bitmap.Dispose();\r
-                       }\r
-                       base.Dispose (disposing);\r
-               }\r
+               protected override void Dispose(bool disposing) {
+                       if (icon_bitmap != null) {
+                               icon_bitmap.Dispose();
+                       }
+
+                       if (disposing)
+                               icon = null;
+
+                       base.Dispose (disposing);
+               }
 
                #endregion      // Protected Instance Methods
 
                #region Events
+               static object ClickEvent = new object ();
+               static object DoubleClickEvent = new object ();
+               static object MouseDownEvent = new object ();
+               static object MouseMoveEvent = new object ();
+               static object MouseUpEvent = new object ();
+
+#if NET_2_0
+               [MWFCategory("Action")]
+#else
                [Category("Action")]
-               public event EventHandler       Click;
+#endif
+               public event EventHandler Click {
+                       add { Events.AddHandler (ClickEvent, value); }
+                       remove { Events.RemoveHandler (ClickEvent, value); }
+               }
 
+#if NET_2_0
+               [MWFCategory("Action")]
+#else
                [Category("Action")]
-               public event EventHandler       DoubleClick;
+#endif
+               public event EventHandler DoubleClick {
+                       add { Events.AddHandler (DoubleClickEvent, value); }
+                       remove { Events.RemoveHandler (DoubleClickEvent, value); }
+               }
+
+               public event MouseEventHandler MouseDown {
+                       add { Events.AddHandler (MouseDownEvent, value); }
+                       remove { Events.RemoveHandler (MouseDownEvent, value); }
+               }
+
+               public event MouseEventHandler MouseMove {
+                       add { Events.AddHandler (MouseMoveEvent, value); }
+                       remove { Events.RemoveHandler (MouseMoveEvent, value); }
+               }
+
+               public event MouseEventHandler MouseUp {
+                       add { Events.AddHandler (MouseUpEvent, value); }
+                       remove { Events.RemoveHandler (MouseUpEvent, value); }
+               }
 
-               public event MouseEventHandler  MouseDown;
-               public event MouseEventHandler  MouseMove;
-               public event MouseEventHandler  MouseUp;
                #endregion      // Events
        }
 }