aboutsummaryrefslogtreecommitdiffstats
path: root/composer/e-msg-composer.c
diff options
context:
space:
mode:
Diffstat (limited to 'composer/e-msg-composer.c')
-rw-r--r--composer/e-msg-composer.c283
1 files changed, 81 insertions, 202 deletions
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c
index e05dc71103..f614c6512d 100644
--- a/composer/e-msg-composer.c
+++ b/composer/e-msg-composer.c
@@ -564,7 +564,7 @@ do_exit (EMsgComposer *composer)
/* Menu callbacks. */
static void
-menu_file_open_cb (BonoboUIHandler *uih,
+menu_file_open_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -583,7 +583,7 @@ menu_file_open_cb (BonoboUIHandler *uih,
}
static void
-menu_file_save_cb (BonoboUIHandler *uih,
+menu_file_save_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -608,7 +608,7 @@ menu_file_save_cb (BonoboUIHandler *uih,
}
static void
-menu_file_save_as_cb (BonoboUIHandler *uih,
+menu_file_save_as_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -620,7 +620,7 @@ menu_file_save_as_cb (BonoboUIHandler *uih,
}
static void
-menu_file_send_cb (BonoboUIHandler *uih,
+menu_file_send_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -628,7 +628,7 @@ menu_file_send_cb (BonoboUIHandler *uih,
}
static void
-menu_file_send_later_cb (BonoboUIHandler *uih,
+menu_file_send_later_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -636,7 +636,7 @@ menu_file_send_later_cb (BonoboUIHandler *uih,
}
static void
-menu_file_close_cb (BonoboUIHandler *uih,
+menu_file_close_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -647,7 +647,7 @@ menu_file_close_cb (BonoboUIHandler *uih,
}
static void
-menu_file_add_attachment_cb (BonoboUIHandler *uih,
+menu_file_add_attachment_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -661,14 +661,21 @@ menu_file_add_attachment_cb (BonoboUIHandler *uih,
}
static void
-menu_view_attachments_activate_cb (BonoboUIHandler *uih,
- void *data,
- const char *path)
+menu_view_attachments_activate_cb (BonoboUIComponent *component,
+ const char *path,
+ Bonobo_UIComponent_EventType type,
+ const char *state,
+ gpointer user_data)
+
{
- gboolean state;
+ gboolean new_state;
+
+ if (type != Bonobo_UIComponent_STATE_CHANGED)
+ return;
+
+ new_state = atoi (state);
- state = bonobo_ui_handler_menu_get_toggle_state (uih, path);
- e_msg_composer_show_attachments (E_MSG_COMPOSER (data), state);
+ e_msg_composer_show_attachments (E_MSG_COMPOSER (user_data), new_state);
}
#if 0
@@ -811,7 +818,7 @@ static void fs_selection_get (GtkWidget *widget, GtkSelectionData *sdata,
#endif
static void
-menu_file_insert_file_cb (BonoboUIHandler *uih,
+menu_file_insert_file_cb (BonoboUIComponent *uic,
void *data,
const char *path)
{
@@ -837,205 +844,76 @@ menu_file_insert_file_cb (BonoboUIHandler *uih,
}
static void
-menu_format_html_cb (BonoboUIHandler *uih,
- void *data,
- const char *path)
+menu_format_html_cb (BonoboUIComponent *component,
+ const char *path,
+ Bonobo_UIComponent_EventType type,
+ const char *state,
+ gpointer user_data)
+
{
EMsgComposer *composer;
gboolean new_state;
- composer = E_MSG_COMPOSER (data);
+ if (type != Bonobo_UIComponent_STATE_CHANGED)
+ return;
+
+ composer = E_MSG_COMPOSER (user_data);
- new_state = bonobo_ui_handler_menu_get_toggle_state (uih, path);
- if ((new_state && composer->send_html) || (! new_state && ! composer->send_html))
+ new_state = atoi (state);
+
+ if ((new_state && composer->send_html) ||
+ (! new_state && ! composer->send_html))
return;
e_msg_composer_set_send_html (composer, new_state);
}
-/* Menu bar creation. */
+static BonoboUIVerb verbs [] = {
-static void
-create_menubar_file (EMsgComposer *composer,
- BonoboUIHandler *uih)
-{
- bonobo_ui_handler_menu_new_subtree (uih, "/File",
- _("_File"),
- NULL, -1,
- BONOBO_UI_HANDLER_PIXMAP_NONE, NULL,
- 0, 0);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Open",
- _("_Open..."),
- _("Load a previously saved message"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_MENU_OPEN,
- 0, 0,
- menu_file_open_cb, composer);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Save",
- _("_Save..."),
- _("Save message"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_MENU_SAVE,
- 0, 0,
- menu_file_save_cb, composer);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Save as",
- _("Save _as..."),
- _("Save message with a different name"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_MENU_SAVE_AS,
- 0, 0,
- menu_file_save_as_cb, composer);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Save in folder",
- _("Save in _folder..."),
- _("Save the message in a specified folder"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_NONE, NULL,
- 0, 0,
- NULL, composer);
-
- bonobo_ui_handler_menu_new_separator (uih, "/File/Separator1", -1);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Insert text file",
- _("_Insert text file... (FIXME)"),
- _("Insert a file as text into the message"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_NONE, NULL,
- 0, 0,
- menu_file_insert_file_cb, composer);
-
- bonobo_ui_handler_menu_new_separator (uih, "/File/Separator2", -1);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Send Now",
- _("Send _Now"),
- _("Send the message now"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_MENU_MAIL_SND,
- 0, 0,
- menu_file_send_cb, composer);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Send Later",
- _("Send _Later"),
- _("Send the message later"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_MENU_MAIL_SND,
- 0, 0,
- menu_file_send_later_cb, composer);
-
- bonobo_ui_handler_menu_new_separator (uih, "/File/Separator3", -1);
-
- bonobo_ui_handler_menu_new_item (uih, "/File/Close",
- _("_Close..."),
- _("Quit the message composer"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_MENU_CLOSE,
- 0, 0,
- menu_file_close_cb, composer);
-}
+ BONOBO_UI_UNSAFE_VERB ("FileOpen", menu_file_open_cb),
+ BONOBO_UI_UNSAFE_VERB ("FileSave", menu_file_save_cb),
+ BONOBO_UI_UNSAFE_VERB ("FileSaveAs", menu_file_save_as_cb),
+ BONOBO_UI_UNSAFE_VERB ("FileClose", menu_file_close_cb),
-static void
-create_menubar_edit (EMsgComposer *composer,
- BonoboUIHandler *uih)
-{
- bonobo_ui_handler_menu_new_subtree (uih, "/Edit",
- _("_Edit"),
- NULL, -1,
- BONOBO_UI_HANDLER_PIXMAP_NONE, NULL,
- 0, 0);
-}
+ BONOBO_UI_UNSAFE_VERB ("FileInsertFile", menu_file_insert_file_cb),
+ BONOBO_UI_UNSAFE_VERB ("FileAttach", menu_file_add_attachment_cb),
-static void
-create_menubar_format (EMsgComposer *composer,
- BonoboUIHandler *uih)
-{
- bonobo_ui_handler_menu_new_subtree (uih, "/Format",
- _("F_ormat"),
- NULL, -1,
- BONOBO_UI_HANDLER_PIXMAP_NONE, NULL,
- 0, 0);
-
- bonobo_ui_handler_menu_new_toggleitem (uih, "/Format/HTML",
- _("HTML"),
- _("Send the mail in HTML format"),
- -1,
- 0, 0,
- menu_format_html_cb, composer);
-
- bonobo_ui_handler_menu_set_toggle_state (uih, "/Format/HTML", composer->send_html);
-}
+ BONOBO_UI_UNSAFE_VERB ("FileSend", menu_file_send_cb),
+ BONOBO_UI_UNSAFE_VERB ("FileSendLater", menu_file_send_later_cb),
-static void
-create_menubar_view (EMsgComposer *composer,
- BonoboUIHandler *uih)
-{
- bonobo_ui_handler_menu_new_subtree (uih, "/View",
- _("_View"),
- NULL, -1,
- BONOBO_UI_HANDLER_PIXMAP_NONE, NULL,
- 0, 0);
-
- bonobo_ui_handler_menu_new_toggleitem (uih, "/View/Show attachments",
- _("Show _attachments"),
- _("Show/hide attachments"),
- -1,
- 0, 0,
- menu_view_attachments_activate_cb, composer);
-}
+ BONOBO_UI_VERB_END
+};
static void
-create_menubar (EMsgComposer *composer)
+setup_ui (EMsgComposer *composer)
{
- BonoboUIHandler *uih;
-
- uih = composer->uih;
- bonobo_ui_handler_create_menubar (uih);
-
- create_menubar_file (composer, uih);
- create_menubar_edit (composer, uih);
- create_menubar_format (composer, uih);
- create_menubar_view (composer, uih);
-}
+ BonoboUIContainer *container;
-
-/* Toolbar implementation. */
+ container = bonobo_ui_container_new ();
+ bonobo_ui_container_set_win (container, BONOBO_WIN (composer));
-static void
-create_toolbar (EMsgComposer *composer)
-{
- BonoboUIHandler *uih;
-
- uih = composer->uih;
- bonobo_ui_handler_create_toolbar (uih, "Toolbar");
-
- bonobo_ui_handler_toolbar_new_item (uih,
- "/Toolbar/Send",
- _("Send"),
- _("Send this message"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_PIXMAP_MAIL_SND,
- 0, 0,
- menu_file_send_cb, composer);
-
- bonobo_ui_handler_toolbar_new_item (uih,
- "/Toolbar/Attach",
- _("Attach"),
- _("Attach a file"),
- -1,
- BONOBO_UI_HANDLER_PIXMAP_STOCK,
- GNOME_STOCK_PIXMAP_ATTACH,
- 0, 0,
- menu_file_add_attachment_cb, composer);
+ composer->uic = bonobo_ui_component_new ("evolution-message-composer");
+ bonobo_ui_component_set_container (
+ composer->uic, bonobo_object_corba_objref (BONOBO_OBJECT (container)));
+
+ bonobo_ui_component_add_verb_list_with_data (
+ composer->uic, verbs, composer);
+
+ bonobo_ui_util_set_ui (composer->uic, EVOLUTION_DATADIR,
+ "evolution-message-composer.xml",
+ "evolution-message-composer");
+
+ bonobo_ui_component_set_prop (composer->uic, "/commands/FormatHtml",
+ "state", composer->send_html ? "1" : "0", NULL);
+
+ bonobo_ui_component_add_listener (
+ composer->uic, "FormatHtml",
+ menu_format_html_cb, composer);
+
+ bonobo_ui_component_add_listener (
+ composer->uic, "ViewAttach",
+ menu_view_attachments_activate_cb, composer);
}
@@ -1066,7 +944,9 @@ destroy (GtkObject *object)
composer = E_MSG_COMPOSER (object);
- bonobo_object_unref (BONOBO_OBJECT (composer->uih));
+ if (composer->uic)
+ bonobo_object_unref (BONOBO_OBJECT (composer->uic));
+ composer->uic = NULL;
/* FIXME? I assume the Bonobo widget will get destroyed
normally? */
@@ -1188,7 +1068,7 @@ class_init (EMsgComposerClass *klass)
static void
init (EMsgComposer *composer)
{
- composer->uih = NULL;
+ composer->uic = NULL;
composer->hdrs = NULL;
composer->extra_hdr_names = g_ptr_array_new ();
@@ -1262,8 +1142,7 @@ e_msg_composer_construct (EMsgComposer *composer)
gtk_signal_connect (GTK_OBJECT (composer), "drag_data_received",
GTK_SIGNAL_FUNC (drag_data_received), NULL);
- composer->uih = bonobo_ui_handler_new ();
- bonobo_ui_handler_set_app (composer->uih, BONOBO_WIN (composer));
+ setup_ui (composer);
vbox = gtk_vbox_new (FALSE, 0);
@@ -1272,12 +1151,10 @@ e_msg_composer_construct (EMsgComposer *composer)
gtk_widget_show (composer->hdrs);
/* Editor component. */
-
- create_menubar (composer);
- create_toolbar (composer);
composer->editor = bonobo_widget_new_control (
HTML_EDITOR_CONTROL_ID,
- bonobo_ui_compat_get_container (composer->uih));
+ bonobo_ui_component_get_container (composer->uic));
+
if (!composer->editor)
return;
@@ -1767,7 +1644,9 @@ e_msg_composer_set_send_html (EMsgComposer *composer,
return;
composer->send_html = send_html;
- bonobo_ui_handler_menu_set_toggle_state (composer->uih, "/Format/HTML", send_html);
+
+ bonobo_ui_component_set_prop (composer->uic, "/commands/FormatHtml",
+ "state", composer->send_html ? "1" : "0", NULL);
}
/**