aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--calendar/TODO3
-rw-r--r--calendar/gncal-full-day.c45
-rw-r--r--calendar/gui/gncal-full-day.c45
3 files changed, 66 insertions, 27 deletions
diff --git a/calendar/TODO b/calendar/TODO
index c93a64eae8..23be8e5b32 100644
--- a/calendar/TODO
+++ b/calendar/TODO
@@ -15,9 +15,6 @@ Event editor dialog:
Full day view widget:
-- The child widgets are not destroyed when the widget is updated, so
- everything gets displayed incorrectly.
-
- Notify the calendar when a child changes. Look for the FIXMEs in
the code.
diff --git a/calendar/gncal-full-day.c b/calendar/gncal-full-day.c
index 10a8246f73..90a4813947 100644
--- a/calendar/gncal-full-day.c
+++ b/calendar/gncal-full-day.c
@@ -128,7 +128,7 @@ child_map (GncalFullDay *fullday, Child *child)
{
gdk_window_show (child->window);
- if (GTK_WIDGET_VISIBLE (child->widget) && !GTK_WIDGET_MAPPED (child->widget))
+ if (!GTK_WIDGET_MAPPED (child->widget))
gtk_widget_map (child->widget);
}
@@ -137,7 +137,7 @@ child_unmap (GncalFullDay *fullday, Child *child)
{
gdk_window_hide (child->window);
- if (GTK_WIDGET_VISIBLE (child->widget) && GTK_WIDGET_MAPPED (child->widget))
+ if (GTK_WIDGET_MAPPED (child->widget))
gtk_widget_unmap (child->widget);
}
@@ -322,7 +322,6 @@ child_new (GncalFullDay *fullday, iCalObject *ico)
gtk_text_set_word_wrap (GTK_TEXT (child->widget), TRUE);
gtk_widget_set_parent (child->widget, GTK_WIDGET (fullday));
- gtk_widget_show (child->widget);
return child;
}
@@ -330,7 +329,21 @@ child_new (GncalFullDay *fullday, iCalObject *ico)
static void
child_destroy (GncalFullDay *fullday, Child *child)
{
- /* FIXME */
+ /* Unparent the child widget manually as we don't have a remove method */
+
+ gtk_widget_ref (child->widget);
+
+ gtk_widget_unparent (child->widget);
+
+ if (GTK_WIDGET_MAPPED (fullday))
+ child_unmap (fullday, child);
+
+ if (GTK_WIDGET_REALIZED (fullday))
+ child_unrealize (fullday, child);
+
+ gtk_widget_unref (child->widget);
+
+ g_free (child);
}
static void
@@ -341,7 +354,7 @@ child_set_pos (GncalFullDay *fullday, Child *child, int x, int y, int width, int
child->width = width;
child->height = height;
- if (!GTK_WIDGET_REALIZED (fullday))
+ if (!child->window) /* realized? */
return;
child_set_text_pos (child);
@@ -566,12 +579,22 @@ static void
gncal_full_day_destroy (GtkObject *object)
{
GncalFullDay *fullday;
+ GList *children;
+ Child *child;
g_return_if_fail (object != NULL);
g_return_if_fail (GNCAL_IS_FULL_DAY (object));
fullday = GNCAL_FULL_DAY (object);
+ /* Unparent the children manually as we don't have a remove method */
+
+ for (children = fullday->children; children; children = children->next) {
+ child = children->data;
+
+ gtk_widget_unparent (child->widget);
+ }
+
g_list_free (fullday->children);
g_free (fullday->drag_info);
@@ -1161,13 +1184,6 @@ gncal_full_day_update (GncalFullDay *fullday)
if (!fullday->calendar->cal)
return;
- l_events = calendar_get_events_in_range (fullday->calendar->cal,
- fullday->lower,
- fullday->upper,
- calendar_compare_by_dtstart);
-
- /* FIXME: this is expensive and looks ugly -- use some form of cache? */
-
for (children = fullday->children; children; children = children->next)
child_destroy (fullday, children->data);
@@ -1175,6 +1191,11 @@ gncal_full_day_update (GncalFullDay *fullday)
children = NULL;
+ l_events = calendar_get_events_in_range (fullday->calendar->cal,
+ fullday->lower,
+ fullday->upper,
+ calendar_compare_by_dtstart);
+
for (events = l_events; events; events = events->next) {
child = child_new (fullday, events->data);
children = g_list_append (children, child);
diff --git a/calendar/gui/gncal-full-day.c b/calendar/gui/gncal-full-day.c
index 10a8246f73..90a4813947 100644
--- a/calendar/gui/gncal-full-day.c
+++ b/calendar/gui/gncal-full-day.c
@@ -128,7 +128,7 @@ child_map (GncalFullDay *fullday, Child *child)
{
gdk_window_show (child->window);
- if (GTK_WIDGET_VISIBLE (child->widget) && !GTK_WIDGET_MAPPED (child->widget))
+ if (!GTK_WIDGET_MAPPED (child->widget))
gtk_widget_map (child->widget);
}
@@ -137,7 +137,7 @@ child_unmap (GncalFullDay *fullday, Child *child)
{
gdk_window_hide (child->window);
- if (GTK_WIDGET_VISIBLE (child->widget) && GTK_WIDGET_MAPPED (child->widget))
+ if (GTK_WIDGET_MAPPED (child->widget))
gtk_widget_unmap (child->widget);
}
@@ -322,7 +322,6 @@ child_new (GncalFullDay *fullday, iCalObject *ico)
gtk_text_set_word_wrap (GTK_TEXT (child->widget), TRUE);
gtk_widget_set_parent (child->widget, GTK_WIDGET (fullday));
- gtk_widget_show (child->widget);
return child;
}
@@ -330,7 +329,21 @@ child_new (GncalFullDay *fullday, iCalObject *ico)
static void
child_destroy (GncalFullDay *fullday, Child *child)
{
- /* FIXME */
+ /* Unparent the child widget manually as we don't have a remove method */
+
+ gtk_widget_ref (child->widget);
+
+ gtk_widget_unparent (child->widget);
+
+ if (GTK_WIDGET_MAPPED (fullday))
+ child_unmap (fullday, child);
+
+ if (GTK_WIDGET_REALIZED (fullday))
+ child_unrealize (fullday, child);
+
+ gtk_widget_unref (child->widget);
+
+ g_free (child);
}
static void
@@ -341,7 +354,7 @@ child_set_pos (GncalFullDay *fullday, Child *child, int x, int y, int width, int
child->width = width;
child->height = height;
- if (!GTK_WIDGET_REALIZED (fullday))
+ if (!child->window) /* realized? */
return;
child_set_text_pos (child);
@@ -566,12 +579,22 @@ static void
gncal_full_day_destroy (GtkObject *object)
{
GncalFullDay *fullday;
+ GList *children;
+ Child *child;
g_return_if_fail (object != NULL);
g_return_if_fail (GNCAL_IS_FULL_DAY (object));
fullday = GNCAL_FULL_DAY (object);
+ /* Unparent the children manually as we don't have a remove method */
+
+ for (children = fullday->children; children; children = children->next) {
+ child = children->data;
+
+ gtk_widget_unparent (child->widget);
+ }
+
g_list_free (fullday->children);
g_free (fullday->drag_info);
@@ -1161,13 +1184,6 @@ gncal_full_day_update (GncalFullDay *fullday)
if (!fullday->calendar->cal)
return;
- l_events = calendar_get_events_in_range (fullday->calendar->cal,
- fullday->lower,
- fullday->upper,
- calendar_compare_by_dtstart);
-
- /* FIXME: this is expensive and looks ugly -- use some form of cache? */
-
for (children = fullday->children; children; children = children->next)
child_destroy (fullday, children->data);
@@ -1175,6 +1191,11 @@ gncal_full_day_update (GncalFullDay *fullday)
children = NULL;
+ l_events = calendar_get_events_in_range (fullday->calendar->cal,
+ fullday->lower,
+ fullday->upper,
+ calendar_compare_by_dtstart);
+
for (events = l_events; events; events = events->next) {
child = child_new (fullday, events->data);
children = g_list_append (children, child);
rget on FreeBSD 4.x.lesi2005-02-011-1/+4 * Clarify message about how to install luit setuid a bit.lesi2005-01-312-3/+5 * rmdir X11PREFIX/sbin during uninstall if possibleoliver2005-01-301-0/+1 * devel/gconf2mezz2005-01-302-2/+25 * Apparently the maintainer still exists but with a new email address.linimon2005-01-301-1/+1 * With portmgr hat on, reset bouncing maintainer address:linimon2005-01-301-1/+1 * Really add MASTER_SITE_GNOME to MASTER_SITESahze2005-01-281-0/+1 * Readd MASTER_SITE_GNOME to MASTER_SITESahze2005-01-281-1/+2 * Enable new FreeBSD customers to waste time instant-messaging their GF/BFlofi2005-01-281-1/+1 * Add Terminal 0.2.2, terminal emulator for the X windowing system.oliver2005-01-285-0/+76 * Add libexo 0.2.0,oliver2005-01-285-0/+109 * update xfce4-clipman-plugin to 0.4.1oliver2005-01-283-7/+5 * - bring xfce4 to 4.2oliver2005-01-2710-29/+88 * - Move print/ggv2 to print/ggvpav2005-01-254-4/+4 * - Move editors/gedit2 to editors/geditpav2005-01-254-4/+4 * - Move x11/gdm2 to x11/gdmpav2005-01-2516-6/+5 * - Move graphics/eog2 to graphics/eogpav2005-01-253-3/+3 * - Move devel/bugbuddy2 to devel/bugbuddypav2005-01-253-3/+3