aboutsummaryrefslogtreecommitdiffstats
path: root/calendar
diff options
context:
space:
mode:
Diffstat (limited to 'calendar')
-rw-r--r--calendar/ChangeLog12
-rw-r--r--calendar/gui/main.c4
-rw-r--r--calendar/gui/year-view.c224
-rw-r--r--calendar/main.c4
-rw-r--r--calendar/year-view.c224
5 files changed, 442 insertions, 26 deletions
diff --git a/calendar/ChangeLog b/calendar/ChangeLog
index 8440184509..11d14a3d89 100644
--- a/calendar/ChangeLog
+++ b/calendar/ChangeLog
@@ -1,3 +1,15 @@
+1998-09-24 Federico Mena Quintero <federico@nuclecu.unam.mx>
+
+ * year-view.c (do_popup_menu): New function to execute the popup
+ menu in the year view.
+ (day_event): Invoke the popup menu with the context set to days.
+ (new_appointment): New function to create a new appointment from
+ the year view.
+ (do_jump): New function to do the appropriate view/date jumping
+ from the popup menu.
+
+ * main.c: Fixed two icons in the File menu.
+
1998-09-21 Federico Mena Quintero <federico@nuclecu.unam.mx>
* main.c: Added underlined shortcuts and accelerators to the main menu.
diff --git a/calendar/gui/main.c b/calendar/gui/main.c
index e47eb3e98c..d8a5af2b87 100644
--- a/calendar/gui/main.c
+++ b/calendar/gui/main.c
@@ -399,7 +399,7 @@ static GnomeUIInfo gnome_cal_file_menu [] = {
{ GNOME_APP_UI_ITEM, N_("_Save calendar"), NULL, save_calendar_cmd, NULL, NULL,
GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_SAVE, 's', GDK_CONTROL_MASK, NULL },
{ GNOME_APP_UI_ITEM, N_("Save calendar _as..."), NULL, save_as_calendar_cmd, NULL, NULL,
- GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_SAVE, 0, 0, NULL },
+ GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_SAVE_AS, 0, 0, NULL },
GNOMEUIINFO_SEPARATOR,
@@ -409,7 +409,7 @@ static GnomeUIInfo gnome_cal_file_menu [] = {
GNOMEUIINFO_SEPARATOR,
{ GNOME_APP_UI_ITEM, N_("_Close this calendar"), NULL, close_cmd, NULL, NULL,
- GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_EXIT, 'w', GDK_CONTROL_MASK, NULL },
+ GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_CLOSE, 'w', GDK_CONTROL_MASK, NULL },
{ GNOME_APP_UI_ITEM, N_("E_xit"), NULL, quit_cmd, NULL, NULL,
GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_EXIT, 'x', GDK_CONTROL_MASK, NULL },
diff --git a/calendar/gui/year-view.c b/calendar/gui/year-view.c
index 4bf330c1fd..2027cac398 100644
--- a/calendar/gui/year-view.c
+++ b/calendar/gui/year-view.c
@@ -8,7 +8,8 @@
#include <config.h>
#include <gtk/gtkmain.h>
-#include <libgnomeui/gnome-canvas-text.h>
+#include <gnome.h>
+#include "eventedit.h"
#include "year-view.h"
#include "main.h"
#include "mark.h"
@@ -155,28 +156,224 @@ need_resize (YearView *yv)
yv->idle_id = gtk_idle_add (idle_handler, yv);
}
+/* Callback used to destroy the year view's popup menu when the year view itself is destroyed */
+static void
+destroy_menu (GtkWidget *widget, gpointer data)
+{
+ gtk_widget_destroy (GTK_WIDGET (data));
+}
+
+/* Create a new appointment in the highlighted day from the year view's popup menu */
+static void
+new_appointment (GtkWidget *widget, gpointer data)
+{
+ YearView *yv;
+ GtkWidget *ee;
+ time_t *t;
+ struct tm tm;
+ iCalObject *ico;
+
+ yv = YEAR_VIEW (data);
+
+ /* Get the time data from the menu item */
+
+ t = gtk_object_get_data (GTK_OBJECT (widget), "time_data");
+ tm = *localtime (t);
+
+ ico = ical_new ("", user_name, "");
+ ico->new = TRUE;
+
+ /* Set the start time of the event to the beginning of the day */
+
+ tm.tm_hour = day_begin;
+ tm.tm_min = 0;
+ tm.tm_sec = 0;
+ ico->dtstart = mktime (&tm);
+
+ /* Set the end time of the event to the end of the day */
+
+ tm.tm_hour = day_end;
+ ico->dtend = mktime (&tm);
+
+ /* Launch the event editor */
+
+ ee = event_editor_new (yv->calendar, ico);
+ gtk_widget_show (ee);
+}
+
+/* Convenience functions to jump to a view and set the time */
+static void
+do_jump (GtkWidget *widget, gpointer data, char *view_name)
+{
+ YearView *yv;
+ time_t *t;
+
+ yv = YEAR_VIEW (data);
+
+ /* Get the time data from the menu item */
+
+ t = gtk_object_get_data (GTK_OBJECT (widget), "time_data");
+
+ /* Set the view and time */
+
+ gnome_calendar_set_view (yv->calendar, view_name);
+ gnome_calendar_goto (yv->calendar, *t);
+}
+
+/* The following three callbacks set the view in the calendar and change the time */
+
+static void
+jump_to_day (GtkWidget *widget, gpointer data)
+{
+ do_jump (widget, data, "dayview");
+}
+
+static void
+jump_to_week (GtkWidget *widget, gpointer data)
+{
+ do_jump (widget, data, "weekview");
+}
+
+static void
+jump_to_month (GtkWidget *widget, gpointer data)
+{
+ do_jump (widget, data, "monthview");
+}
+
+/* Information for the year view's popup menu */
+static GnomeUIInfo yv_popup_menu[] = {
+ GNOMEUIINFO_ITEM_STOCK ("_New appointment in this day...", NULL, new_appointment, GNOME_STOCK_MENU_NEW),
+
+ GNOMEUIINFO_SEPARATOR,
+
+ GNOMEUIINFO_ITEM_STOCK ("Jump to this _day", NULL, jump_to_day, GNOME_STOCK_MENU_JUMP_TO),
+ GNOMEUIINFO_ITEM_STOCK ("Jump to this _week", NULL, jump_to_week, GNOME_STOCK_MENU_JUMP_TO),
+ GNOMEUIINFO_ITEM_STOCK ("Jump to this _month", NULL, jump_to_month, GNOME_STOCK_MENU_JUMP_TO),
+ GNOMEUIINFO_END
+};
+
+/* Returns the popup menu cooresponding to the specified year view. If the menu has not been
+ * created yet, it creates it and attaches it to the year view.
+ */
+static GtkWidget *
+get_popup_menu (YearView *yv)
+{
+ GtkWidget *menu;
+
+ menu = gtk_object_get_data (GTK_OBJECT (yv), "popup_menu");
+
+ if (!menu) {
+ menu = gnome_popup_menu_new (yv_popup_menu);
+ gtk_object_set_data (GTK_OBJECT (yv), "popup_menu", menu);
+ gtk_signal_connect (GTK_OBJECT (yv), "destroy",
+ (GtkSignalFunc) destroy_menu,
+ menu);
+ }
+
+ return menu;
+}
+
+/* Executes the year view's popup menu. It may disable/enable some menu items based on the
+ * specified flags. A pointer to a time_t value containing the specified time data is set in the
+ * "time_data" object data key of the menu items.
+ */
+static void
+do_popup_menu (YearView *yv, GdkEventButton *event, int allow_new, int allow_day, int allow_week, int allow_month,
+ int year, int month, int day)
+{
+ GtkWidget *menu;
+ static time_t t;
+
+ menu = get_popup_menu (yv);
+
+ /* Enable/disable items as appropriate */
+
+ gtk_widget_set_sensitive (yv_popup_menu[0].widget, allow_new);
+ gtk_widget_set_sensitive (yv_popup_menu[2].widget, allow_day);
+ gtk_widget_set_sensitive (yv_popup_menu[3].widget, allow_week);
+ gtk_widget_set_sensitive (yv_popup_menu[4].widget, allow_month);
+
+ /* Set the day item relevant to the context */
+
+ t = time_from_day (year, month, day);
+
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[0].widget), "time_data", &t);
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[2].widget), "time_data", &t);
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[3].widget), "time_data", &t);
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[4].widget), "time_data", &t);
+
+ gnome_popup_menu_do_popup (menu, NULL, NULL, event, yv);
+}
+
/* Event handler for days in the year's month items */
static gint
day_event (GnomeCanvasItem *item, GdkEvent *event, gpointer data)
{
YearView *yv;
- GnomeCanvasItem *mitem;
+ GnomeMonthItem *mitem;
int child_num, day;
- mitem = data;
- child_num = gnome_month_item_child2num (GNOME_MONTH_ITEM (mitem), item);
- day = gnome_month_item_num2day (GNOME_MONTH_ITEM (mitem), child_num);
+ mitem = GNOME_MONTH_ITEM (data);
+ child_num = gnome_month_item_child2num (mitem, item);
+ day = gnome_month_item_num2day (mitem, child_num);
- yv = gtk_object_get_user_data (GTK_OBJECT (mitem));
+ yv = YEAR_VIEW (item->canvas);
switch (event->type) {
case GDK_BUTTON_PRESS:
- if ((event->button.button == 1) && (day != 0))
+ if (day == 0)
+ break;
+
+ if (event->button.button == 1) {
gnome_calendar_dayjump (yv->calendar,
- time_from_day (GNOME_MONTH_ITEM (mitem)->year,
- GNOME_MONTH_ITEM (mitem)->month,
+ time_from_day (mitem->year,
+ mitem->month,
day));
+ return TRUE;
+ } else if (event->button.button == 3) {
+ do_popup_menu (yv, (GdkEventButton *) event, TRUE, TRUE, TRUE, TRUE,
+ mitem->year, mitem->month, day);
+
+ /* We have to stop the signal emission because mark.c will grab it too and
+ * set the return value to FALSE. Blargh.
+ */
+ gtk_signal_emit_stop_by_name (GTK_OBJECT (item), "event");
+ return TRUE;
+ }
+
+ break;
+
+ default:
break;
+ }
+
+ return FALSE;
+}
+
+/* Event handler for whole month items */
+static gint
+month_event (GnomeCanvasItem *item, GdkEvent *event, gpointer data)
+{
+ YearView *yv;
+ GnomeMonthItem *mitem;
+
+ mitem = GNOME_MONTH_ITEM (item);
+
+ yv = YEAR_VIEW (item->canvas);
+
+ switch (event->type) {
+ case GDK_BUTTON_PRESS:
+ if (event->button.button != 3)
+ break;
+
+ do_popup_menu (yv, (GdkEventButton *) event, FALSE, FALSE, FALSE, TRUE,
+ mitem->year, mitem->month, 1);
+
+ /* We have to stop the signal emission because mark.c will grab it too and
+ * set the return value to FALSE. Blargh.
+ */
+ gtk_signal_emit_stop_by_name (GTK_OBJECT (item), "event");
+ return TRUE;
default:
break;
@@ -195,7 +392,7 @@ setup_month_item (YearView *yv, int n)
mitem = yv->mitems[n];
- /* Connect signals */
+ /* Connect the day signals */
for (i = 0; i < 42; i++) {
item = gnome_month_item_num2child (GNOME_MONTH_ITEM (mitem), GNOME_MONTH_ITEM_DAY_GROUP + i);
@@ -203,6 +400,12 @@ setup_month_item (YearView *yv, int n)
(GtkSignalFunc) day_event,
mitem);
}
+
+ /* Connect the month signals */
+
+ gtk_signal_connect (GTK_OBJECT (mitem), "event",
+ (GtkSignalFunc) month_event,
+ NULL);
}
static void
@@ -242,7 +445,6 @@ year_view_init (YearView *yv)
/* Month item */
yv->mitems[i] = gnome_month_item_new (gnome_canvas_root (GNOME_CANVAS (yv)));
- gtk_object_set_user_data (GTK_OBJECT (yv->mitems[i]), yv);
gnome_canvas_item_set (yv->mitems[i],
"anchor", GTK_ANCHOR_NW,
"start_on_monday", week_starts_on_monday,
diff --git a/calendar/main.c b/calendar/main.c
index e47eb3e98c..d8a5af2b87 100644
--- a/calendar/main.c
+++ b/calendar/main.c
@@ -399,7 +399,7 @@ static GnomeUIInfo gnome_cal_file_menu [] = {
{ GNOME_APP_UI_ITEM, N_("_Save calendar"), NULL, save_calendar_cmd, NULL, NULL,
GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_SAVE, 's', GDK_CONTROL_MASK, NULL },
{ GNOME_APP_UI_ITEM, N_("Save calendar _as..."), NULL, save_as_calendar_cmd, NULL, NULL,
- GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_SAVE, 0, 0, NULL },
+ GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_SAVE_AS, 0, 0, NULL },
GNOMEUIINFO_SEPARATOR,
@@ -409,7 +409,7 @@ static GnomeUIInfo gnome_cal_file_menu [] = {
GNOMEUIINFO_SEPARATOR,
{ GNOME_APP_UI_ITEM, N_("_Close this calendar"), NULL, close_cmd, NULL, NULL,
- GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_EXIT, 'w', GDK_CONTROL_MASK, NULL },
+ GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_CLOSE, 'w', GDK_CONTROL_MASK, NULL },
{ GNOME_APP_UI_ITEM, N_("E_xit"), NULL, quit_cmd, NULL, NULL,
GNOME_APP_PIXMAP_STOCK, GNOME_STOCK_MENU_EXIT, 'x', GDK_CONTROL_MASK, NULL },
diff --git a/calendar/year-view.c b/calendar/year-view.c
index 4bf330c1fd..2027cac398 100644
--- a/calendar/year-view.c
+++ b/calendar/year-view.c
@@ -8,7 +8,8 @@
#include <config.h>
#include <gtk/gtkmain.h>
-#include <libgnomeui/gnome-canvas-text.h>
+#include <gnome.h>
+#include "eventedit.h"
#include "year-view.h"
#include "main.h"
#include "mark.h"
@@ -155,28 +156,224 @@ need_resize (YearView *yv)
yv->idle_id = gtk_idle_add (idle_handler, yv);
}
+/* Callback used to destroy the year view's popup menu when the year view itself is destroyed */
+static void
+destroy_menu (GtkWidget *widget, gpointer data)
+{
+ gtk_widget_destroy (GTK_WIDGET (data));
+}
+
+/* Create a new appointment in the highlighted day from the year view's popup menu */
+static void
+new_appointment (GtkWidget *widget, gpointer data)
+{
+ YearView *yv;
+ GtkWidget *ee;
+ time_t *t;
+ struct tm tm;
+ iCalObject *ico;
+
+ yv = YEAR_VIEW (data);
+
+ /* Get the time data from the menu item */
+
+ t = gtk_object_get_data (GTK_OBJECT (widget), "time_data");
+ tm = *localtime (t);
+
+ ico = ical_new ("", user_name, "");
+ ico->new = TRUE;
+
+ /* Set the start time of the event to the beginning of the day */
+
+ tm.tm_hour = day_begin;
+ tm.tm_min = 0;
+ tm.tm_sec = 0;
+ ico->dtstart = mktime (&tm);
+
+ /* Set the end time of the event to the end of the day */
+
+ tm.tm_hour = day_end;
+ ico->dtend = mktime (&tm);
+
+ /* Launch the event editor */
+
+ ee = event_editor_new (yv->calendar, ico);
+ gtk_widget_show (ee);
+}
+
+/* Convenience functions to jump to a view and set the time */
+static void
+do_jump (GtkWidget *widget, gpointer data, char *view_name)
+{
+ YearView *yv;
+ time_t *t;
+
+ yv = YEAR_VIEW (data);
+
+ /* Get the time data from the menu item */
+
+ t = gtk_object_get_data (GTK_OBJECT (widget), "time_data");
+
+ /* Set the view and time */
+
+ gnome_calendar_set_view (yv->calendar, view_name);
+ gnome_calendar_goto (yv->calendar, *t);
+}
+
+/* The following three callbacks set the view in the calendar and change the time */
+
+static void
+jump_to_day (GtkWidget *widget, gpointer data)
+{
+ do_jump (widget, data, "dayview");
+}
+
+static void
+jump_to_week (GtkWidget *widget, gpointer data)
+{
+ do_jump (widget, data, "weekview");
+}
+
+static void
+jump_to_month (GtkWidget *widget, gpointer data)
+{
+ do_jump (widget, data, "monthview");
+}
+
+/* Information for the year view's popup menu */
+static GnomeUIInfo yv_popup_menu[] = {
+ GNOMEUIINFO_ITEM_STOCK ("_New appointment in this day...", NULL, new_appointment, GNOME_STOCK_MENU_NEW),
+
+ GNOMEUIINFO_SEPARATOR,
+
+ GNOMEUIINFO_ITEM_STOCK ("Jump to this _day", NULL, jump_to_day, GNOME_STOCK_MENU_JUMP_TO),
+ GNOMEUIINFO_ITEM_STOCK ("Jump to this _week", NULL, jump_to_week, GNOME_STOCK_MENU_JUMP_TO),
+ GNOMEUIINFO_ITEM_STOCK ("Jump to this _month", NULL, jump_to_month, GNOME_STOCK_MENU_JUMP_TO),
+ GNOMEUIINFO_END
+};
+
+/* Returns the popup menu cooresponding to the specified year view. If the menu has not been
+ * created yet, it creates it and attaches it to the year view.
+ */
+static GtkWidget *
+get_popup_menu (YearView *yv)
+{
+ GtkWidget *menu;
+
+ menu = gtk_object_get_data (GTK_OBJECT (yv), "popup_menu");
+
+ if (!menu) {
+ menu = gnome_popup_menu_new (yv_popup_menu);
+ gtk_object_set_data (GTK_OBJECT (yv), "popup_menu", menu);
+ gtk_signal_connect (GTK_OBJECT (yv), "destroy",
+ (GtkSignalFunc) destroy_menu,
+ menu);
+ }
+
+ return menu;
+}
+
+/* Executes the year view's popup menu. It may disable/enable some menu items based on the
+ * specified flags. A pointer to a time_t value containing the specified time data is set in the
+ * "time_data" object data key of the menu items.
+ */
+static void
+do_popup_menu (YearView *yv, GdkEventButton *event, int allow_new, int allow_day, int allow_week, int allow_month,
+ int year, int month, int day)
+{
+ GtkWidget *menu;
+ static time_t t;
+
+ menu = get_popup_menu (yv);
+
+ /* Enable/disable items as appropriate */
+
+ gtk_widget_set_sensitive (yv_popup_menu[0].widget, allow_new);
+ gtk_widget_set_sensitive (yv_popup_menu[2].widget, allow_day);
+ gtk_widget_set_sensitive (yv_popup_menu[3].widget, allow_week);
+ gtk_widget_set_sensitive (yv_popup_menu[4].widget, allow_month);
+
+ /* Set the day item relevant to the context */
+
+ t = time_from_day (year, month, day);
+
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[0].widget), "time_data", &t);
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[2].widget), "time_data", &t);
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[3].widget), "time_data", &t);
+ gtk_object_set_data (GTK_OBJECT (yv_popup_menu[4].widget), "time_data", &t);
+
+ gnome_popup_menu_do_popup (menu, NULL, NULL, event, yv);
+}
+
/* Event handler for days in the year's month items */
static gint
day_event (GnomeCanvasItem *item, GdkEvent *event, gpointer data)
{
YearView *yv;
- GnomeCanvasItem *mitem;
+ GnomeMonthItem *mitem;
int child_num, day;
- mitem = data;
- child_num = gnome_month_item_child2num (GNOME_MONTH_ITEM (mitem), item);
- day = gnome_month_item_num2day (GNOME_MONTH_ITEM (mitem), child_num);
+ mitem = GNOME_MONTH_ITEM (data);
+ child_num = gnome_month_item_child2num (mitem, item);
+ day = gnome_month_item_num2day (mitem, child_num);
- yv = gtk_object_get_user_data (GTK_OBJECT (mitem));
+ yv = YEAR_VIEW (item->canvas);
switch (event->type) {
case GDK_BUTTON_PRESS:
- if ((event->button.button == 1) && (day != 0))
+ if (day == 0)
+ break;
+
+ if (event->button.button == 1) {
gnome_calendar_dayjump (yv->calendar,
- time_from_day (GNOME_MONTH_ITEM (mitem)->year,
- GNOME_MONTH_ITEM (mitem)->month,
+ time_from_day (mitem->year,
+ mitem->month,
day));
+ return TRUE;
+ } else if (event->button.button == 3) {
+ do_popup_menu (yv, (GdkEventButton *) event, TRUE, TRUE, TRUE, TRUE,
+ mitem->year, mitem->month, day);
+
+ /* We have to stop the signal emission because mark.c will grab it too and
+ * set the return value to FALSE. Blargh.
+ */
+ gtk_signal_emit_stop_by_name (GTK_OBJECT (item), "event");
+ return TRUE;
+ }
+
+ break;
+
+ default:
break;
+ }
+
+ return FALSE;
+}
+
+/* Event handler for whole month items */
+static gint
+month_event (GnomeCanvasItem *item, GdkEvent *event, gpointer data)
+{
+ YearView *yv;
+ GnomeMonthItem *mitem;
+
+ mitem = GNOME_MONTH_ITEM (item);
+
+ yv = YEAR_VIEW (item->canvas);
+
+ switch (event->type) {
+ case GDK_BUTTON_PRESS:
+ if (event->button.button != 3)
+ break;
+
+ do_popup_menu (yv, (GdkEventButton *) event, FALSE, FALSE, FALSE, TRUE,
+ mitem->year, mitem->month, 1);
+
+ /* We have to stop the signal emission because mark.c will grab it too and
+ * set the return value to FALSE. Blargh.
+ */
+ gtk_signal_emit_stop_by_name (GTK_OBJECT (item), "event");
+ return TRUE;
default:
break;
@@ -195,7 +392,7 @@ setup_month_item (YearView *yv, int n)
mitem = yv->mitems[n];
- /* Connect signals */
+ /* Connect the day signals */
for (i = 0; i < 42; i++) {
item = gnome_month_item_num2child (GNOME_MONTH_ITEM (mitem), GNOME_MONTH_ITEM_DAY_GROUP + i);
@@ -203,6 +400,12 @@ setup_month_item (YearView *yv, int n)
(GtkSignalFunc) day_event,
mitem);
}
+
+ /* Connect the month signals */
+
+ gtk_signal_connect (GTK_OBJECT (mitem), "event",
+ (GtkSignalFunc) month_event,
+ NULL);
}
static void
@@ -242,7 +445,6 @@ year_view_init (YearView *yv)
/* Month item */
yv->mitems[i] = gnome_month_item_new (gnome_canvas_root (GNOME_CANVAS (yv)));
- gtk_object_set_user_data (GTK_OBJECT (yv->mitems[i]), yv);
gnome_canvas_item_set (yv->mitems[i],
"anchor", GTK_ANCHOR_NW,
"start_on_monday", week_starts_on_monday,