diff options
Diffstat (limited to 'calendar/gui')
-rw-r--r-- | calendar/gui/calendar-component.c | 39 | ||||
-rw-r--r-- | calendar/gui/tasks-component.c | 34 |
2 files changed, 18 insertions, 55 deletions
diff --git a/calendar/gui/calendar-component.c b/calendar/gui/calendar-component.c index 1cad66d98c..0efea35e82 100644 --- a/calendar/gui/calendar-component.c +++ b/calendar/gui/calendar-component.c @@ -33,6 +33,7 @@ #include "calendar-config.h" #include "calendar-component.h" #include "calendar-commands.h" +#include "control-factory.h" #include "gnome-cal.h" #include "migration.h" #include "e-comp-editor-registry.h" @@ -62,6 +63,8 @@ struct _CalendarComponentPrivate { GnomeCalendar *calendar; GtkWidget *source_selector; + BonoboControl *view_control; + ECal *create_ecal; GList *notifications; @@ -191,7 +194,9 @@ update_uri_for_primary_selection (CalendarComponent *calendar_component) uri = e_source_get_uri (source); gnome_calendar_set_default_uri (priv->calendar, uri); g_free (uri); - + + calendar_control_sensitize_calendar_commands (priv->view_control, priv->calendar, TRUE); + /* Save the selection for next time we start up */ calendar_config_set_primary_calendar (e_source_peek_uid (source)); } @@ -515,19 +520,6 @@ impl_finalize (GObject *object) /* Evolution::Component CORBA methods. */ static void -control_activate_cb (BonoboControl *control, gboolean activate, gpointer data) -{ - GnomeCalendar *gcal; - - gcal = GNOME_CALENDAR (data); - - if (activate) - calendar_control_activate (control, gcal); - else - calendar_control_deactivate (control, gcal); -} - -static void impl_createControls (PortableServer_Servant servant, Bonobo_Control *corba_sidebar_control, Bonobo_Control *corba_view_control, @@ -539,7 +531,6 @@ impl_createControls (PortableServer_Servant servant, GtkWidget *selector_scrolled_window; GtkWidget *statusbar_widget; BonoboControl *sidebar_control; - BonoboControl *view_control; BonoboControl *statusbar_control; guint not; @@ -562,24 +553,14 @@ impl_createControls (PortableServer_Servant servant, /* Create main calendar view */ /* FIXME Instead of returning, we should make a control with a * label describing the problem */ - priv->calendar = GNOME_CALENDAR (gnome_calendar_new ()); - if (!priv->calendar) { - g_warning (G_STRLOC ": could not create the calendar widget!"); - bonobo_exception_set (ev, ex_GNOME_Evolution_Component_Failed); - return; - } - - gtk_widget_show (GTK_WIDGET (priv->calendar)); - - view_control = bonobo_control_new (GTK_WIDGET (priv->calendar)); - if (!view_control) { + priv->view_control = control_factory_new_control (); + if (!priv->view_control) { g_warning (G_STRLOC ": could not create the control!"); bonobo_exception_set (ev, ex_GNOME_Evolution_Component_Failed); return; } - g_object_set_data (G_OBJECT (priv->calendar), "control", view_control); - g_signal_connect (view_control, "activate", G_CALLBACK (control_activate_cb), priv->calendar); + priv->calendar = (GnomeCalendar *) bonobo_control_get_widget (priv->view_control); g_signal_connect_object (priv->source_selector, "selection_changed", G_CALLBACK (source_selection_changed_cb), @@ -611,7 +592,7 @@ impl_createControls (PortableServer_Servant servant, /* Return the controls */ *corba_sidebar_control = CORBA_Object_duplicate (BONOBO_OBJREF (sidebar_control), ev); - *corba_view_control = CORBA_Object_duplicate (BONOBO_OBJREF (view_control), ev); + *corba_view_control = CORBA_Object_duplicate (BONOBO_OBJREF (priv->view_control), ev); *corba_statusbar_control = CORBA_Object_duplicate (BONOBO_OBJREF (statusbar_control), ev); } diff --git a/calendar/gui/tasks-component.c b/calendar/gui/tasks-component.c index db7864bdd7..bda28845e2 100644 --- a/calendar/gui/tasks-component.c +++ b/calendar/gui/tasks-component.c @@ -66,8 +66,10 @@ struct _TasksComponentPrivate { ETasks *tasks; GtkWidget *source_selector; + BonoboControl *view_control; + ECal *create_ecal; - + GList *notifications; }; @@ -478,17 +480,6 @@ impl_finalize (GObject *object) /* Evolution::Component CORBA methods */ static void -control_activate_cb (BonoboControl *control, gboolean activate, gpointer data) -{ - ETasks *tasks = data; - - if (activate) - tasks_control_activate (control, tasks); - else - tasks_control_deactivate (control, tasks); -} - -static void impl_createControls (PortableServer_Servant servant, Bonobo_Control *corba_sidebar_control, Bonobo_Control *corba_view_control, @@ -498,7 +489,7 @@ impl_createControls (PortableServer_Servant servant, TasksComponent *component = TASKS_COMPONENT (bonobo_object_from_servant (servant)); TasksComponentPrivate *priv; GtkWidget *selector_scrolled_window; - BonoboControl *sidebar_control, *view_control; + BonoboControl *sidebar_control; guint not; priv = component->priv; @@ -518,23 +509,14 @@ impl_createControls (PortableServer_Servant servant, sidebar_control = bonobo_control_new (selector_scrolled_window); /* create the tasks view */ - priv->tasks = E_TASKS (e_tasks_new ()); - if (!priv->tasks) { - g_warning (G_STRLOC ": could not create the control!"); - bonobo_exception_set (ev, ex_GNOME_Evolution_Component_Failed); - return; - } - - gtk_widget_show (GTK_WIDGET (priv->tasks)); - - view_control = bonobo_control_new (GTK_WIDGET (priv->tasks)); - if (!view_control) { + priv->view_control = tasks_control_new (); + if (!priv->view_control) { g_warning (G_STRLOC ": could not create the control!"); bonobo_exception_set (ev, ex_GNOME_Evolution_Component_Failed); return; } - g_signal_connect (view_control, "activate", G_CALLBACK (control_activate_cb), priv->tasks); + priv->tasks = (ETasks *) bonobo_control_get_widget (priv->view_control); g_signal_connect_object (priv->source_selector, "selection_changed", G_CALLBACK (source_selection_changed_cb), @@ -561,7 +543,7 @@ impl_createControls (PortableServer_Servant servant, /* Return the controls */ *corba_sidebar_control = CORBA_Object_duplicate (BONOBO_OBJREF (sidebar_control), ev); - *corba_view_control = CORBA_Object_duplicate (BONOBO_OBJREF (view_control), ev); + *corba_view_control = CORBA_Object_duplicate (BONOBO_OBJREF (priv->view_control), ev); /* The tasks component doesn't use the status bar so just return an empty label. */ { |