summaryrefslogtreecommitdiff
path: root/tests/testcalendar.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/testcalendar.c')
-rw-r--r--tests/testcalendar.c522
1 files changed, 398 insertions, 124 deletions
diff --git a/tests/testcalendar.c b/tests/testcalendar.c
index 0ab4409ee..7ac0f8c0c 100644
--- a/tests/testcalendar.c
+++ b/tests/testcalendar.c
@@ -23,12 +23,14 @@
#include <string.h>
#include <gtk/gtk.h>
-#define DEF_PAD 10
-#define DEF_PAD_SMALL 5
+#define DEF_PAD 12
+#define DEF_PAD_SMALL 6
#define TM_YEAR_BASE 1900
-typedef struct _CalendarData {
+typedef struct _CalendarData
+{
+ GtkWidget *calendar_widget;
GtkWidget *flag_checkboxes[5];
gboolean settings[5];
GtkWidget *font_dialog;
@@ -37,9 +39,14 @@ typedef struct _CalendarData {
GtkWidget *prev_sig;
GtkWidget *last_sig;
GtkWidget *month;
+
+ GHashTable *details_table;
+ GtkTextBuffer *details_buffer;
+ guint details_changed;
} CalendarData;
-enum {
+enum
+{
calendar_show_header,
calendar_show_days,
calendar_month_change,
@@ -66,7 +73,49 @@ void calendar_date_to_string (CalendarData *data,
g_date_free (date);
}
-void calendar_set_signal_strings (char *sig_str,
+static void
+calendar_set_detail (CalendarData *data,
+ guint year,
+ guint month,
+ guint day,
+ gchar *detail)
+{
+ gchar *key = g_strdup_printf ("%04d-%02d-%02d", year, month + 1, day);
+ g_hash_table_replace (data->details_table, key, detail);
+}
+
+static G_CONST_RETURN gchar*
+calendar_get_detail (CalendarData *data,
+ guint year,
+ guint month,
+ guint day)
+{
+ const gchar *detail;
+ gchar *key;
+
+ key = g_strdup_printf ("%04d-%02d-%02d", year, month + 1, day);
+ detail = g_hash_table_lookup (data->details_table, key);
+ g_free (key);
+
+ return detail;
+}
+
+static void
+calendar_update_details (CalendarData *data)
+{
+ guint year, month, day;
+ const gchar *detail;
+
+ gtk_calendar_get_date (GTK_CALENDAR (data->calendar_widget), &year, &month, &day);
+ detail = calendar_get_detail (data, year, month, day);
+
+ g_signal_handler_block (data->details_buffer, data->details_changed);
+ gtk_text_buffer_set_text (data->details_buffer, detail ? detail : "", -1);
+ g_signal_handler_unblock (data->details_buffer, data->details_changed);
+}
+
+static void
+calendar_set_signal_strings (char *sig_str,
CalendarData *data)
{
const gchar *prev_sig;
@@ -95,6 +144,8 @@ void calendar_day_selected (GtkWidget *widget,
calendar_date_to_string (data, buffer+14, 256-14);
calendar_set_signal_strings (buffer, data);
+
+ calendar_update_details (data);
}
void calendar_day_selected_double_click (GtkWidget *widget,
@@ -153,155 +204,258 @@ void calendar_next_year( GtkWidget *widget,
}
-void calendar_set_flags( CalendarData *calendar )
+static void
+calendar_set_flags (CalendarData *calendar)
{
- gint i;
- gint options=0;
- for (i=0;i<5;i++)
+ gint options = 0, i;
+
+ for (i = 0; i < G_N_ELEMENTS (calendar->settings); i++)
if (calendar->settings[i])
- {
- options=options + (1<<i);
- }
+ options=options + (1 << i);
+
if (calendar->window)
gtk_calendar_set_display_options (GTK_CALENDAR (calendar->window), options);
}
-void calendar_toggle_flag( GtkWidget *toggle,
- CalendarData *calendar )
+static void
+calendar_toggle_flag (GtkWidget *toggle,
+ CalendarData *calendar)
{
gint i;
- gint j;
- j=0;
- for (i=0; i<5; i++)
+
+ for (i = 0; i < G_N_ELEMENTS (calendar->flag_checkboxes); i++)
if (calendar->flag_checkboxes[i] == toggle)
- j = i;
+ calendar->settings[i] = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (toggle));
- calendar->settings[j]=!calendar->settings[j];
calendar_set_flags(calendar);
}
-void calendar_font_selection_ok (GtkWidget *button,
- CalendarData *calendar)
+void
+calendar_select_font (GtkWidget *button,
+ CalendarData *calendar)
{
+ const char *font = NULL;
GtkRcStyle *style;
- char *font_name;
if (calendar->window)
- {
- font_name = gtk_font_selection_dialog_get_font_name (GTK_FONT_SELECTION_DIALOG(calendar->font_dialog));
- if (font_name)
+ font = gtk_font_button_get_font_name (GTK_FONT_BUTTON (button));
+
+ if (font)
{
style = gtk_rc_style_new ();
pango_font_description_free (style->font_desc);
- style->font_desc = pango_font_description_from_string (font_name);
+ style->font_desc = pango_font_description_from_string (font);
gtk_widget_modify_style (calendar->window, style);
- g_free (font_name);
}
+}
+
+static G_CONST_RETURN gchar*
+calendar_detail_cb (GtkCalendar *calendar,
+ guint year,
+ guint month,
+ guint day,
+ gpointer data)
+{
+ return calendar_get_detail (data, year, month, day);
+}
+
+static void
+calendar_details_changed (GtkTextBuffer *buffer,
+ CalendarData *data)
+{
+ GtkTextIter start, end;
+ guint year, month, day;
+ gchar *detail;
+
+ gtk_text_buffer_get_start_iter(buffer, &start);
+ gtk_text_buffer_get_end_iter(buffer, &end);
+
+ gtk_calendar_get_date (GTK_CALENDAR (data->calendar_widget), &year, &month, &day);
+ detail = gtk_text_buffer_get_text (buffer, &start, &end, FALSE);
+
+ if (!detail[0])
+ {
+ g_free (detail);
+ detail = NULL;
}
- gtk_widget_destroy (calendar->font_dialog);
+ calendar_set_detail (data, year, month, day, detail);
+ gtk_widget_queue_resize (data->calendar_widget);
}
-void calendar_select_font( GtkWidget *button,
- CalendarData *calendar )
+static void
+demonstrate_details (CalendarData *data)
{
- GtkWidget *window;
+ static char *rainbow[] = { "#900", "#980", "#390", "#095", "#059", "#309", "#908" };
+ GtkCalendar *calendar = GTK_CALENDAR (data->calendar_widget);
+ gint row, col;
- if (!calendar->font_dialog) {
- window = gtk_font_selection_dialog_new ("Font Selection Dialog");
- g_return_if_fail(GTK_IS_FONT_SELECTION_DIALOG(window));
- calendar->font_dialog = window;
-
- gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
+ for (row = 0; row < 6; ++row)
+ for (col = 0; col < 7; ++col)
+ {
+ gint year, month, day;
+ gchar *detail;
- g_signal_connect (window, "destroy",
- G_CALLBACK (gtk_widget_destroyed),
- &calendar->font_dialog);
+ year = calendar->year;
+ month = calendar->month;
+ month += calendar->day_month[row][col];
+ day = calendar->day[row][col];
- g_signal_connect (GTK_FONT_SELECTION_DIALOG (window)->ok_button,
- "clicked", G_CALLBACK (calendar_font_selection_ok),
- calendar);
- g_signal_connect_swapped (GTK_FONT_SELECTION_DIALOG (window)->cancel_button,
- "clicked", G_CALLBACK (gtk_widget_destroy),
- calendar->font_dialog);
+ if (month < 1)
+ {
+ month += 12;
+ year -= 1;
+ }
+ else if (month > 12)
+ {
+ month -= 12;
+ year += 1;
}
- window=calendar->font_dialog;
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
+
+ detail = g_strdup_printf ("<span color='%s'>yadda\n"
+ "(%04d-%02d-%02d)</span>",
+ rainbow[(day - 1) % 7],
+ year, month, day);
+
+ calendar_set_detail (data, year, month - 1, day, detail);
+ }
+
+ gtk_widget_queue_resize (data->calendar_widget);
+ calendar_update_details (data);
+}
+
+static void
+reset_details (CalendarData *data)
+{
+ g_hash_table_remove_all (data->details_table);
+ gtk_widget_queue_resize (data->calendar_widget);
+ calendar_update_details (data);
+}
+
+static void
+calendar_toggle_details (GtkWidget *widget,
+ CalendarData *data)
+{
+ if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)))
+ gtk_calendar_set_detail_func (GTK_CALENDAR (data->calendar_widget),
+ calendar_detail_cb, data, NULL);
else
- gtk_widget_destroy (window);
+ gtk_calendar_set_detail_func (GTK_CALENDAR (data->calendar_widget),
+ NULL, NULL, NULL);
+}
+
+static GtkWidget*
+create_expander (const char *caption,
+ GtkWidget *child,
+ gdouble xscale,
+ gdouble yscale)
+{
+ GtkWidget *expander = gtk_expander_new ("");
+ GtkWidget *label = gtk_expander_get_label_widget (GTK_EXPANDER (expander));
+ GtkWidget *align = gtk_alignment_new (0, 0, xscale, yscale);
+
+ gtk_alignment_set_padding (GTK_ALIGNMENT (align), 6, 0, 18, 0);
+ gtk_label_set_markup (GTK_LABEL (label), caption);
+
+ gtk_container_add (GTK_CONTAINER (expander), align);
+ gtk_container_add (GTK_CONTAINER (align), child);
+ return expander;
}
-void create_calendar(void)
+static GtkWidget*
+create_frame (const char *caption,
+ GtkWidget *child,
+ gdouble xscale,
+ gdouble yscale)
+{
+ GtkWidget *frame = gtk_frame_new ("");
+ GtkWidget *label = gtk_frame_get_label_widget (GTK_FRAME (frame));
+ GtkWidget *align = gtk_alignment_new (0, 0, xscale, yscale);
+
+ gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_NONE);
+ gtk_alignment_set_padding (GTK_ALIGNMENT (align), 6, 0, 18, 0);
+ gtk_label_set_markup (GTK_LABEL (label), caption);
+
+ gtk_container_add (GTK_CONTAINER (frame), align);
+ gtk_container_add (GTK_CONTAINER (align), child);
+
+ return frame;
+}
+
+static void
+detail_width_changed (GtkSpinButton *button,
+ CalendarData *data)
+{
+ gint value = (gint) gtk_spin_button_get_value (button);
+ gtk_calendar_set_detail_width_chars (GTK_CALENDAR (data->calendar_widget), value);
+}
+
+static void
+detail_height_changed (GtkSpinButton *button,
+ CalendarData *data)
+{
+ gint value = (gint) gtk_spin_button_get_value (button);
+ gtk_calendar_set_detail_height_rows (GTK_CALENDAR (data->calendar_widget), value);
+}
+
+static void
+create_calendar(void)
{
- GtkWidget *window;
- GtkWidget *vbox, *vbox2, *vbox3;
- GtkWidget *hbox;
- GtkWidget *hbbox;
- GtkWidget *calendar;
- GtkWidget *toggle;
- GtkWidget *button;
- GtkWidget *frame;
- GtkWidget *separator;
- GtkWidget *label;
- GtkWidget *bbox;
static CalendarData calendar_data;
+
+ GtkWidget *window, *hpaned, *vbox, *rpane, *hbox;
+ GtkWidget *calendar, *toggle, *scroller, *button;
+ GtkWidget *frame, *label, *bbox, *align, *details;
+
+ GtkSizeGroup *size;
+ GtkStyle *style;
+ gchar *font;
gint i;
struct {
+ gboolean init;
char *label;
} flags[] =
{
- { "Show Heading" },
- { "Show Day Names" },
- { "No Month Change" },
- { "Show Week Numbers" },
- { "Week Start Monday" }
+ { TRUE, "Show _Heading" },
+ { TRUE, "Show Day _Names" },
+ { FALSE, "No Month _Change" },
+ { TRUE, "Show _Week Numbers" },
+ { FALSE, "Week Start _Monday" },
};
-
calendar_data.window = NULL;
calendar_data.font_dialog = NULL;
+ calendar_data.details_table = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_free);
- for (i=0; i<5; i++) {
- calendar_data.settings[i]=0;
- }
+ for (i = 0; i < G_N_ELEMENTS (calendar_data.settings); i++)
+ calendar_data.settings[i] = 0;
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
gtk_window_set_title (GTK_WINDOW (window), "GtkCalendar Example");
- gtk_container_set_border_width (GTK_CONTAINER (window), 5);
+ gtk_container_set_border_width (GTK_CONTAINER (window), 12);
g_signal_connect (window, "destroy",
G_CALLBACK (gtk_main_quit),
NULL);
g_signal_connect (window, "delete-event",
G_CALLBACK (gtk_false),
NULL);
- gtk_window_set_resizable (GTK_WINDOW (window), FALSE);
- vbox = gtk_vbox_new (FALSE, DEF_PAD);
- gtk_container_add (GTK_CONTAINER (window), vbox);
+ hpaned = gtk_hpaned_new ();
- /*
- * The top part of the window, Calendar, flags and fontsel.
- */
+ /* Calendar widget */
- hbox = gtk_hbox_new(FALSE, DEF_PAD);
- gtk_box_pack_start (GTK_BOX(vbox), hbox, TRUE, TRUE, DEF_PAD);
- hbbox = gtk_hbutton_box_new();
- gtk_box_pack_start(GTK_BOX(hbox), hbbox, FALSE, FALSE, DEF_PAD);
- gtk_button_box_set_layout(GTK_BUTTON_BOX(hbbox), GTK_BUTTONBOX_SPREAD);
- gtk_box_set_spacing(GTK_BOX(hbbox), 5);
+ calendar = gtk_calendar_new ();
+ calendar_data.calendar_widget = calendar;
+ frame = create_frame ("<b>Calendar</b>", calendar, 0, 0);
+ gtk_paned_pack1 (GTK_PANED (hpaned), frame, TRUE, FALSE);
- /* Calendar widget */
- frame = gtk_frame_new("Calendar");
- gtk_box_pack_start(GTK_BOX(hbbox), frame, FALSE, TRUE, DEF_PAD);
- calendar=gtk_calendar_new();
calendar_data.window = calendar;
calendar_set_flags(&calendar_data);
gtk_calendar_mark_day (GTK_CALENDAR (calendar), 19);
- gtk_container_add (GTK_CONTAINER (frame), calendar);
+
g_signal_connect (calendar, "month_changed",
G_CALLBACK (calendar_month_changed),
&calendar_data);
@@ -324,82 +478,202 @@ void create_calendar(void)
G_CALLBACK (calendar_next_year),
&calendar_data);
+ rpane = gtk_vbox_new (FALSE, DEF_PAD_SMALL);
+ gtk_paned_pack2 (GTK_PANED (hpaned), rpane, FALSE, FALSE);
+
+ /* Build the right font-button */
+
+ vbox = gtk_vbox_new(FALSE, DEF_PAD_SMALL);
+ frame = create_frame ("<b>Options</b>", vbox, 1, 0);
+ gtk_box_pack_start (GTK_BOX (rpane), frame, FALSE, TRUE, 0);
+ size = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
+
+ gtk_widget_ensure_style (calendar);
+ style = gtk_widget_get_style (calendar);
+ font = pango_font_description_to_string (style->font_desc);
+ button = gtk_font_button_new_with_font (font);
+ g_free (font);
+
+ g_signal_connect (button, "font-set",
+ G_CALLBACK(calendar_select_font),
+ &calendar_data);
+
+ label = gtk_label_new_with_mnemonic ("_Font:");
+ gtk_label_set_mnemonic_widget (GTK_LABEL (label), button);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_size_group_add_widget (size, label);
+
+ hbox = gtk_hbox_new (FALSE, DEF_PAD_SMALL);
+ gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
+
+ /* Build the width entry */
+
+ button = gtk_spin_button_new_with_range (0, 127, 1);
+ gtk_spin_button_set_value (GTK_SPIN_BUTTON (button),
+ gtk_calendar_get_detail_width_chars (GTK_CALENDAR (calendar)));
+
+ g_signal_connect (button, "value-changed",
+ G_CALLBACK (detail_width_changed),
+ &calendar_data);
+
+ label = gtk_label_new_with_mnemonic ("Details W_idth:");
+ gtk_label_set_mnemonic_widget (GTK_LABEL (label), button);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_size_group_add_widget (size, label);
+
+ hbox = gtk_hbox_new (FALSE, DEF_PAD_SMALL);
+ gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
+
+ /* Build the height entry */
+
+ button = gtk_spin_button_new_with_range (0, 127, 1);
+ gtk_spin_button_set_value (GTK_SPIN_BUTTON (button),
+ gtk_calendar_get_detail_height_rows (GTK_CALENDAR (calendar)));
- separator = gtk_vseparator_new ();
- gtk_box_pack_start (GTK_BOX (hbox), separator, FALSE, TRUE, 0);
+ g_signal_connect (button, "value-changed",
+ G_CALLBACK (detail_height_changed),
+ &calendar_data);
- vbox2 = gtk_vbox_new(FALSE, DEF_PAD);
- gtk_box_pack_start(GTK_BOX(hbox), vbox2, FALSE, FALSE, DEF_PAD);
+ label = gtk_label_new_with_mnemonic ("Details H_eight:");
+ gtk_label_set_mnemonic_widget (GTK_LABEL (label), button);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_size_group_add_widget (size, label);
+
+ hbox = gtk_hbox_new (FALSE, DEF_PAD_SMALL);
+ gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
+
+ /* Build the right details frame */
+
+ vbox = gtk_vbox_new(FALSE, DEF_PAD_SMALL);
+ frame = create_frame ("<b>Details</b>", vbox, 1, 1);
+ gtk_box_pack_start (GTK_BOX (rpane), frame, FALSE, TRUE, 0);
+
+ details = gtk_text_view_new();
+ calendar_data.details_buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (details));
+
+ calendar_data.details_changed = g_signal_connect (calendar_data.details_buffer, "changed",
+ G_CALLBACK (calendar_details_changed),
+ &calendar_data);
+
+ scroller = gtk_scrolled_window_new (NULL, NULL);
+ gtk_container_add (GTK_CONTAINER (scroller), details);
+
+ gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scroller),
+ GTK_SHADOW_IN);
+ gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scroller),
+ GTK_POLICY_AUTOMATIC,
+ GTK_POLICY_AUTOMATIC);
+
+ gtk_box_pack_start (GTK_BOX (vbox), scroller, FALSE, TRUE, 0);
+
+ hbox = gtk_hbox_new (FALSE, DEF_PAD_SMALL);
+ align = gtk_alignment_new (0.0, 0.5, 0.0, 0.0);
+ gtk_container_add (GTK_CONTAINER (align), hbox);
+ gtk_box_pack_start (GTK_BOX (vbox), align, FALSE, TRUE, 0);
+
+ button = gtk_button_new_with_mnemonic ("Demonstrate _Details");
+
+ g_signal_connect_swapped (button,
+ "clicked",
+ G_CALLBACK (demonstrate_details),
+ &calendar_data);
+
+ gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, TRUE, 0);
+
+ button = gtk_button_new_with_mnemonic ("_Reset Details");
+
+ g_signal_connect_swapped (button,
+ "clicked",
+ G_CALLBACK (reset_details),
+ &calendar_data);
+
+ gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, TRUE, 0);
+
+ toggle = gtk_check_button_new_with_mnemonic ("_Show Details");
+ g_signal_connect (toggle, "toggled",
+ G_CALLBACK(calendar_toggle_details),
+ &calendar_data);
+ gtk_box_pack_start (GTK_BOX (vbox), toggle, FALSE, TRUE, 0);
/* Build the Right frame with the flags in */
- frame = gtk_frame_new("Flags");
- gtk_box_pack_start(GTK_BOX(vbox2), frame, TRUE, TRUE, DEF_PAD);
- vbox3 = gtk_vbox_new(TRUE, DEF_PAD_SMALL);
- gtk_container_add(GTK_CONTAINER(frame), vbox3);
+ vbox = gtk_vbox_new(FALSE, DEF_PAD_SMALL);
+ frame = create_expander ("<b>Flags</b>", vbox, 1, 0);
+ gtk_box_pack_start (GTK_BOX (rpane), frame, TRUE, TRUE, 0);
- for (i = 0; i < 5; i++)
+ for (i = 0; i < G_N_ELEMENTS (calendar_data.settings); i++)
{
- toggle = gtk_check_button_new_with_label(flags[i].label);
- g_signal_connect (toggle,
- "toggled",
- G_CALLBACK(calendar_toggle_flag),
+ toggle = gtk_check_button_new_with_mnemonic(flags[i].label);
+ gtk_box_pack_start (GTK_BOX (vbox), toggle, FALSE, TRUE, 0);
+ calendar_data.flag_checkboxes[i] = toggle;
+
+ g_signal_connect (toggle, "toggled",
+ G_CALLBACK (calendar_toggle_flag),
&calendar_data);
- gtk_box_pack_start (GTK_BOX (vbox3), toggle, TRUE, TRUE, 0);
- calendar_data.flag_checkboxes[i]=toggle;
+
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), flags[i].init);
}
- /* Build the right font-button */
- button = gtk_button_new_with_label("Font...");
- g_signal_connect (button,
- "clicked",
- G_CALLBACK(calendar_select_font),
- &calendar_data);
- gtk_box_pack_start (GTK_BOX (vbox2), button, FALSE, FALSE, 0);
/*
* Build the Signal-event part.
*/
- frame = gtk_frame_new("Signal events");
- gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, DEF_PAD);
-
- vbox2 = gtk_vbox_new(TRUE, DEF_PAD_SMALL);
- gtk_container_add(GTK_CONTAINER(frame), vbox2);
+ vbox = gtk_vbox_new (TRUE, DEF_PAD_SMALL);
+ frame = create_frame ("<b>Signal Events</b>", vbox, 1, 0);
hbox = gtk_hbox_new (FALSE, 3);
- gtk_box_pack_start (GTK_BOX (vbox2), hbox, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
label = gtk_label_new ("Signal:");
gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
calendar_data.last_sig = gtk_label_new ("");
gtk_box_pack_start (GTK_BOX (hbox), calendar_data.last_sig, FALSE, TRUE, 0);
hbox = gtk_hbox_new (FALSE, 3);
- gtk_box_pack_start (GTK_BOX (vbox2), hbox, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
label = gtk_label_new ("Previous signal:");
gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
calendar_data.prev_sig = gtk_label_new ("");
gtk_box_pack_start (GTK_BOX (hbox), calendar_data.prev_sig, FALSE, TRUE, 0);
hbox = gtk_hbox_new (FALSE, 3);
- gtk_box_pack_start (GTK_BOX (vbox2), hbox, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
label = gtk_label_new ("Second previous signal:");
gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
calendar_data.prev2_sig = gtk_label_new ("");
gtk_box_pack_start (GTK_BOX (hbox), calendar_data.prev2_sig, FALSE, TRUE, 0);
+ /*
+ * Glue everything together
+ */
+
bbox = gtk_hbutton_box_new ();
- gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, FALSE, 0);
gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END);
button = gtk_button_new_with_label ("Close");
- g_signal_connect (button, "clicked",
- G_CALLBACK (gtk_main_quit),
- NULL);
+ g_signal_connect (button, "clicked", G_CALLBACK (gtk_main_quit), NULL);
gtk_container_add (GTK_CONTAINER (bbox), button);
+
+ vbox = gtk_vbox_new (FALSE, DEF_PAD_SMALL);
+
+ gtk_box_pack_start (GTK_BOX (vbox), hpaned, TRUE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), gtk_hseparator_new (), FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), gtk_hseparator_new (), FALSE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, TRUE, 0);
+
+ gtk_container_add (GTK_CONTAINER (window), vbox);
+
GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
gtk_widget_grab_default (button);
- gtk_widget_show_all(window);
+ gtk_window_set_default_size (GTK_WINDOW (window), 600, 0);
+ gtk_widget_show_all (window);
}