diff options
-rw-r--r-- | mail/ChangeLog | 10 | ||||
-rw-r--r-- | mail/GNOME_Evolution_Mail.server.in.in | 30 | ||||
-rw-r--r-- | mail/mail-component.c | 79 |
3 files changed, 104 insertions, 15 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 3de054e03f..ddb65d5891 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,13 @@ +2004-01-12 Larry Ewing <lewing@ximian.com> + + * GNOME_Evolution_Mail.server.in.in: fix up the controls factory + location. + + * mail-component.c (mail_control_new): add new interface for + getting a mail control with a folder_uri property bag. + (get_prop): pbag get method. + (set_prop): pbag set method. + 2004-01-11 Jeffrey Stedfast <fejj@ximian.com> * em-migrate.c (cp): Don't O_TRUNC the dest file, instead use diff --git a/mail/GNOME_Evolution_Mail.server.in.in b/mail/GNOME_Evolution_Mail.server.in.in index 36e48bce0d..d482615e30 100644 --- a/mail/GNOME_Evolution_Mail.server.in.in +++ b/mail/GNOME_Evolution_Mail.server.in.in @@ -15,20 +15,6 @@ _value="Evolution Mail"/> </oaf_server> - <!-- (control) --> - <oaf_server iid="OAFIID:GNOME_Evolution_Mail_Control:@VERSION@" - type="factory" - location="OAFIID:GNOME_Evolution_Mail_ControlFactory:@VERSION@"> - - <oaf_attribute name="repo_ids" type="stringv"> - <item value="IDL:BonoboControl/evolution-mail:@VERSION@"/> - <item value="IDL:GNOME/Control:1.0"/> - </oaf_attribute> - - <oaf_attribute name="name" type="string" - _value="Evolution Mail folder viewer"/> - </oaf_server> - <!-- Component Interface --> <oaf_server iid="OAFIID:GNOME_Evolution_Mail_Component:@VERSION@" @@ -90,8 +76,22 @@ _value="Evolution Mail composer"/> </oaf_server> - <!-- Startup Wizard --> + <!-- (control) --> + <oaf_server iid="OAFIID:GNOME_Evolution_Mail_Control:@VERSION@" + type="factory" + location="OAFIID:GNOME_Evolution_Mail_Factory:@VERSION@"> + + <oaf_attribute name="repo_ids" type="stringv"> + <item value="IDL:BonoboControl/evolution-mail-control:@VERSION@"/> + <item value="IDL:GNOME/Control:1.0"/> + </oaf_attribute> + <oaf_attribute name="name" type="string" + _value="Evolution Mail folder viewer"/> + + </oaf_server> + + <!-- Startup Wizard --> <!-- (wizard) --> <oaf_server iid="OAFIID:GNOME_Evolution_Mail_Wizard:@VERSION@" type="factory" diff --git a/mail/mail-component.c b/mail/mail-component.c index 00715d7970..1faa15068d 100644 --- a/mail/mail-component.c +++ b/mail/mail-component.c @@ -235,6 +235,55 @@ folder_selected_cb (EMFolderTree *emft, const char *path, const char *uri, EMFol em_folder_view_set_folder_uri (view, uri); } +#define PROPERTY_FOLDER_URI "folder_uri" +#define PROPERTY_FOLDER_URI_IDX 1 + +static void +set_prop (BonoboPropertyBag *bag, + const BonoboArg *arg, + guint arg_id, + CORBA_Environment *ev, + gpointer user_data) +{ + EMFolderView *view = (EMFolderView *)bonobo_control_get_widget (user_data); + const gchar *uri; + + switch (arg_id) { + case PROPERTY_FOLDER_URI_IDX: + uri = BONOBO_ARG_GET_STRING (arg); + + g_warning ("XXX setting uri blah=\"%s\"\n", uri); + + em_folder_view_set_folder_uri (view, uri); + break; + default: + g_warning ("Unhandled arg %d\n", arg_id); + break; + } +} + +static void +get_prop (BonoboPropertyBag *bag, + BonoboArg *arg, + guint arg_id, + CORBA_Environment *ev, + gpointer user_data) +{ + GtkWidget *widget = bonobo_control_get_widget (user_data); + EMFolderView *view = (EMFolderView *)widget; + + switch (arg_id) { + case PROPERTY_FOLDER_URI_IDX: + if (view->folder_uri) + BONOBO_ARG_SET_STRING (arg, view->folder_uri); + else + BONOBO_ARG_SET_STRING (arg, ""); + break; + default: + g_warning ("Unhandled arg %d\n", arg_id); + } +} + static void view_control_activate_cb (BonoboControl *control, gboolean activate, EMFolderView *view) { @@ -512,6 +561,36 @@ mail_component_init (MailComponent *component) /* Public API. */ +BonoboControl * +mail_control_new (void) +{ + BonoboControl *view_control; + GtkWidget *view_widget; + BonoboPropertyBag *pbag; + + view_widget = em_folder_browser_new (); + gtk_widget_show (view_widget); + + view_control = bonobo_control_new (view_widget); + pbag = bonobo_property_bag_new (get_prop, set_prop, view_control); + + bonobo_property_bag_add (pbag, + PROPERTY_FOLDER_URI, + PROPERTY_FOLDER_URI_IDX, + BONOBO_ARG_STRING, + NULL, + _("URI of the mail source that the view will display"), + 0); + + bonobo_control_set_properties (view_control, + bonobo_object_corba_objref (BONOBO_OBJECT (pbag)), + NULL); + bonobo_object_unref (BONOBO_OBJECT (pbag)); + + g_signal_connect (view_control, "activate", G_CALLBACK (view_control_activate_cb), view_widget); + + return view_control; +} MailComponent * mail_component_peek (void) |