diff options
author | Not Zed <NotZed@Ximian.com> | 2004-10-12 15:45:09 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2004-10-12 15:45:09 +0800 |
commit | c0b21b141efd40f487b59069deb9b3a70899afb5 (patch) | |
tree | 06f498f8557316a83d7a43c7db253b0d75072063 /calendar/gui/e-cal-popup.c | |
parent | acbeb6cddd469e969b95cd4df7f9750bab39d0c0 (diff) | |
download | gsoc2013-evolution-c0b21b141efd40f487b59069deb9b3a70899afb5.tar.gz gsoc2013-evolution-c0b21b141efd40f487b59069deb9b3a70899afb5.tar.zst gsoc2013-evolution-c0b21b141efd40f487b59069deb9b3a70899afb5.zip |
removed. (e_calendar_table_show_popup_menu): convert to use e-popup for
2004-10-12 Not Zed <NotZed@Ximian.com>
* gui/e-calendar-table.c (setup_popup_icons): removed.
(e_calendar_table_show_popup_menu): convert to use e-popup for
pluggable popup menu.
(e_calendar_table_on_open_task, e_calendar_table_on_save_as)
(e_calendar_table_on_print_task, e_calendar_table_on_cut)
(e_calendar_table_on_copy, e_calendar_table_on_paste)
(e_calendar_table_on_assign, e_calendar_table_on_forward)
(delete_cb):
(mark_as_complete_cb, open_url_cb): convert to epopup callbacks.
Moved all of the callbacks above the table rather than maintaining
forward declarations for some of them.
* gui/e-cal-popup.c (e_cal_popup_target_new_select): add the task
required masks, and make one vs many mutally exclusive.
* gui/e-calendar-view.c (e_calendar_view_create_popup_menu):
copy/setup the event list here.
* gui/e-cal-popup.c (e_cal_popup_target_new_select): take model +
events rather than the calendar view.
svn path=/trunk/; revision=27553
Diffstat (limited to 'calendar/gui/e-cal-popup.c')
-rw-r--r-- | calendar/gui/e-cal-popup.c | 49 |
1 files changed, 25 insertions, 24 deletions
diff --git a/calendar/gui/e-cal-popup.c b/calendar/gui/e-cal-popup.c index 55bd7bccbf..bfa8f971f7 100644 --- a/calendar/gui/e-cal-popup.c +++ b/calendar/gui/e-cal-popup.c @@ -111,56 +111,55 @@ ECalPopup *e_cal_popup_new(const char *menuid) /** * e_cal_popup_target_new_select: + * @eabp: + * @model: The calendar model. + * @events: An array of pointers to ECalModelComponent items. These + * items must be copied. They, and the @events array will be freed by + * the popup menu automatically. * * Create a new selection popup target. * * Return value: **/ ECalPopupTargetSelect * -e_cal_popup_target_new_select(ECalPopup *eabp, ECalendarView *view) +e_cal_popup_target_new_select(ECalPopup *eabp, struct _ECalModel *model, GPtrArray *events) { ECalPopupTargetSelect *t = e_popup_target_new(&eabp->popup, E_CAL_POPUP_TARGET_SELECT, sizeof(*t)); guint32 mask = ~0; - GList *events, *l; ECal *client; gboolean read_only; - t->model = e_calendar_view_get_model(view); + t->model = model; g_object_ref(t->model); - t->events = g_ptr_array_new(); - l = events = e_calendar_view_get_selected_events(view); - for (l=events;l;l=g_list_next(l)) { - ECalendarViewEvent *event = l->data; - - if (event) - g_ptr_array_add(t->events, e_cal_model_copy_component_data(event->comp_data)); - } - - /* In reality this is only ever called with a single event or none */ + t->events = events; if (t->events->len == 0) { client = e_cal_model_get_default_client(t->model); } else { - ECalendarViewEvent *event = (ECalendarViewEvent *)events->data; + ECalModelComponent *comp_data = (ECalendarViewEvent *)t->events->pdata[0]; - mask &= ~E_CAL_POPUP_SELECT_MANY; - if (events->next == NULL) + if (t->events->len == 1) mask &= ~E_CAL_POPUP_SELECT_ONE; + else + mask &= ~E_CAL_POPUP_SELECT_MANY; - if (e_cal_util_component_has_recurrences (event->comp_data->icalcomp)) + if (icalcomponent_get_first_property (comp_data->icalcomp, ICAL_URL_PROPERTY)) + mask &= ~E_CAL_POPUP_SELECT_HASURL; + + if (e_cal_util_component_has_recurrences (comp_data->icalcomp)) mask &= ~E_CAL_POPUP_SELECT_RECURRING; else mask &= ~E_CAL_POPUP_SELECT_NONRECURRING; - if (e_cal_util_component_is_instance (event->comp_data->icalcomp)) + if (e_cal_util_component_is_instance (comp_data->icalcomp)) mask &= ~E_CAL_POPUP_SELECT_INSTANCE; - if (e_cal_util_component_has_organizer (event->comp_data->icalcomp)) { + if (e_cal_util_component_has_organizer (comp_data->icalcomp)) { ECalComponent *comp; comp = e_cal_component_new (); - e_cal_component_set_icalcomponent (comp, icalcomponent_new_clone (event->comp_data->icalcomp)); - if (!itip_organizer_is_user (comp, event->comp_data->client)) + e_cal_component_set_icalcomponent (comp, icalcomponent_new_clone (comp_data->icalcomp)); + if (!itip_organizer_is_user (comp, comp_data->client)) mask &= ~E_CAL_POPUP_SELECT_ORGANIZER; g_object_unref (comp); @@ -169,15 +168,17 @@ e_cal_popup_target_new_select(ECalPopup *eabp, ECalendarView *view) mask &= ~(E_CAL_POPUP_SELECT_ORGANIZER|E_CAL_POPUP_SELECT_NOTMEETING); } - client = event->comp_data->client; + client = comp_data->client; } - g_list_free(events); - e_cal_is_read_only(client, &read_only, NULL); if (!read_only) mask &= ~E_CAL_POPUP_SELECT_EDITABLE; + if (!e_cal_get_static_capability (client, CAL_STATIC_CAPABILITY_NO_TASK_ASSIGNMENT) + && !e_cal_get_static_capability (client, CAL_STATIC_CAPABILITY_NO_CONV_TO_ASSIGN_TASK)) + mask &= ~E_CAL_POPUP_SELECT_ASSIGNABLE; + /* This bit isn't implemented ... */ mask &= ~E_CAL_POPUP_SELECT_NOTEDITING; |