aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui')
-rw-r--r--calendar/gui/prop.c137
1 files changed, 137 insertions, 0 deletions
diff --git a/calendar/gui/prop.c b/calendar/gui/prop.c
new file mode 100644
index 0000000000..a7d3c8162d
--- /dev/null
+++ b/calendar/gui/prop.c
@@ -0,0 +1,137 @@
+#include <config.h>
+#include <gnome.h>
+#include "main.h"
+#include "gnome-cal.h"
+
+static GtkWidget *prop_win, *r1;
+static GtkObject *sa, *ea;
+
+void
+start_changed (GtkAdjustment *sa, GtkAdjustment *ea)
+{
+ if (sa->value == ea->value){
+ sa->value -= 1.0;
+ gtk_signal_emit_by_name (GTK_OBJECT (sa), "value_changed");
+ } else if (sa->value > ea->value){
+ ea->value = sa->value + 1.0;
+ gtk_signal_emit_by_name (GTK_OBJECT (ea), "value_changed");
+ }
+}
+
+void
+end_changed (GtkAdjustment *ea, GtkAdjustment *sa)
+{
+ if (ea->value == sa->value){
+ ea->value += 1.0;
+ gtk_signal_emit_by_name (GTK_OBJECT (ea), "value_changed");
+ } else if (ea->value < sa->value){
+ sa->value = ea->value - 1.0;
+ gtk_signal_emit_by_name (GTK_OBJECT (sa), "value_changed");
+ }
+}
+
+/* justifies the text */
+static GtkWidget *
+align (GtkWidget *w, float side)
+{
+ GtkWidget *a;
+
+ a = gtk_alignment_new (side, 0.5, 1.0, 1.0);
+ gtk_container_add (GTK_CONTAINER (a), w);
+
+ return a;
+}
+
+static void
+prop_cancel (void)
+{
+ gtk_widget_destroy (prop_win);
+ prop_win = 0;
+}
+
+static void
+prop_ok (void)
+{
+ day_begin = GTK_ADJUSTMENT (sa)->value;
+ day_end = GTK_ADJUSTMENT (ea)->value;
+ gnome_config_set_int ("/calendar/Calendar/Day start", day_begin);
+ gnome_config_set_int ("/calendar/Calendar/Day end", day_end);
+
+ am_pm_flag = (GTK_TOGGLE_BUTTON (r1)->active) == 0;
+ gnome_config_set_bool ("/calendar/Calendar/AM PM flag", am_pm_flag);
+
+ gnome_config_sync ();
+
+ prop_cancel ();
+ day_range_changed ();
+}
+
+void
+properties (void)
+{
+ GtkWidget *t, *f, *l, *ds, *de;
+ GtkWidget *r2;
+ GtkWidget *ok, *cancel, *hbox;
+
+ if (prop_win)
+ return;
+
+ prop_win = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ t = gtk_table_new (0, 0, 0);
+ f = gtk_frame_new (_("Calendar global parameters"));
+ gtk_container_add (GTK_CONTAINER (prop_win), f);
+ gtk_container_add (GTK_CONTAINER (f), t);
+ gtk_container_border_width (GTK_CONTAINER (prop_win), GNOME_PAD);
+ gtk_container_border_width (GTK_CONTAINER (t), GNOME_PAD);
+
+ l = gtk_label_new (_("Day start:"));
+ gtk_table_attach (GTK_TABLE (t), l,
+ 0, 1, 0, 1, 0, 0, 0, 0);
+ sa = gtk_adjustment_new (day_begin, 0.0, 25.00, 1.0, 1.0, 1.0);
+ ds = gtk_hscale_new (GTK_ADJUSTMENT (sa));
+ gtk_scale_set_digits (GTK_SCALE (ds), 0);
+ gtk_table_attach (GTK_TABLE (t), ds,
+ 1, 2, 0, 1, GTK_FILL | GTK_EXPAND, 0, 0, 0);
+
+ l = gtk_label_new (_("Day end:"));
+ gtk_table_attach (GTK_TABLE (t), l,
+ 0, 1, 1, 2, 0, 0, 0, 0);
+ ea = gtk_adjustment_new (day_end, 0.0, 25.00, 1.0, 1.0, 1.0);
+ de = gtk_hscale_new (GTK_ADJUSTMENT (ea));
+ gtk_scale_set_digits (GTK_SCALE (de), 0);
+ gtk_table_attach (GTK_TABLE (t), de,
+ 1, 2, 1, 2, GTK_FILL | GTK_EXPAND, 0, 0, 0);
+
+ gtk_signal_connect (sa, "value_changed",
+ GTK_SIGNAL_FUNC (start_changed), ea);
+ gtk_signal_connect (ea, "value_changed",
+ GTK_SIGNAL_FUNC (end_changed), sa);
+
+ /* Nice spacing :-) */
+ gtk_table_attach (GTK_TABLE (t), gtk_label_new (""),
+ 0, 1, 2, 3, 0, 0, 0, 0);
+
+ r1 = gtk_radio_button_new_with_label (NULL, _("24 hour format"));
+ r2 = gtk_radio_button_new_with_label_from_widget (GTK_RADIO_BUTTON (r1),
+ _("12 hour format"));
+ if (am_pm_flag)
+ gtk_toggle_button_set_state (GTK_TOGGLE_BUTTON (r2), 1);
+
+ gtk_table_attach (GTK_TABLE (t), align (r1, 0.0), 0, 2, 3, 4, GTK_FILL | GTK_EXPAND, 0, 0, 0);
+ gtk_table_attach (GTK_TABLE (t), align (r2, 0.0), 0, 2, 4, 5, GTK_FILL | GTK_EXPAND, 0, 0, 0);
+
+ hbox = gtk_hbox_new (0, 0);
+ ok = gnome_stock_button (GNOME_STOCK_BUTTON_OK);
+ cancel = gnome_stock_button (GNOME_STOCK_BUTTON_CANCEL);
+ gtk_box_pack_start (GTK_BOX (hbox), ok, 0, 0, 0);
+ gtk_box_pack_end (GTK_BOX (hbox), cancel, 0, 0, 0);
+
+ gtk_table_attach (GTK_TABLE (t), hbox, 0, 2, 5, 6, GTK_FILL | GTK_EXPAND, 0, 0, GNOME_PAD);
+
+ gtk_signal_connect (GTK_OBJECT (ok), "clicked",
+ GTK_SIGNAL_FUNC (prop_ok), NULL);
+ gtk_signal_connect (GTK_OBJECT (cancel), "clicked",
+ GTK_SIGNAL_FUNC (prop_cancel), NULL);
+ gtk_widget_show_all (prop_win);
+}
+