[gnome-calendar] gcal-year-view: implemented new GcalView API
- From: Erick Pérez Castellanos <erickpc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-calendar] gcal-year-view: implemented new GcalView API
- Date: Thu, 4 Dec 2014 22:26:57 +0000 (UTC)
commit c1d163b24e6abcd5941e06182f2213d965f7cbf5
Author: Erick Pérez Castellanos <erick red gmail com>
Date: Sun Jun 30 17:38:27 2013 -0400
gcal-year-view: implemented new GcalView API
Added missing methods :mark_current_unit and :clear_marks
src/gcal-year-view.c | 143 +++++++++++++++++++++++---------------------------
1 files changed, 66 insertions(+), 77 deletions(-)
---
diff --git a/src/gcal-year-view.c b/src/gcal-year-view.c
index f018b5b..e549fdf 100644
--- a/src/gcal-year-view.c
+++ b/src/gcal-year-view.c
@@ -112,6 +112,12 @@ static icaltimetype* gcal_year_view_get_initial_date (GcalView
static icaltimetype* gcal_year_view_get_final_date (GcalView *view);
+static void gcal_year_view_mark_current_unit (GcalView *view,
+ gint *x,
+ gint *y);
+
+static void gcal_year_view_clear_marks (GcalView *view);
+
static gchar* gcal_year_view_get_left_header (GcalView *view);
static gchar* gcal_year_view_get_right_header (GcalView *view);
@@ -125,11 +131,6 @@ static GtkWidget* gcal_year_view_get_by_uuid (GcalView
static void gcal_year_view_clear (GcalView *view);
-/* Review API */
-static void gcal_year_view_clear_selection (GcalView *view);
-
-static void gcal_year_view_create_event_on_current_unit (GcalView *view);
-
G_DEFINE_TYPE_WITH_CODE (GcalYearView,
gcal_year_view,
GTK_TYPE_CONTAINER,
@@ -199,13 +200,13 @@ gcal_year_view_init (GcalYearView *self)
static void
gcal_view_interface_init (GcalViewIface *iface)
{
- iface->clear_selection = gcal_year_view_clear_selection;
- iface->create_event_on_current_unit = gcal_year_view_create_event_on_current_unit;
-
/* New API */
iface->get_initial_date = gcal_year_view_get_initial_date;
iface->get_final_date = gcal_year_view_get_final_date;
+ iface->mark_current_unit = gcal_year_view_mark_current_unit;
+ iface->clear_marks = gcal_year_view_clear_marks;
+
iface->get_left_header = gcal_year_view_get_left_header;
iface->get_right_header = gcal_year_view_get_right_header;
@@ -971,6 +972,63 @@ gcal_year_view_get_final_date (GcalView *view)
return new_date;
}
+static void
+gcal_year_view_mark_current_unit (GcalView *view,
+ gint *x,
+ gint *y)
+{
+ GcalYearViewPrivate *priv;
+
+ gint x_pos, y_pos;
+ gint width, height;
+
+ /* FIXME: This need to include marking the current unit */
+ priv = gcal_year_view_get_instance_private (GCAL_YEAR_VIEW (view));
+
+ width = gtk_widget_get_allocated_width (GTK_WIDGET (view));
+ height = gtk_widget_get_allocated_height (GTK_WIDGET (view));
+
+ priv->start_mark_cell = priv->date->month - 1;
+ priv->end_mark_cell = priv->start_mark_cell;
+
+ x_pos = (width / 6) * (( priv->start_mark_cell % 6) + 0.5);
+ y_pos = (height / 2) * (( priv->start_mark_cell / 6) + 0.5);
+
+ gtk_widget_queue_draw (GTK_WIDGET (view));
+
+ if (x != NULL)
+ *x = x_pos;
+ if (y != NULL)
+ *y = y_pos;
+}
+
+static void
+gcal_year_view_clear_marks (GcalView *view)
+{
+ GcalYearViewPrivate *priv;
+
+ priv = gcal_year_view_get_instance_private (GCAL_YEAR_VIEW (view));
+
+ priv->start_mark_cell = -1;
+ priv->end_mark_cell = -1;
+ gtk_widget_queue_draw (GTK_WIDGET (view));
+}
+
+static gchar*
+gcal_year_view_get_left_header (GcalView *view)
+{
+ GcalYearViewPrivate *priv;
+
+ priv = gcal_year_view_get_instance_private (GCAL_YEAR_VIEW (view));
+
+ return g_strdup_printf ("%d", priv->date->year);
+}
+
+static gchar*
+gcal_year_view_get_right_header (GcalView *view)
+{
+ return g_strdup ("");
+}
static gboolean
gcal_year_view_draw_event (GcalView *view,
@@ -1022,75 +1080,6 @@ gcal_year_view_clear (GcalView *view)
(GtkCallback) gtk_widget_destroy, NULL);
}
-static void
-gcal_year_view_clear_selection (GcalView *view)
-{
- GcalYearViewPrivate *priv;
-
- priv = gcal_year_view_get_instance_private (GCAL_YEAR_VIEW (view));
-
- priv->start_mark_cell = -1;
- priv->end_mark_cell = -1;
- gtk_widget_queue_draw (GTK_WIDGET (view));
-}
-
-static void
-gcal_year_view_create_event_on_current_unit (GcalView *view)
-{
- GcalYearViewPrivate *priv;
-
- gdouble x, y;
- gint width, height;
-
- icaltimetype *start_span;
- icaltimetype *end_span;
-
- /* FIXME: This need to include marking the current unit */
- priv = gcal_year_view_get_instance_private (GCAL_YEAR_VIEW (view));
-
- width = gtk_widget_get_allocated_width (GTK_WIDGET (view));
- height = gtk_widget_get_allocated_height (GTK_WIDGET (view));
-
- priv->start_mark_cell = priv->date->month - 1;
- priv->end_mark_cell = priv->start_mark_cell;
-
- x = (width / 6) * (( priv->start_mark_cell % 6) + 0.5);
- y = (height / 2) * (( priv->start_mark_cell / 6) + 0.5);
-
- gtk_widget_queue_draw (GTK_WIDGET (view));
-
- start_span = gcal_dup_icaltime (priv->date);
- start_span->day = 1;
- start_span->is_date = 1;
- end_span = gcal_dup_icaltime (priv->date);
- end_span->day = icaltime_days_in_month(priv->date->month, priv->date->year);
- end_span->is_date = 1;
-
- g_signal_emit_by_name (view,
- "create-event",
- start_span, end_span,
- x, y);
-
- g_free (start_span);
- g_free (end_span);
-}
-
-static gchar*
-gcal_year_view_get_left_header (GcalView *view)
-{
- GcalYearViewPrivate *priv;
-
- priv = gcal_year_view_get_instance_private (GCAL_YEAR_VIEW (view));
-
- return g_strdup_printf ("%d", priv->date->year);
-}
-
-static gchar*
-gcal_year_view_get_right_header (GcalView *view)
-{
- return g_strdup ("");
-}
-
/* Public API */
/**
* gcal_year_view_new:
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]