diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/datetime-service.c | 71 | ||||
| -rw-r--r-- | src/dbus-shared.h | 9 | ||||
| -rw-r--r-- | src/indicator-datetime.c | 62 | 
3 files changed, 99 insertions, 43 deletions
| diff --git a/src/datetime-service.c b/src/datetime-service.c index af63a2a..6303a98 100644 --- a/src/datetime-service.c +++ b/src/datetime-service.c @@ -127,7 +127,7 @@ check_timezone_sync (void) {  	} else {  		g_debug("Timezones are different");  	} - +	  	gboolean show = g_settings_get_boolean (conf, SETTINGS_SHOW_LOCATIONS_S);  	if (geo_location != NULL && current_location != NULL) { @@ -222,6 +222,7 @@ update_current_timezone (void) {  	check_timezone_sync(); +    if (error != NULL) g_error_free(error);  	return;  } @@ -266,52 +267,35 @@ activate_cb (DbusmenuMenuitem * menuitem, guint timestamp, const gchar *command)  	}  } +static gboolean +month_changed_cb (DbusmenuMenuitem * menuitem, GVariant *variant, guint timestamp) +{ +	// TODO: * Decode the month/year from the string we received +	//       * Check what our current month/year are +	//		 * Set some globals so when we-re-run update appointment menu items it gets the right start date +	//		 * update appointment menu items +	g_debug("Received month changed : %s", g_variant_get_string(variant, NULL)); +	return TRUE; +} +  /* Looks for the calendar application and enables the item if     we have one */  static gboolean  check_for_calendar (gpointer user_data)  {  	g_return_val_if_fail (calendar != NULL, FALSE); +	 +	if (!g_settings_get_boolean(conf, SETTINGS_SHOW_CALENDAR_S)) return FALSE;  	gchar *evo = g_find_program_in_path("evolution");  	if (evo != NULL) {  		g_debug("Found the calendar application: %s", evo);  		dbusmenu_menuitem_property_set_bool(calendar, DBUSMENU_MENUITEM_PROP_ENABLED, TRUE);  		dbusmenu_menuitem_property_set_bool(calendar, DBUSMENU_MENUITEM_PROP_VISIBLE, TRUE); -/* -		GError *gerror = NULL; -		// TODO: In reality we should iterate sources of calendar, but getting the local one doens't lag for > a minute -		g_debug("Setting up ecal."); -		if (!ecal) -			ecal = e_cal_new_system_calendar(); -	 -		if (!ecal) { -			g_debug("e_cal_new_system_calendar failed"); -			ecal = NULL; -		} -		g_debug("Open calendar."); -		if (!e_cal_open(ecal, FALSE, &gerror) ) { -			g_debug("e_cal_open: %s\n", gerror->message); -			g_free(ecal); -			ecal = NULL; -		} -		g_debug("Get calendar timezone."); -		if (!e_cal_get_timezone(ecal, "UTC", &tzone, &gerror)) { -			g_debug("failed to get time zone\n"); -			g_free(ecal); -			ecal = NULL; -		} -	 -		 This timezone represents the timezone of the calendar, this might be different to the current UTC offset. -		 * this means we'll have some geoclue interaction going on, and possibly the user will be involved in setting -		 * their location manually, case in point: trains have satellite links which often geoclue to sweden, -		 * this shouldn't automatically set the location and mess up all the appointments for the user. -		  -		if (ecal) ecal_timezone = icaltimezone_get_tzid(tzone); -		*/ +  		DbusmenuMenuitem * separator = dbusmenu_menuitem_new();  		dbusmenu_menuitem_property_set(separator, DBUSMENU_MENUITEM_PROP_TYPE, DBUSMENU_CLIENT_TYPES_SEPARATOR); -		dbusmenu_menuitem_child_add_position(root, separator, 3); +		dbusmenu_menuitem_child_add_position(root, separator, 2);  		add_appointment = dbusmenu_menuitem_new();  		dbusmenu_menuitem_property_set     (add_appointment, DBUSMENU_MENUITEM_PROP_LABEL, _("Add Appointment")); @@ -320,9 +304,12 @@ check_for_calendar (gpointer user_data)  		g_signal_connect(G_OBJECT(add_appointment), DBUSMENU_MENUITEM_SIGNAL_ITEM_ACTIVATED, G_CALLBACK(activate_cb), "evolution -c calendar");  		dbusmenu_menuitem_child_add_position (root, add_appointment, 3); -		update_appointment_menu_items(NULL); -		g_signal_connect(root, DBUSMENU_MENUITEM_SIGNAL_ABOUT_TO_SHOW, G_CALLBACK(update_appointment_menu_items), NULL);	 - +		// Update the calendar items every 5 minutes if it updates the first time +		if (update_appointment_menu_items(NULL)) +			g_timeout_add_seconds(60*5, update_appointment_menu_items, NULL);  +			 +		// Connect to event::month-changed  +		g_signal_connect(calendar, "event::month-changed", G_CALLBACK(month_changed_cb), NULL);  		g_free(evo);  	} else {  		g_debug("Unable to find calendar app."); @@ -337,6 +324,7 @@ check_for_calendar (gpointer user_data)  static gboolean  update_timezone_menu_items(gpointer user_data) {  	g_debug("Updating timezone menu items"); +  	gchar ** locations = g_settings_get_strv(conf, SETTINGS_LOCATIONS_S);  	if (locations == NULL) {   		g_debug("No locations configured (NULL)"); @@ -403,7 +391,7 @@ auth_func (ECal *ecal, const gchar *prompt, const gchar *key, gpointer user_data  	else component_name = "Calendar";  	gchar *password = e_passwords_get_password (component_name, key); - +	  	if (password == NULL) {  		password = e_passwords_ask_password (  			_("Enter password"), @@ -471,6 +459,9 @@ static gboolean  update_appointment_menu_items (gpointer user_data) {  	// FFR: we should take into account short term timers, for instance  	// tea timers, pomodoro timers etc... that people may add, this is hinted to in the spec. +	if (calendar == NULL) return FALSE; +	if (!g_settings_get_boolean(conf, SETTINGS_SHOW_EVENTS_S)) return FALSE; +	  	time_t t1, t2;  	gchar *query, *is, *ie, *ad;  	GList *objects = NULL, *l; @@ -523,7 +514,6 @@ update_appointment_menu_items (gpointer user_data) {  			g_signal_connect (G_OBJECT(source), "changed", G_CALLBACK (update_appointment_menu_items), NULL);  			ECal *ecal = e_cal_new(source, E_CAL_SOURCE_TYPE_EVENT);  			e_cal_set_auth_func (ecal, (ECalAuthFunc) auth_func, NULL); -			//icaltimezone * tzone;  			if (!e_cal_open(ecal, FALSE, &gerror)) {  				g_debug("Failed to get ecal sources %s", gerror->message); @@ -536,7 +526,8 @@ update_appointment_menu_items (gpointer user_data) {  			if (!e_cal_get_object_list_as_comp(ecal, query, &objects, &gerror)) {  				g_debug("Failed to get objects\n");  				g_free(ecal); -				return FALSE; +				gerror = NULL; +				continue;  			}  			g_debug("Number of objects returned: %d", g_list_length(objects)); @@ -681,6 +672,8 @@ update_appointment_menu_items (gpointer user_data) {  		if (i == 4) break; // See above FIXME regarding query result limit  		i++;  	} +	 +    if (gerror != NULL) g_error_free(gerror);  	g_object_unref(allobjects);  	g_debug("End of objects");  	return TRUE; diff --git a/src/dbus-shared.h b/src/dbus-shared.h index f0f05a9..fa6de7b 100644 --- a/src/dbus-shared.h +++ b/src/dbus-shared.h @@ -27,7 +27,14 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #define  MENU_OBJ      "/com/canonical/indicator/datetime/menu" -#define  DBUSMENU_CALENDAR_MENUITEM_TYPE "x-canonical-calendar-item" +#define DBUSMENU_CALENDAR_MENUITEM_TYPE    "x-canonical-calendar-item" + +// The following properties are not *really* properties, but are just +// a way of accessing the calendar from the service +#define CALENDAR_MENUITEM_PROP_MARK        "calendar-mark" +#define CALENDAR_MENUITEM_PROP_UNMARK      "calendar-unmark" +#define CALENDAR_MENUITEM_PROP_CLEAR_MARKS "calendar-clear-marks" +  #define APPOINTMENT_MENUITEM_TYPE          "appointment-item"	  #define APPOINTMENT_MENUITEM_PROP_LABEL    "appointment-label" diff --git a/src/indicator-datetime.c b/src/indicator-datetime.c index 2e336c7..2099929 100644 --- a/src/indicator-datetime.c +++ b/src/indicator-datetime.c @@ -25,6 +25,7 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  /* GStuff */  #include <glib.h> +#include <glib/gprintf.h>  #include <glib-object.h>  #include <glib/gi18n-lib.h>  #include <gio/gio.h> @@ -36,7 +37,7 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  /* DBusMenu */  #include <libdbusmenu-gtk/menu.h> -#include <libido/idocalendarmenuitem.h> +#include <libido/libido.h>  #include <libdbusmenu-gtk/menuitem.h>  #include "utils.h" @@ -77,6 +78,9 @@ struct _IndicatorDatetimePrivate {  	gchar * custom_string;  	gboolean custom_show_seconds; +	gboolean show_week_numbers; +	gint week_start; +	  	guint idle_measure;  	gint  max_width; @@ -100,7 +104,8 @@ enum {  	PROP_SHOW_SECONDS,  	PROP_SHOW_DAY,  	PROP_SHOW_DATE, -	PROP_CUSTOM_TIME_FORMAT +	PROP_CUSTOM_TIME_FORMAT, +	PROP_SHOW_WEEK_NUMBERS  };  typedef struct _indicator_item_t indicator_item_t; @@ -118,6 +123,7 @@ struct _indicator_item_t {  #define PROP_SHOW_DAY_S                 "show-day"  #define PROP_SHOW_DATE_S                "show-date"  #define PROP_CUSTOM_TIME_FORMAT_S       "custom-time-format" +#define PROP_SHOW_WEEK_NUMBERS_S        "show-week-numbers"  #define INDICATOR_DATETIME_GET_PRIVATE(o) \  (G_TYPE_INSTANCE_GET_PRIVATE ((o), INDICATOR_DATETIME_TYPE, IndicatorDatetimePrivate)) @@ -222,6 +228,13 @@ indicator_datetime_class_init (IndicatorDatetimeClass *klass)  	                                                     DEFAULT_TIME_FORMAT,  	                                                     G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS)); +	g_object_class_install_property (object_class, +	                                 PROP_SHOW_WEEK_NUMBERS, +	                                 g_param_spec_boolean(PROP_SHOW_WEEK_NUMBERS_S, +	                                                      "Whether to show the week numbers in the calendar.", +	                                                      "Shows the week numbers in the monthly calendar in indicator-datetime's menu.", +	                                                      FALSE, /* default */ +	                                                      G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));  	return;  } @@ -280,6 +293,11 @@ indicator_datetime_init (IndicatorDatetime *self)  		                self,  		                PROP_CUSTOM_TIME_FORMAT_S,  		                G_SETTINGS_BIND_DEFAULT); +		g_settings_bind(self->priv->settings, +		                SETTINGS_SHOW_WEEK_NUMBERS_S, +		                self, +		                PROP_SHOW_WEEK_NUMBERS_S, +		                G_SETTINGS_BIND_DEFAULT);  	} else {  		g_warning("Unable to get settings for '" SETTINGS_INTERFACE "'");  	} @@ -506,6 +524,18 @@ set_property (GObject * object, guint prop_id, const GValue * value, GParamSpec  		}  		break;  	} +	case PROP_SHOW_WEEK_NUMBERS: { +		if (g_value_get_boolean(value) != self->priv->show_week_numbers) { +			GtkCalendarDisplayOptions flags = ido_calendar_menu_item_get_display_options (self->priv->ido_calendar); +			if (g_value_get_boolean(value) == TRUE) +				flags |= GTK_CALENDAR_SHOW_WEEK_NUMBERS; +			else +				flags &= ~GTK_CALENDAR_SHOW_WEEK_NUMBERS; +			ido_calendar_menu_item_set_display_options (self->priv->ido_calendar, flags); +			self->priv->show_week_numbers = g_value_get_boolean(value); +		} +		break; +	}  	default:  		G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);  		return; @@ -561,6 +591,9 @@ get_property (GObject * object, guint prop_id, GValue * value, GParamSpec * pspe  	case PROP_CUSTOM_TIME_FORMAT:  		g_value_set_string(value, self->priv->custom_string);  		break; +	case PROP_SHOW_WEEK_NUMBERS: +		g_value_set_boolean(value, self->priv->show_week_numbers); +		break;  	default:  		G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);  		return; @@ -1055,6 +1088,15 @@ indicator_prop_change_cb (DbusmenuMenuitem * mi, gchar * prop, GVariant *value,  		timezone_update_labels(mi_data);  	} else if (!g_strcmp0(prop, TIMEZONE_MENUITEM_PROP_RADIO)) {  		gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(mi_data->gmi), g_variant_get_boolean(value)); +		 +	// Properties for marking and unmarking the calendar +	 +	} else if (!g_strcmp0(prop, CALENDAR_MENUITEM_PROP_MARK)) { +		ido_calendar_menu_item_mark_day (IDO_CALENDAR_MENU_ITEM (mi_data), g_variant_get_int16(value)); +	} else if (!g_strcmp0(prop, CALENDAR_MENUITEM_PROP_UNMARK)) { +		ido_calendar_menu_item_unmark_day (IDO_CALENDAR_MENU_ITEM (mi_data), g_variant_get_int16(value)); +	} else if (!g_strcmp0(prop, CALENDAR_MENUITEM_PROP_CLEAR_MARKS)) { +		ido_calendar_menu_item_clear_marks (IDO_CALENDAR_MENU_ITEM (mi_data));  	} else {  		g_warning("Indicator Item property '%s' unknown", prop);  	} @@ -1138,6 +1180,20 @@ new_appointment_item (DbusmenuMenuitem * newitem, DbusmenuMenuitem * parent, Dbu  	return TRUE;  } +static void +month_changed_cb (IdoCalendarMenuItem *ido,  +                  gpointer        user_data)  +{ +	gchar datestring[20]; +	guint d,m,y; +	DbusmenuMenuitem * item = DBUSMENU_MENUITEM (user_data); +	ido_calendar_menu_item_get_date(ido, &y, &m, &d); +	g_sprintf(datestring, "%d-%d-%d", y, m, d); +	GVariant *variant = g_variant_new_string(datestring); +	guint timestamp = (guint)time(NULL); +	dbusmenu_menuitem_handle_event(DBUSMENU_MENUITEM(item), "event::month-changed", variant, timestamp); +	g_debug("Got month changed signal: %s", datestring); +}  static gboolean  new_calendar_item (DbusmenuMenuitem * newitem, @@ -1162,7 +1218,7 @@ new_calendar_item (DbusmenuMenuitem * newitem,  	self->priv->ido_calendar = ido;  	dbusmenu_gtkclient_newitem_base(DBUSMENU_GTKCLIENT(client), newitem, GTK_MENU_ITEM(ido), parent); - +	g_signal_connect_after(ido, "month-changed", G_CALLBACK(month_changed_cb), (gpointer)newitem);  	return TRUE;  } | 
