diff options
-rw-r--r-- | calendar/ChangeLog | 12 | ||||
-rw-r--r-- | calendar/gui/calendar-component.c | 75 | ||||
-rw-r--r-- | calendar/gui/tasks-component.c | 43 |
3 files changed, 69 insertions, 61 deletions
diff --git a/calendar/ChangeLog b/calendar/ChangeLog index 4a5161f63b..923e1512e3 100644 --- a/calendar/ChangeLog +++ b/calendar/ChangeLog @@ -1,3 +1,15 @@ +2004-01-14 JP Rosevear <jpr@ximian.com> + + * gui/tasks-component.c (impl_requestCreateItem): new utility + routine to create new tasks + (create_new_todo): use above so we don't try to set up the + creation ecal unless we are actually creating a new item + + * gui/calendar-component.c (create_new_event): new utility routine + to create new events + (impl_requestCreateItem): use above so we don't try to set up the + creation ecal unless we are actually creating a new item + 2004-01-14 Rodrigo Moya <rodrigo@ximian.com> * gui/e-calendar-table.c (e_calendar_table_show_popup_menu): diff --git a/calendar/gui/calendar-component.c b/calendar/gui/calendar-component.c index 0726ee9ccc..194d4ec563 100644 --- a/calendar/gui/calendar-component.c +++ b/calendar/gui/calendar-component.c @@ -112,26 +112,6 @@ is_in_uids (GSList *uids, ESource *source) return FALSE; } -static ESource * -find_first_source (ESourceList *source_list) -{ - GSList *groups, *sources, *l, *m; - - groups = e_source_list_peek_groups (source_list); - for (l = groups; l; l = l->next) { - ESourceGroup *group = l->data; - - sources = e_source_group_peek_sources (group); - for (m = sources; m; m = m->next) { - ESource *source = m->data; - - return source; - } - } - - return NULL; -} - static void update_uris_for_selection (CalendarComponent *calendar_component) { @@ -826,52 +806,55 @@ setup_create_ecal (CalendarComponent *calendar_component) } static void -impl_requestCreateItem (PortableServer_Servant servant, - const CORBA_char *item_type_name, - CORBA_Environment *ev) +create_new_event (CalendarComponent *calendar_component, gboolean is_allday, gboolean is_meeting, CORBA_Environment *ev) { - CalendarComponent *calendar_component = CALENDAR_COMPONENT (bonobo_object_from_servant (servant)); CalendarComponentPrivate *priv; ECalComponent *comp; EventEditor *editor; - gboolean is_meeting = FALSE; - gboolean read_only = FALSE; + gboolean read_only; priv = calendar_component->priv; - + if (!setup_create_ecal (calendar_component)) { bonobo_exception_set (ev, ex_GNOME_Evolution_Component_Failed); return; - - e_cal_is_read_only (priv->create_ecal, &read_only, NULL); - if (read_only) - return; - } + if (!e_cal_is_read_only (priv->create_ecal, &read_only, NULL) || read_only); + return; + editor = event_editor_new (priv->create_ecal); + comp = get_default_event (priv->create_ecal, is_allday); + + comp_editor_edit_comp (COMP_EDITOR (editor), comp); + if (is_meeting) + event_editor_show_meeting (editor); + comp_editor_focus (COMP_EDITOR (editor)); + + e_comp_editor_registry_add (comp_editor_registry, COMP_EDITOR (editor), TRUE); +} + +static void +impl_requestCreateItem (PortableServer_Servant servant, + const CORBA_char *item_type_name, + CORBA_Environment *ev) +{ + CalendarComponent *calendar_component = CALENDAR_COMPONENT (bonobo_object_from_servant (servant)); + CalendarComponentPrivate *priv; + + priv = calendar_component->priv; if (strcmp (item_type_name, CREATE_EVENT_ID) == 0) { - comp = get_default_event (priv->create_ecal, FALSE); + create_new_event (calendar_component, FALSE, FALSE, ev); } else if (strcmp (item_type_name, CREATE_ALLDAY_EVENT_ID) == 0) { - comp = get_default_event (priv->create_ecal, TRUE); + create_new_event (calendar_component, TRUE, FALSE, ev); } else if (strcmp (item_type_name, CREATE_MEETING_ID) == 0) { - comp = get_default_event (priv->create_ecal, FALSE); - is_meeting = TRUE; + create_new_event (calendar_component, FALSE, TRUE, ev); } else if (strcmp (item_type_name, CREATE_CALENDAR_ID) == 0) { calendar_setup_new_calendar (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (priv->calendar)))); - return; } else { bonobo_exception_set (ev, ex_GNOME_Evolution_Component_UnknownType); - return; - } - - comp_editor_edit_comp (COMP_EDITOR (editor), comp); - if (is_meeting) - event_editor_show_meeting (editor); - comp_editor_focus (COMP_EDITOR (editor)); - - e_comp_editor_registry_add (comp_editor_registry, COMP_EDITOR (editor), TRUE); + } } diff --git a/calendar/gui/tasks-component.c b/calendar/gui/tasks-component.c index ce9f77157f..3472aeb418 100644 --- a/calendar/gui/tasks-component.c +++ b/calendar/gui/tasks-component.c @@ -726,6 +726,33 @@ setup_create_ecal (TasksComponent *component) } static void +create_new_todo (TasksComponent *task_component, CORBA_Environment *ev) +{ + TasksComponentPrivate *priv; + ECalComponent *comp; + TaskEditor *editor; + gboolean read_only; + + priv = task_component->priv; + + if (!setup_create_ecal (task_component)) { + bonobo_exception_set (ev, ex_GNOME_Evolution_Component_Failed); + return; + } + + if (!e_cal_is_read_only (priv->create_ecal, &read_only, NULL) || read_only); + return; + + editor = task_editor_new (priv->create_ecal); + comp = get_default_task (priv->create_ecal); + + comp_editor_edit_comp (COMP_EDITOR (editor), comp); + comp_editor_focus (COMP_EDITOR (editor)); + + e_comp_editor_registry_add (comp_editor_registry, COMP_EDITOR (editor), TRUE); +} + +static void impl_requestCreateItem (PortableServer_Servant servant, const CORBA_char *item_type_name, CORBA_Environment *ev) @@ -736,25 +763,11 @@ impl_requestCreateItem (PortableServer_Servant servant, priv = tasks_component->priv; if (strcmp (item_type_name, CREATE_TASK_ID) == 0) { - ECalComponent *comp; - TaskEditor *editor; - - if (!setup_create_ecal (tasks_component)) - return; - - editor = task_editor_new (priv->create_ecal); - - comp = get_default_task (priv->create_ecal); - - comp_editor_edit_comp (COMP_EDITOR (editor), comp); - comp_editor_focus (COMP_EDITOR (editor)); - - e_comp_editor_registry_add (comp_editor_registry, COMP_EDITOR (editor), TRUE); + create_new_todo (tasks_component, ev); } else if (strcmp (item_type_name, CREATE_TASK_LIST_ID) == 0) { calendar_setup_new_task_list (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (priv->tasks)))); } else { bonobo_exception_set (ev, ex_GNOME_Evolution_Component_UnknownType); - return; } } |