diff options
Diffstat (limited to 'calendar/gui')
-rw-r--r-- | calendar/gui/calendar-commands.c | 2 | ||||
-rw-r--r-- | calendar/gui/e-cal-view.h | 7 | ||||
-rw-r--r-- | calendar/gui/e-calendar-table.c | 10 | ||||
-rw-r--r-- | calendar/gui/e-calendar-table.h | 1 | ||||
-rw-r--r-- | calendar/gui/e-calendar-view.h | 7 | ||||
-rw-r--r-- | calendar/gui/e-tasks.c | 9 | ||||
-rw-r--r-- | calendar/gui/e-tasks.h | 1 | ||||
-rw-r--r-- | calendar/gui/tasks-control.c | 16 |
8 files changed, 52 insertions, 1 deletions
diff --git a/calendar/gui/calendar-commands.c b/calendar/gui/calendar-commands.c index 9127ab8d84..ce6c5651b3 100644 --- a/calendar/gui/calendar-commands.c +++ b/calendar/gui/calendar-commands.c @@ -544,7 +544,7 @@ calendar_control_sensitize_calendar_commands (BonoboControl *control, GnomeCalen } bonobo_ui_component_set_prop (uic, "/commands/EventOpen", "sensitive", - n_selected == 0 || read_only ? "0" : "1", + n_selected != 1 ? "0" : "1", NULL); bonobo_ui_component_set_prop (uic, "/commands/Cut", "sensitive", n_selected == 0 || read_only ? "0" : "1", diff --git a/calendar/gui/e-cal-view.h b/calendar/gui/e-cal-view.h index c224098554..8f1f1ba285 100644 --- a/calendar/gui/e-cal-view.h +++ b/calendar/gui/e-cal-view.h @@ -48,6 +48,13 @@ typedef enum { E_CALENDAR_VIEW_POS_BOTTOM_EDGE } ECalendarViewPosition; +typedef enum { + E_CAL_VIEW_MOVE_UP, + E_CAL_VIEW_MOVE_DOWN, + E_CAL_VIEW_MOVE_LEFT, + E_CAL_VIEW_MOVE_RIGHT +} ECalViewMoveDirection; + #define E_CALENDAR_VIEW_EVENT_FIELDS \ GnomeCanvasItem *canvas_item; \ ECalModelComponent *comp_data; \ diff --git a/calendar/gui/e-calendar-table.c b/calendar/gui/e-calendar-table.c index 4200f2421b..1fa9b9c0b2 100644 --- a/calendar/gui/e-calendar-table.c +++ b/calendar/gui/e-calendar-table.c @@ -589,6 +589,16 @@ e_calendar_table_get_table (ECalendarTable *cal_table) return e_table_scrolled_get_table (E_TABLE_SCROLLED (cal_table->etable)); } +void +e_calendar_table_open_selected (ECalendarTable *cal_table) +{ + ECalModelComponent *comp_data; + + comp_data = get_selected_comp (cal_table); + if (comp_data != NULL) + open_task (cal_table, comp_data, FALSE); +} + /** * e_calendar_table_complete_selected: * @cal_table: A calendar table diff --git a/calendar/gui/e-calendar-table.h b/calendar/gui/e-calendar-table.h index 2cff1bead3..1aebd430b8 100644 --- a/calendar/gui/e-calendar-table.h +++ b/calendar/gui/e-calendar-table.h @@ -76,6 +76,7 @@ ECalModel *e_calendar_table_get_model (ECalendarTable *cal_table); ETable *e_calendar_table_get_table (ECalendarTable *cal_table); +void e_calendar_table_open_selected (ECalendarTable *cal_table); void e_calendar_table_complete_selected (ECalendarTable *cal_table); void e_calendar_table_delete_selected (ECalendarTable *cal_table); diff --git a/calendar/gui/e-calendar-view.h b/calendar/gui/e-calendar-view.h index c224098554..8f1f1ba285 100644 --- a/calendar/gui/e-calendar-view.h +++ b/calendar/gui/e-calendar-view.h @@ -48,6 +48,13 @@ typedef enum { E_CALENDAR_VIEW_POS_BOTTOM_EDGE } ECalendarViewPosition; +typedef enum { + E_CAL_VIEW_MOVE_UP, + E_CAL_VIEW_MOVE_DOWN, + E_CAL_VIEW_MOVE_LEFT, + E_CAL_VIEW_MOVE_RIGHT +} ECalViewMoveDirection; + #define E_CALENDAR_VIEW_EVENT_FIELDS \ GnomeCanvasItem *canvas_item; \ ECalModelComponent *comp_data; \ diff --git a/calendar/gui/e-tasks.c b/calendar/gui/e-tasks.c index 10d180ef77..b092fc5cfe 100644 --- a/calendar/gui/e-tasks.c +++ b/calendar/gui/e-tasks.c @@ -804,6 +804,15 @@ backend_error_cb (ECal *client, const char *message, gpointer data) } void +e_tasks_open_task (ETasks *tasks) +{ + ECalendarTable *cal_table; + + cal_table = e_tasks_get_calendar_table (tasks); + e_calendar_table_open_selected (cal_table); +} + +void e_tasks_new_task (ETasks *tasks) { ETasksPrivate *priv; diff --git a/calendar/gui/e-tasks.h b/calendar/gui/e-tasks.h index 10e79ef8c3..4b6f3a6b75 100644 --- a/calendar/gui/e-tasks.h +++ b/calendar/gui/e-tasks.h @@ -69,6 +69,7 @@ gboolean e_tasks_remove_todo_uri (ETasks *tasks, const char *str_uri); gboolean e_tasks_set_default_uri (ETasks *tasks, const char *str_uri); ECal *e_tasks_get_default_client (ETasks *tasks); +void e_tasks_open_task (ETasks *tasks); void e_tasks_new_task (ETasks *tasks); void e_tasks_complete_selected (ETasks *tasks); void e_tasks_delete_selected (ETasks *tasks); diff --git a/calendar/gui/tasks-control.c b/calendar/gui/tasks-control.c index fc4b560f76..aa63f91519 100644 --- a/calendar/gui/tasks-control.c +++ b/calendar/gui/tasks-control.c @@ -71,6 +71,9 @@ static void tasks_control_set_property (BonoboPropertyBag *bag, static void tasks_control_activate_cb (BonoboControl *control, gboolean activate, gpointer user_data); +static void tasks_control_open_task_cmd (BonoboUIComponent *uic, + gpointer data, + const char *path); static void tasks_control_new_task_cmd (BonoboUIComponent *uic, gpointer data, const char *path); @@ -246,6 +249,9 @@ tasks_control_sensitize_commands (BonoboControl *control, ETasks *tasks, int n_s model = e_calendar_table_get_model (e_tasks_get_calendar_table (tasks)); e_cal_is_read_only (e_cal_model_get_default_client (model), &read_only, NULL); + bonobo_ui_component_set_prop (uic, "/commands/TasksOpenTask", "sensitive", + n_selected != 1 ? "0" : "1", + NULL); bonobo_ui_component_set_prop (uic, "/commands/TasksCut", "sensitive", n_selected == 0 || read_only ? "0" : "1", NULL); @@ -278,6 +284,7 @@ selection_changed_cb (ETasks *tasks, int n_selected, gpointer data) } static BonoboUIVerb verbs [] = { + BONOBO_UI_VERB ("TasksOpenTask", tasks_control_open_task_cmd), BONOBO_UI_VERB ("TasksNewTask", tasks_control_new_task_cmd), BONOBO_UI_VERB ("TasksCut", tasks_control_cut_cmd), BONOBO_UI_VERB ("TasksCopy", tasks_control_copy_cmd), @@ -359,6 +366,15 @@ tasks_control_deactivate (BonoboControl *control, ETasks *tasks) bonobo_ui_component_unset_container (uic, NULL); } +static void tasks_control_open_task_cmd (BonoboUIComponent *uic, + gpointer data, + const char *path) +{ + ETasks *tasks; + + tasks = E_TASKS (data); + e_tasks_open_task (tasks); +} static void tasks_control_new_task_cmd (BonoboUIComponent *uic, |