aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/calendar-model.c
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui/calendar-model.c')
-rw-r--r--calendar/gui/calendar-model.c87
1 files changed, 68 insertions, 19 deletions
diff --git a/calendar/gui/calendar-model.c b/calendar/gui/calendar-model.c
index 1e64b940c4..bcd4d69843 100644
--- a/calendar/gui/calendar-model.c
+++ b/calendar/gui/calendar-model.c
@@ -43,8 +43,9 @@
#include <gal/widgets/e-unicode.h>
#include <e-util/e-time-utils.h>
#include <cal-util/timeutil.h>
-#include "calendar-model.h"
#include "calendar-commands.h"
+#include "calendar-config.h"
+#include "calendar-model.h"
/* Private part of the ECalendarModel structure */
@@ -561,7 +562,7 @@ get_url (CalComponent *comp)
/* Returns whether the completion date has been set on a component */
static gboolean
-get_is_complete (CalComponent *comp)
+is_complete (CalComponent *comp)
{
struct icaltimetype *t;
gboolean retval;
@@ -575,14 +576,11 @@ get_is_complete (CalComponent *comp)
return retval;
}
-/* Returns whether a calendar component is overdue.
- *
- * FIXME: This will only get called when the component is scrolled into the
- * ETable. There should be some sort of dynamic update thingy for if a component
- * becomes overdue while it is being viewed.
+/* Returns whether a component is overdue. Sigh, this is very similar to
+ * get_color() below.
*/
static gboolean
-get_is_overdue (CalComponent *comp)
+is_overdue (CalComponent *comp)
{
CalComponentDateTime dt;
gboolean retval;
@@ -598,15 +596,12 @@ get_is_overdue (CalComponent *comp)
/* Second, is it already completed? */
- if (get_is_complete (comp)) {
+ if (is_complete (comp)) {
retval = FALSE;
goto out;
}
- /* Third, are we overdue as of right now? We use <= in the
- * comparison below so that the table entries change color
- * immediately.
- */
+ /* Third, are we overdue as of right now? */
t = icaltime_as_timet (*dt.value);
@@ -623,6 +618,63 @@ get_is_overdue (CalComponent *comp)
return retval;
}
+/* Computes the color to be used to display a component */
+static const char *
+get_color (CalComponent *comp)
+{
+ CalComponentDateTime dt;
+ const char *retval;
+
+ cal_component_get_due (comp, &dt);
+
+ /* First, do we have a due date? */
+
+ if (!dt.value)
+ retval = NULL;
+ else {
+ time_t t, t_now;
+ struct tm tm, tm_now;
+
+ /* Second, is it already completed? */
+
+ if (is_complete (comp)) {
+ retval = NULL;
+ goto out;
+ }
+
+ /* Third, is it due today? */
+
+ t = icaltime_as_timet (*dt.value);
+ tm = *localtime (&t);
+
+ t_now = time (NULL);
+ tm_now = *localtime (&t_now);
+
+ if (tm.tm_year == tm_now.tm_year
+ && tm.tm_mon == tm_now.tm_mon
+ && tm.tm_mday == tm_now.tm_mday) {
+ retval = calendar_config_get_tasks_due_today_color ();
+ goto out;
+ }
+
+ /* Fourth, are we overdue as of right now? We use <= in the
+ * comparison below so that the table entries change color
+ * immediately.
+ */
+
+ if (t <= t_now)
+ retval = calendar_config_get_tasks_overdue_color ();
+ else
+ retval = NULL;
+ }
+
+ out:
+
+ cal_component_free_datetime (&dt);
+
+ return retval;
+}
+
static void *
get_status (CalComponent *comp)
{
@@ -732,19 +784,16 @@ calendar_model_value_at (ETableModel *etm, int col, int row)
}
}
case CAL_COMPONENT_FIELD_COMPLETE:
- return GINT_TO_POINTER (get_is_complete (comp));
+ return GINT_TO_POINTER (is_complete (comp));
case CAL_COMPONENT_FIELD_RECURRING:
return GINT_TO_POINTER (cal_component_has_recurrences (comp));
case CAL_COMPONENT_FIELD_OVERDUE:
- return GINT_TO_POINTER (get_is_overdue (comp));
+ return GINT_TO_POINTER (is_overdue (comp));
case CAL_COMPONENT_FIELD_COLOR:
- if (get_is_overdue (comp))
- return "red";
- else
- return NULL;
+ return (void *) get_color (comp);
case CAL_COMPONENT_FIELD_STATUS:
return get_status (comp);