diff options
Diffstat (limited to 'widgets/misc/e-title-bar.c')
-rw-r--r-- | widgets/misc/e-title-bar.c | 221 |
1 files changed, 176 insertions, 45 deletions
diff --git a/widgets/misc/e-title-bar.c b/widgets/misc/e-title-bar.c index 613df2dcde..8ca6885ccf 100644 --- a/widgets/misc/e-title-bar.c +++ b/widgets/misc/e-title-bar.c @@ -40,14 +40,16 @@ enum { - TITLE_BUTTON_PRESS_EVENT, - CLOSE_BUTTON_CLICKED, + LABEL_BUTTON_PRESS_EVENT, + BUTTON_CLICKED, LAST_SIGNAL }; static guint signals[LAST_SIGNAL] = { 0 }; -static char *close_button_xpm[] = { +/* The pixmaps. */ + +static char *close_xpm[] = { "12 12 2 1", " c none", ". c #000000000000", @@ -65,54 +67,152 @@ static char *close_button_xpm[] = { " " }; +static char *pin_xpm[] = { + "16 16 33 1", + " c None", + ". c #000000", + "+ c #74744D", + "@ c #B2B279", + "# c #6C6C46", + "$ c #CACA9C", + "% c #F4F4AD", + "& c #85855A", + "* c #B1B175", + "= c #9A9A66", + "- c #A9A98A", + "; c #B0B07B", + "> c #535353", + ", c #818181", + "' c #B7B7B7", + ") c #D8D8D8", + "! c #FFFFFF", + "~ c #EBEBA1", + "{ c #8A8A75", + "] c #9F9F76", + "^ c #9E9E75", + "/ c #8A8A66", + "( c #979770", + "_ c #6B6B46", + ": c #28281A", + "< c #505034", + "[ c #666645", + "} c #61614D", + "| c #818155", + "1 c #4A4A31", + "2 c #4D4D34", + "3 c #6C6C48", + "4 c #5D5D3E", + " ", + " ", + " ", + " . . ", + " .. .+. ", + " .@...#$. ", + " ......%&*=-;. ", + ".>,')!.~{]^/(. ", + " ......_:<[}|. ", + " .1...23. ", + " .. .4. ", + " . . ", + " ", + " ", + " ", + " " +}; + + #define PARENT_TYPE GTK_TYPE_FRAME static GtkFrameClass *parent_class = NULL; struct _ETitleBarPrivate { + ETitleBarButtonMode button_mode; GtkWidget *label; - GtkWidget *close_button; - GtkWidget *close_button_gtk_pixmap; + GtkWidget *button; + GtkWidget *close_gtk_pixmap; + GtkWidget *pin_gtk_pixmap; }; +/* Mode handling. We put both the close and pin GtkPixmaps into an hbox in the + button, and hide one of them according to the mode. */ + +static void +show_and_hide_pixmaps_according_to_mode (ETitleBar *title_bar) +{ + ETitleBarPrivate *priv; + + priv = title_bar->priv; + + if (priv->close_gtk_pixmap == NULL || priv->pin_gtk_pixmap == NULL) + return; + + switch (priv->button_mode) { + case E_TITLE_BAR_BUTTON_MODE_PIN: + gtk_widget_hide (priv->close_gtk_pixmap); + gtk_widget_show (priv->pin_gtk_pixmap); + break; + case E_TITLE_BAR_BUTTON_MODE_CLOSE: + gtk_widget_hide (priv->pin_gtk_pixmap); + gtk_widget_show (priv->close_gtk_pixmap); + break; + default: + g_assert_not_reached (); + } +} + + /* Child signal callbacks. */ static void -close_button_realize_cb (GtkWidget *widget, - gpointer data) +button_realize_cb (GtkWidget *widget, + gpointer data) { - GdkPixmap *close_button_pixmap; - GdkBitmap *close_button_mask; + GdkPixmap *close_pixmap; + GdkBitmap *close_mask; + GdkPixmap *pin_pixmap; + GdkBitmap *pin_mask; + GtkWidget *hbox; ETitleBar *title_bar; ETitleBarPrivate *priv; title_bar = E_TITLE_BAR (data); priv = title_bar->priv; - if (priv->close_button_gtk_pixmap != NULL) + if (priv->close_gtk_pixmap != NULL) return; - close_button_pixmap = gdk_pixmap_create_from_xpm_d (GTK_WIDGET (priv->close_button)->window, - &close_button_mask, - NULL, close_button_xpm); - priv->close_button_gtk_pixmap = gtk_pixmap_new (close_button_pixmap, close_button_mask); + close_pixmap = gdk_pixmap_create_from_xpm_d (GTK_WIDGET (priv->button)->window, + &close_mask, NULL, close_xpm); + priv->close_gtk_pixmap = gtk_pixmap_new (close_pixmap, close_mask); + + pin_pixmap = gdk_pixmap_create_from_xpm_d (GTK_WIDGET (priv->button)->window, + &pin_mask, NULL, pin_xpm); + priv->pin_gtk_pixmap = gtk_pixmap_new (pin_pixmap, pin_mask); + + hbox = gtk_hbox_new (TRUE, 0); + gtk_widget_show (hbox); + gtk_box_pack_start (GTK_BOX (hbox), priv->pin_gtk_pixmap, TRUE, TRUE, 0); + gtk_box_pack_start (GTK_BOX (hbox), priv->close_gtk_pixmap, TRUE, TRUE, 0); - gtk_container_add (GTK_CONTAINER (priv->close_button), priv->close_button_gtk_pixmap); - gtk_widget_show (priv->close_button_gtk_pixmap); + gtk_container_add (GTK_CONTAINER (priv->button), hbox); - gdk_pixmap_unref (close_button_pixmap); - gdk_bitmap_unref (close_button_mask); + gdk_pixmap_unref (close_pixmap); + gdk_bitmap_unref (close_mask); + gdk_pixmap_unref (pin_pixmap); + gdk_bitmap_unref (pin_mask); + + show_and_hide_pixmaps_according_to_mode (title_bar); } static void -close_button_clicked_cb (GtkButton *button, - gpointer data) +button_clicked_cb (GtkButton *button, + gpointer data) { ETitleBar *title_bar; title_bar = E_TITLE_BAR (data); - gtk_signal_emit (GTK_OBJECT (title_bar), signals[CLOSE_BUTTON_CLICKED]); + gtk_signal_emit (GTK_OBJECT (title_bar), signals[BUTTON_CLICKED]); } static void @@ -124,7 +224,7 @@ label_button_press_event_cb (GtkWidget *widget, title_bar = E_TITLE_BAR (data); - gtk_signal_emit (GTK_OBJECT (title_bar), signals[TITLE_BUTTON_PRESS_EVENT], event); + gtk_signal_emit (GTK_OBJECT (title_bar), signals[LABEL_BUTTON_PRESS_EVENT], event); } @@ -155,20 +255,20 @@ class_init (ETitleBarClass *klass) parent_class = gtk_type_class (gtk_frame_get_type ()); - signals[TITLE_BUTTON_PRESS_EVENT] = - gtk_signal_new ("title_button_press_event", + signals[LABEL_BUTTON_PRESS_EVENT] = + gtk_signal_new ("label_button_press_event", GTK_RUN_FIRST, object_class->type, - GTK_SIGNAL_OFFSET (ETitleBarClass, title_button_press_event), + GTK_SIGNAL_OFFSET (ETitleBarClass, label_button_press_event), gtk_marshal_NONE__POINTER, GTK_TYPE_NONE, 1, GTK_TYPE_GDK_EVENT); - signals[CLOSE_BUTTON_CLICKED] = - gtk_signal_new ("close_button_clicked", + signals[BUTTON_CLICKED] = + gtk_signal_new ("button_clicked", GTK_RUN_FIRST, object_class->type, - GTK_SIGNAL_OFFSET (ETitleBarClass, close_button_clicked), + GTK_SIGNAL_OFFSET (ETitleBarClass, button_clicked), gtk_marshal_NONE__NONE, GTK_TYPE_NONE, 0); @@ -182,9 +282,11 @@ init (ETitleBar *title_bar) priv = g_new (ETitleBarPrivate, 1); - priv->label = NULL; - priv->close_button = NULL; - priv->close_button_gtk_pixmap = NULL; + priv->button_mode = E_TITLE_BAR_BUTTON_MODE_CLOSE; + priv->label = NULL; + priv->button = NULL; + priv->close_gtk_pixmap = NULL; + priv->pin_gtk_pixmap = NULL; title_bar->priv = priv; } @@ -206,23 +308,23 @@ e_title_bar_construct (ETitleBar *title_bar, gtk_misc_set_alignment (GTK_MISC (priv->label), 0.0, 0.5); gtk_widget_show (priv->label); - priv->close_button = gtk_button_new (); - GTK_WIDGET_UNSET_FLAGS (priv->close_button, GTK_CAN_FOCUS); - gtk_container_set_border_width (GTK_CONTAINER (priv->close_button), 1); - gtk_button_set_relief (GTK_BUTTON (priv->close_button), GTK_RELIEF_NONE); - gtk_widget_show (priv->close_button); + priv->button = gtk_button_new (); + GTK_WIDGET_UNSET_FLAGS (priv->button, GTK_CAN_FOCUS); + gtk_container_set_border_width (GTK_CONTAINER (priv->button), 1); + gtk_button_set_relief (GTK_BUTTON (priv->button), GTK_RELIEF_NONE); + gtk_widget_show (priv->button); hbox = gtk_hbox_new (FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), priv->label, TRUE, TRUE, 2); - gtk_box_pack_start (GTK_BOX (hbox), priv->close_button, FALSE, TRUE, 1); + gtk_box_pack_start (GTK_BOX (hbox), priv->button, FALSE, TRUE, 1); gtk_widget_show (hbox); gtk_container_add (GTK_CONTAINER (title_bar), hbox); - gtk_signal_connect (GTK_OBJECT (priv->close_button), "realize", - GTK_SIGNAL_FUNC (close_button_realize_cb), title_bar); - gtk_signal_connect (GTK_OBJECT (priv->close_button), "clicked", - GTK_SIGNAL_FUNC (close_button_clicked_cb), title_bar); + gtk_signal_connect (GTK_OBJECT (priv->button), "realize", + GTK_SIGNAL_FUNC (button_realize_cb), title_bar); + gtk_signal_connect (GTK_OBJECT (priv->button), "clicked", + GTK_SIGNAL_FUNC (button_clicked_cb), title_bar); gtk_signal_connect (GTK_OBJECT (priv->label), "button_press_event", GTK_SIGNAL_FUNC (label_button_press_event_cb), title_bar); } @@ -251,8 +353,8 @@ e_title_bar_set_title (ETitleBar *title_bar, } void -e_title_bar_show_close_button (ETitleBar *title_bar, - gboolean show) +e_title_bar_show_button (ETitleBar *title_bar, + gboolean show) { ETitleBarPrivate *priv; @@ -262,9 +364,38 @@ e_title_bar_show_close_button (ETitleBar *title_bar, priv = title_bar->priv; if (show) - gtk_widget_show (priv->close_button); + gtk_widget_show (priv->button); else - gtk_widget_hide (priv->close_button); + gtk_widget_hide (priv->button); +} + +void +e_title_bar_set_button_mode (ETitleBar *title_bar, + ETitleBarButtonMode button_mode) +{ + ETitleBarPrivate *priv; + + g_return_if_fail (title_bar != NULL); + g_return_if_fail (E_IS_TITLE_BAR (title_bar)); + g_return_if_fail (button_mode == E_TITLE_BAR_BUTTON_MODE_CLOSE + || button_mode == E_TITLE_BAR_BUTTON_MODE_PIN); + + priv = title_bar->priv; + + if (priv->button_mode == button_mode) + return; + + priv->button_mode = button_mode; + show_and_hide_pixmaps_according_to_mode (title_bar); +} + +ETitleBarButtonMode +e_title_bar_get_button_mode (ETitleBar *title_bar) +{ + g_return_val_if_fail (title_bar != NULL, E_TITLE_BAR_BUTTON_MODE_CLOSE); + g_return_val_if_fail (E_IS_TITLE_BAR (title_bar), E_TITLE_BAR_BUTTON_MODE_CLOSE); + + return title_bar->priv->button_mode; } |