diff options
| -rw-r--r-- | src/datetime-prefs.c | 43 | ||||
| -rw-r--r-- | src/datetime-service.c | 2 | ||||
| -rw-r--r-- | src/indicator-datetime.c | 31 | 
3 files changed, 70 insertions, 6 deletions
| diff --git a/src/datetime-prefs.c b/src/datetime-prefs.c index 5248911..fbc88f2 100644 --- a/src/datetime-prefs.c +++ b/src/datetime-prefs.c @@ -35,6 +35,7 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #include <unique/unique.h>  #include <polkitgtk/polkitgtk.h> +#include "dbus-shared.h"  #include "settings-shared.h"  #include "utils.h"  #include "datetime-prefs-locations.h" @@ -225,7 +226,8 @@ tz_query_answered (GObject *object, GAsyncResult *res, gpointer user_data)    g_variant_unref (answers);  } -void proxy_ready (GObject *object, GAsyncResult *res, gpointer user_data) +static void +proxy_ready (GObject *object, GAsyncResult *res, gpointer user_data)  {    GError * error = NULL; @@ -244,6 +246,35 @@ void proxy_ready (GObject *object, GAsyncResult *res, gpointer user_data)                       NULL, tz_query_answered, NULL);  } +static void +service_name_owner_changed (GDBusProxy * proxy, GParamSpec *pspec, gpointer user_data) +{ +  GtkWidget * widget = GTK_WIDGET (user_data); +  gchar * owner = g_dbus_proxy_get_name_owner (proxy); + +  gtk_widget_set_sensitive (widget, (owner != NULL)); + +  g_free (owner); +} + +static void +service_proxy_ready (GObject *object, GAsyncResult *res, gpointer user_data) +{ +  GError * error = NULL; + +  proxy = g_dbus_proxy_new_for_bus_finish (res, &error); + +  if (error != NULL) { +    g_critical("Could not grab DBus proxy for indicator-datetime-service: %s", error->message); +    g_error_free(error); +    return; +  } + +  /* And now, do initial proxy configuration */ +  g_signal_connect (proxy, "notify::g-name-owner", G_CALLBACK (service_name_owner_changed), user_data); +  service_name_owner_changed (proxy, NULL, user_data); +} +  static gboolean  are_spinners_focused (void)  { @@ -634,6 +665,15 @@ create_dialog (void)                              "org.gnome.SettingsDaemon.DateTimeMechanism",                              NULL, proxy_ready, NULL); +  /* Grab proxy for datetime service, to see if it's running.  It would +     actually be more ideal to see if the indicator module itself is running, +     but that doesn't yet claim a name on the bus.  Presumably the service +     would have been started by any such indicator, so this will at least tell +     us if there *was* a datetime module run this session. */ +  g_dbus_proxy_new_for_bus (G_BUS_TYPE_SESSION, G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START, NULL, +                            SERVICE_NAME, SERVICE_OBJ, SERVICE_IFACE, +                            NULL, service_proxy_ready, WIG ("showClockCheck")); +  #undef WIG    g_object_unref (conf); @@ -678,7 +718,6 @@ main (int argc, char ** argv)      unique_app_watch_window (app, GTK_WINDOW (dlg));      gtk_widget_show_all (dlg); -    g_signal_connect (dlg, "response", G_CALLBACK(gtk_main_quit), NULL);      g_signal_connect (dlg, "destroy", G_CALLBACK(gtk_main_quit), NULL);      gtk_main ();    } diff --git a/src/datetime-service.c b/src/datetime-service.c index 6f38004..3a0a3f0 100644 --- a/src/datetime-service.c +++ b/src/datetime-service.c @@ -336,8 +336,6 @@ 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) { diff --git a/src/indicator-datetime.c b/src/indicator-datetime.c index 618d00d..46ed0d9 100644 --- a/src/indicator-datetime.c +++ b/src/indicator-datetime.c @@ -85,6 +85,7 @@ struct _IndicatorDatetimePrivate {  	gboolean custom_show_seconds;  	gboolean show_week_numbers; +	gboolean show_calendar;  	gint week_start;  	guint idle_measure; @@ -112,7 +113,8 @@ enum {  	PROP_SHOW_DAY,  	PROP_SHOW_DATE,  	PROP_CUSTOM_TIME_FORMAT, -	PROP_SHOW_WEEK_NUMBERS +	PROP_SHOW_WEEK_NUMBERS, +	PROP_SHOW_CALENDAR  };  typedef struct _indicator_item_t indicator_item_t; @@ -132,6 +134,7 @@ struct _indicator_item_t {  #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 PROP_SHOW_CALENDAR_S            "show-calendar"  #define INDICATOR_DATETIME_GET_PRIVATE(o) \  (G_TYPE_INSTANCE_GET_PRIVATE ((o), INDICATOR_DATETIME_TYPE, IndicatorDatetimePrivate)) @@ -250,6 +253,13 @@ indicator_datetime_class_init (IndicatorDatetimeClass *klass)  	                                                      "Shows the week numbers in the monthly calendar in indicator-datetime's menu.",  	                                                      FALSE, /* default */  	                                                      G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS)); +	g_object_class_install_property (object_class, +	                                 PROP_SHOW_CALENDAR, +	                                 g_param_spec_boolean(PROP_SHOW_CALENDAR_S, +	                                                      "Whether to show the calendar.", +	                                                      "Shows the monthly calendar in indicator-datetime's menu.", +	                                                      TRUE, /* default */ +	                                                      G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));  	return;  } @@ -319,6 +329,11 @@ indicator_datetime_init (IndicatorDatetime *self)  		                self,  		                PROP_SHOW_WEEK_NUMBERS_S,  		                G_SETTINGS_BIND_DEFAULT); +		g_settings_bind(self->priv->settings, +		                SETTINGS_SHOW_CALENDAR_S, +		                self, +		                PROP_SHOW_CALENDAR_S, +		                G_SETTINGS_BIND_DEFAULT);  	} else {  		g_warning("Unable to get settings for '" SETTINGS_INTERFACE "'");  	} @@ -564,6 +579,13 @@ set_property (GObject * object, guint prop_id, const GValue * value, GParamSpec  		}  		break;  	} +	case PROP_SHOW_CALENDAR: { +		if (g_value_get_boolean(value) != self->priv->show_calendar) { +			self->priv->show_calendar = g_value_get_boolean(value); +			gtk_widget_set_visible (GTK_WIDGET (self->priv->ido_calendar), self->priv->show_calendar); +		} +		break; +	}  	default:  		G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);  		return; @@ -625,6 +647,9 @@ get_property (GObject * object, guint prop_id, GValue * value, GParamSpec * pspe  	case PROP_SHOW_WEEK_NUMBERS:  		g_value_set_boolean(value, self->priv->show_week_numbers);  		break; +	case PROP_SHOW_CALENDAR: +		g_value_set_boolean(value, self->priv->show_calendar); +		break;  	default:  		G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);  		return; @@ -1254,7 +1279,9 @@ new_calendar_item (DbusmenuMenuitem * newitem,  	else  		flags &= ~GTK_CALENDAR_SHOW_WEEK_NUMBERS;  	ido_calendar_menu_item_set_display_options (self->priv->ido_calendar, flags); -	 + +	gtk_widget_set_visible (GTK_WIDGET (self->priv->ido_calendar), self->priv->show_calendar); +  	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; | 
