aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/e-calendar-table.c
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui/e-calendar-table.c')
-rw-r--r--calendar/gui/e-calendar-table.c481
1 files changed, 481 insertions, 0 deletions
diff --git a/calendar/gui/e-calendar-table.c b/calendar/gui/e-calendar-table.c
new file mode 100644
index 0000000000..c98b17f729
--- /dev/null
+++ b/calendar/gui/e-calendar-table.c
@@ -0,0 +1,481 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+
+/*
+ * Author :
+ * Damon Chaplin <damon@helixcode.com>
+ *
+ * Copyright 2000, Helix Code, Inc.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+ * USA
+ */
+
+/*
+ * ECalendarTable - displays the iCalendar objects in a table (an ETable).
+ * Used for calendar events and tasks.
+ */
+
+#include <config.h>
+#include <gdk/gdkkeysyms.h>
+#include <libgnomeui/gnome-popup-menu.h>
+#include <e-table/e-table-scrolled.h>
+#include <e-table/e-cell-checkbox.h>
+#include <e-table/e-cell-toggle.h>
+#include <e-table/e-cell-text.h>
+#include "e-calendar-table.h"
+#include "calendar-model.h"
+
+/* Pixmaps. */
+#include "task.xpm"
+#include "task-recurring.xpm"
+#include "task-assigned.xpm"
+#include "task-assigned-to.xpm"
+
+#include <e-table/check-filled.xpm>
+
+
+static void e_calendar_table_class_init (ECalendarTableClass *class);
+static void e_calendar_table_init (ECalendarTable *cal_table);
+static void e_calendar_table_destroy (GtkObject *object);
+
+static void e_calendar_table_on_double_click (ETable *table,
+ gint row,
+ ECalendarTable *cal_table);
+static gint e_calendar_table_on_right_click (ETable *table,
+ gint row,
+ gint col,
+ GdkEventButton *event,
+ ECalendarTable *cal_table);
+static void e_calendar_table_on_open_task (GtkWidget *menuitem,
+ gpointer data);
+static void e_calendar_table_on_mark_task_complete (GtkWidget *menuitem,
+ gpointer data);
+static void e_calendar_table_on_delete_task (GtkWidget *menuitem,
+ gpointer data);
+static gint e_calendar_table_on_key_press (ETable *table,
+ gint row,
+ gint col,
+ GdkEventKey *event,
+ ECalendarTable *cal_table);
+
+static void e_calendar_table_open_task (ECalendarTable *cal_table,
+ gint row);
+
+/* The icons to represent the task. */
+#define E_CALENDAR_MODEL_NUM_ICONS 4
+static char** icon_xpm_data[E_CALENDAR_MODEL_NUM_ICONS] = {
+ task_xpm, task_recurring_xpm, task_assigned_xpm, task_assigned_to_xpm
+};
+static GdkPixbuf* icon_pixbufs[E_CALENDAR_MODEL_NUM_ICONS] = { 0 };
+
+static GtkTableClass *parent_class;
+
+
+GtkType
+e_calendar_table_get_type (void)
+{
+ static GtkType e_calendar_table_type = 0;
+
+ if (!e_calendar_table_type){
+ GtkTypeInfo e_calendar_table_info = {
+ "ECalendarTable",
+ sizeof (ECalendarTable),
+ sizeof (ECalendarTableClass),
+ (GtkClassInitFunc) e_calendar_table_class_init,
+ (GtkObjectInitFunc) e_calendar_table_init,
+ NULL, /* reserved 1 */
+ NULL, /* reserved 2 */
+ (GtkClassInitFunc) NULL
+ };
+
+ parent_class = gtk_type_class (GTK_TYPE_TABLE);
+ e_calendar_table_type = gtk_type_unique (GTK_TYPE_TABLE,
+ &e_calendar_table_info);
+ }
+
+ return e_calendar_table_type;
+}
+
+
+static void
+e_calendar_table_class_init (ECalendarTableClass *class)
+{
+ GtkObjectClass *object_class;
+ GtkWidgetClass *widget_class;
+
+ object_class = (GtkObjectClass *) class;
+ widget_class = (GtkWidgetClass *) class;
+
+ /* Method override */
+ object_class->destroy = e_calendar_table_destroy;
+
+#if 0
+ widget_class->realize = e_calendar_table_realize;
+ widget_class->unrealize = e_calendar_table_unrealize;
+ widget_class->style_set = e_calendar_table_style_set;
+ widget_class->size_allocate = e_calendar_table_size_allocate;
+ widget_class->focus_in_event = e_calendar_table_focus_in;
+ widget_class->focus_out_event = e_calendar_table_focus_out;
+ widget_class->key_press_event = e_calendar_table_key_press;
+#endif
+}
+
+
+#define E_CALENDAR_TABLE_SPEC \
+ "<ETableSpecification click-to-add=\"1\">" \
+ "<columns-shown>" \
+ "<column> 16 </column>" \
+ "<column> 17 </column>" \
+ "<column> 13 </column>" \
+ "</columns-shown>" \
+ "<grouping> </grouping>" \
+ "</ETableSpecification>"
+
+#define e_cell_time_new e_cell_text_new
+#define e_cell_time_compare g_str_compare
+#define e_cell_geo_pos_new e_cell_text_new
+#define e_cell_geo_pos_compare g_str_compare
+
+static void
+e_calendar_table_init (ECalendarTable *cal_table)
+{
+ GtkWidget *table;
+ ETableModel *model;
+ ETableHeader *header;
+ ECell *cell;
+ ETableCol *column;
+ gint i;
+ GdkPixbuf *pixbuf;
+ GdkColormap *colormap;
+ gboolean success[E_CALENDAR_TABLE_COLOR_LAST];
+ gint nfailed;
+
+ /* Allocate the colors we need. */
+ colormap = gtk_widget_get_colormap (GTK_WIDGET (cal_table));
+
+ cal_table->colors[E_CALENDAR_TABLE_COLOR_OVERDUE].red = 65535;
+ cal_table->colors[E_CALENDAR_TABLE_COLOR_OVERDUE].green = 0;
+ cal_table->colors[E_CALENDAR_TABLE_COLOR_OVERDUE].blue = 0;
+
+ nfailed = gdk_colormap_alloc_colors (colormap, cal_table->colors,
+ E_CALENDAR_TABLE_COLOR_LAST,
+ FALSE, TRUE, success);
+ if (nfailed)
+ g_warning ("Failed to allocate all colors");
+
+
+ cal_table->model = calendar_model_new ();
+ model = E_TABLE_MODEL (cal_table->model);
+
+ header = e_table_header_new ();
+ gtk_object_ref (GTK_OBJECT (header));
+ gtk_object_sink (GTK_OBJECT (header));
+
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_COMMENT, _("Comment"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_COMMENT);
+
+ cell = e_cell_time_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_COMPLETED, _("Completed"),
+ 1.0, 10, cell, e_cell_time_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_COMPLETED);
+
+ cell = e_cell_time_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_CREATED, _("Created"),
+ 1.0, 10, cell, e_cell_time_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_CREATED);
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_DESCRIPTION, _("Description"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_DESCRIPTION);
+
+ cell = e_cell_time_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_DTSTAMP, _("Timestamp"),
+ 1.0, 10, cell, e_cell_time_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_DTSTAMP);
+
+ cell = e_cell_time_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_DTSTART, _("Start Date"),
+ 1.0, 10, cell, e_cell_time_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_DTSTART);
+
+ cell = e_cell_time_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_DTEND, _("End Date"),
+ 1.0, 10, cell, e_cell_time_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_DTEND);
+
+ cell = e_cell_geo_pos_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_GEO, _("Geographical Position"),
+ 1.0, 10, cell, e_cell_geo_pos_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_GEO);
+
+ cell = e_cell_time_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_LAST_MOD, _("Last Modification Date"),
+ 1.0, 10, cell, e_cell_time_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_LAST_MOD);
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_LOCATION, _("Location"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_LOCATION);
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_ORGANIZER, _("Organizer"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_ORGANIZER);
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_PERCENT, _("% Complete"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_PERCENT);
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_PRIORITY, _("Priority"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_PRIORITY);
+
+ /* FIXME: This should really be 'Subject' in the big view. */
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ gtk_object_set (GTK_OBJECT (cell),
+ "strikeout_column", ICAL_OBJECT_FIELD_COMPLETE,
+ "bold_column", ICAL_OBJECT_FIELD_OVERDUE,
+ "color_column", ICAL_OBJECT_FIELD_COLOR,
+ NULL);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_SUMMARY, _("TaskPad"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_SUMMARY);
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_URL, _("URL"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_URL);
+
+ cell = e_cell_text_new (model, NULL, GTK_JUSTIFY_LEFT);
+ column = e_table_col_new (ICAL_OBJECT_FIELD_HAS_ALARMS, _("Reminder"),
+ 1.0, 10, cell, g_str_compare, TRUE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_HAS_ALARMS);
+
+ /* Create pixmaps. */
+ if (!icon_pixbufs[0]) {
+ for (i = 0; i < E_CALENDAR_MODEL_NUM_ICONS; i++) {
+ icon_pixbufs[i] = gdk_pixbuf_new_from_xpm_data (
+ (const char **) icon_xpm_data[i]);
+ }
+ }
+
+ cell = e_cell_toggle_new (0, 4, icon_pixbufs);
+ column = e_table_col_new_with_pixbuf (ICAL_OBJECT_FIELD_ICON,
+ icon_pixbufs[0], 0.0, 16, cell,
+ g_int_compare, FALSE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_ICON);
+
+ cell = e_cell_checkbox_new ();
+ pixbuf = gdk_pixbuf_new_from_xpm_data ((const char **) check_filled_xpm);
+ column = e_table_col_new_with_pixbuf (ICAL_OBJECT_FIELD_COMPLETE,
+ pixbuf, 0.0, 16, cell,
+ g_int_compare, FALSE);
+ e_table_header_add_column (header, column, ICAL_OBJECT_FIELD_COMPLETE);
+
+
+ table = e_table_scrolled_new (header, model, E_CALENDAR_TABLE_SPEC);
+ gtk_object_set (GTK_OBJECT (table),
+ "click_to_add_message", "Click here to add a new Task",
+ NULL);
+ gtk_table_attach (GTK_TABLE (cal_table), table, 0, 1, 0, 1,
+ GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
+ gtk_widget_show (table);
+
+ gtk_signal_connect (GTK_OBJECT (table), "double_click",
+ GTK_SIGNAL_FUNC (e_calendar_table_on_double_click),
+ cal_table);
+ gtk_signal_connect (GTK_OBJECT (table), "right_click",
+ GTK_SIGNAL_FUNC (e_calendar_table_on_right_click),
+ cal_table);
+ gtk_signal_connect (GTK_OBJECT (table), "key_press",
+ GTK_SIGNAL_FUNC (e_calendar_table_on_key_press),
+ cal_table);
+}
+
+
+/**
+ * e_calendar_table_new:
+ * @Returns: a new #ECalendarTable.
+ *
+ * Creates a new #ECalendarTable.
+ **/
+GtkWidget *
+e_calendar_table_new (void)
+{
+ GtkWidget *cal_table;
+
+ cal_table = GTK_WIDGET (gtk_type_new (e_calendar_table_get_type ()));
+
+ return cal_table;
+}
+
+
+static void
+e_calendar_table_destroy (GtkObject *object)
+{
+ ECalendarTable *cal_table;
+
+ cal_table = E_CALENDAR_TABLE (object);
+
+
+
+ GTK_OBJECT_CLASS (parent_class)->destroy (object);
+}
+
+
+void
+e_calendar_table_set_cal_client (ECalendarTable *cal_table,
+ CalClient *client)
+{
+ g_print ("In e_calendar_table_set_cal_client\n");
+
+ calendar_model_set_cal_client (cal_table->model, client,
+ CALOBJ_TYPE_TODO);
+}
+
+
+static void
+e_calendar_table_on_double_click (ETable *table,
+ gint row,
+ ECalendarTable *cal_table)
+{
+ g_print ("In e_calendar_table_on_double_click row:%i\n", row);
+
+ e_calendar_table_open_task (cal_table, row);
+}
+
+
+static GnomeUIInfo e_calendar_table_popup_uiinfo[] = {
+ { GNOME_APP_UI_ITEM, N_("Open..."),
+ N_("Open the task"), e_calendar_table_on_open_task,
+ NULL, NULL, 0, 0, 0, 0 },
+ { GNOME_APP_UI_ITEM, N_("Mark Complete"),
+ N_("Mark the task complete"), e_calendar_table_on_mark_task_complete,
+ NULL, NULL, 0, 0, 0, 0 },
+ { GNOME_APP_UI_ITEM, N_("Delete"),
+ N_("Delete the task"), e_calendar_table_on_delete_task,
+ NULL, NULL, 0, 0, 0, 0 },
+
+ GNOMEUIINFO_END
+};
+
+
+typedef struct _ECalendarMenuData ECalendarMenuData;
+struct _ECalendarMenuData {
+ ECalendarTable *cal_table;
+ gint row;
+};
+
+static gint
+e_calendar_table_on_right_click (ETable *table,
+ gint row,
+ gint col,
+ GdkEventButton *event,
+ ECalendarTable *cal_table)
+{
+ ECalendarMenuData menu_data;
+ GtkWidget *popup_menu;
+
+ menu_data.cal_table = cal_table;
+ menu_data.row = row;
+
+ popup_menu = gnome_popup_menu_new (e_calendar_table_popup_uiinfo);
+ gnome_popup_menu_do_popup_modal (popup_menu, NULL, NULL, event,
+ &menu_data);
+
+ gtk_widget_destroy (popup_menu);
+
+ return TRUE;
+}
+
+
+static void
+e_calendar_table_on_open_task (GtkWidget *menuitem,
+ gpointer data)
+{
+ ECalendarMenuData *menu_data = (ECalendarMenuData*) data;
+
+ e_calendar_table_open_task (menu_data->cal_table,
+ menu_data->row);
+}
+
+
+static void
+e_calendar_table_on_mark_task_complete (GtkWidget *menuitem,
+ gpointer data)
+{
+ ECalendarMenuData *menu_data = (ECalendarMenuData*) data;
+
+ calendar_model_mark_task_complete (menu_data->cal_table->model,
+ menu_data->row);
+}
+
+
+static void
+e_calendar_table_on_delete_task (GtkWidget *menuitem,
+ gpointer data)
+{
+ ECalendarMenuData *menu_data = (ECalendarMenuData*) data;
+
+ calendar_model_delete_task (menu_data->cal_table->model,
+ menu_data->row);
+}
+
+
+
+static gint
+e_calendar_table_on_key_press (ETable *table,
+ gint row,
+ gint col,
+ GdkEventKey *event,
+ ECalendarTable *cal_table)
+{
+ g_print ("In e_calendar_table_on_key_press\n");
+
+ if (event->keyval == GDK_Delete) {
+ g_print (" delete key!!!\n");
+
+ calendar_model_delete_task (cal_table->model, row);
+ }
+
+ return FALSE;
+}
+
+
+static void
+e_calendar_table_open_task (ECalendarTable *cal_table,
+ gint row)
+{
+ iCalObject *ico;
+
+#if 0
+ task_editor_new ();
+ /* FIXME: Set iCalObject to edit. */
+#endif
+
+ ico = calendar_model_get_cal_object (cal_table->model, row);
+
+ gncal_todo_edit (calendar_model_get_cal_client (cal_table->model),
+ ico);
+}
+
+