diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/Makefile.am | 20 | ||||
| -rw-r--r-- | src/datetime-prefs.c | 211 | ||||
| -rw-r--r-- | src/datetime-service.c | 14 | ||||
| -rw-r--r-- | src/indicator-datetime.c | 31 | ||||
| -rw-r--r-- | src/settings-shared.h | 39 | ||||
| -rw-r--r-- | src/utils.c | 45 | ||||
| -rw-r--r-- | src/utils.h | 34 | 
7 files changed, 356 insertions, 38 deletions
| diff --git a/src/Makefile.am b/src/Makefile.am index 7a290c6..150c87d 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -1,4 +1,5 @@ +bin_PROGRAMS = indicator-datetime-preferences  libexec_PROGRAMS = indicator-datetime-service  indicator_datetime_service_SOURCES = \ @@ -8,7 +9,8 @@ indicator_datetime_service_SOURCES = \  	calendar-menu-item.c \  	calendar-menu-item.h \  	datetime-service.c \ -	dbus-shared.h +	dbus-shared.h \ +	settings-shared.h  indicator_datetime_service_CFLAGS = \  	-Wall \  	-Werror \ @@ -23,6 +25,9 @@ datetimelib_LTLIBRARIES = libdatetime.la  libdatetime_la_SOURCES = \  	gen-datetime-service.xml.h \  	dbus-shared.h \ +	settings-shared.h \ +	utils.c \ +	utils.h \  	indicator-datetime.c  libdatetime_la_CFLAGS = \  	$(INDICATOR_CFLAGS) \ @@ -34,6 +39,19 @@ libdatetime_la_LDFLAGS = \  	-module \  	-avoid-version +indicator_datetime_preferences_SOURCES =\ +	datetime-prefs.c \ +	utils.c \ +	utils.h \ +	settings-shared.h +indicator_datetime_preferences_CFLAGS = \ +	-Wall \ +	-Werror \ +	$(PREF_CFLAGS) \ +	-DPKGDATADIR="\"$(pkgdatadir)\"" +indicator_datetime_preferences_LDADD = \ +	$(PREF_LIBS) +  gen-%.xml.c: %.xml  	@echo "Building $@ from $<"  	@echo "const char * _$(subst -,_,$(subst .,_,$(basename $<))) = " > $@ diff --git a/src/datetime-prefs.c b/src/datetime-prefs.c new file mode 100644 index 0000000..1957b7f --- /dev/null +++ b/src/datetime-prefs.c @@ -0,0 +1,211 @@ +/* -*- Mode: C; coding: utf-8; indent-tabs-mode: nil; tab-width: 2 -*- + +A dialog for setting time and date preferences. + +Copyright 2011 Canonical Ltd. + +Authors: +    Ted Gould <ted@canonical.com> +    Michael Terry <michael.terry@canonical.com> + +This program is free software: you can redistribute it and/or modify it  +under the terms of the GNU General Public License version 3, as published  +by the Free Software Foundation. + +This program is distributed in the hope that it will be useful, but  +WITHOUT ANY WARRANTY; without even the implied warranties of  +MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR  +PURPOSE.  See the GNU General Public License for more details. + +You should have received a copy of the GNU General Public License along  +with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <libintl.h> +#include <locale.h> +#include <gtk/gtk.h> +#include <unique/unique.h> + +#include "settings-shared.h" +#include "utils.h" + +#define DATETIME_DIALOG_UI_FILE PKGDATADIR "/datetime-dialog.ui" + +/* Turns the boolean property into a string gsettings */ +static GVariant * +bind_hours_set (const GValue * value, const GVariantType * type, gpointer user_data) +{ +  const gchar * output = NULL; +  gboolean is_12hour_button = (gboolean)GPOINTER_TO_INT(user_data); + +	if (g_value_get_boolean(value)) { +    /* Only do anything if we're setting active = true */ +		output = is_12hour_button ? "12-hour" : "24-hour"; +	} else { +    return NULL; +  } + +	return g_variant_new_string (output); +} + +/* Turns a string gsettings into a boolean property */ +static gboolean +bind_hours_get (GValue * value, GVariant * variant, gpointer user_data) +{ +	const gchar * str = g_variant_get_string(variant, NULL); +	gboolean output = FALSE; +  gboolean is_12hour_button = (gboolean)GPOINTER_TO_INT(user_data); + +	if (g_strcmp0(str, "locale-default") == 0) { +		output = (is_12hour_button == is_locale_12h ()); +	} else if (g_strcmp0(str, "12-hour") == 0) { +		output = is_12hour_button; +	} else if (g_strcmp0(str, "24-hour") == 0) { +		output = !is_12hour_button; +	} else { +		return FALSE; +	} + +	g_value_set_boolean (value, output); +	return TRUE; +} + +static void +widget_dependency_cb (GtkWidget * parent, GParamSpec *pspec, GtkWidget * dependent) +{ +  gboolean active, sensitive; +  g_object_get (G_OBJECT (parent), +                "active", &active, +                "sensitive", &sensitive, NULL); +  gtk_widget_set_sensitive (dependent, active && sensitive); +} + +static void +add_widget_dependency (GtkWidget * parent, GtkWidget * dependent) +{ +  g_signal_connect (parent, "notify::active", G_CALLBACK(widget_dependency_cb), +                    dependent); +  g_signal_connect (parent, "notify::sensitive", G_CALLBACK(widget_dependency_cb), +                    dependent); +  widget_dependency_cb (parent, NULL, dependent); +} + +static GtkWidget * +create_dialog (void) +{ +  GError * error = NULL; + +  GtkBuilder * builder = gtk_builder_new (); +  gtk_builder_add_from_file (builder, DATETIME_DIALOG_UI_FILE, &error); +  if (error != NULL) { +    /* We have to abort, we can't continue without the ui file */ +    g_error ("Could not load ui file %s: %s", DATETIME_DIALOG_UI_FILE, error->message); +    g_error_free (error); +    return NULL; +  } + +  gtk_builder_set_translation_domain (builder, GETTEXT_PACKAGE); + +	GSettings * conf = g_settings_new (SETTINGS_INTERFACE); + +#define WIG(name) GTK_WIDGET (gtk_builder_get_object (builder, name)) + +  /* Set up settings bindings */ + +  g_settings_bind (conf, SETTINGS_SHOW_CLOCK_S, WIG ("showClockCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); +  g_settings_bind (conf, SETTINGS_SHOW_DAY_S, WIG ("showWeekdayCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); +  g_settings_bind (conf, SETTINGS_SHOW_DATE_S, WIG ("showDateTimeCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); +  g_settings_bind (conf, SETTINGS_SHOW_SECONDS_S, WIG ("showSecondsCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); +  g_settings_bind_with_mapping (conf, SETTINGS_TIME_FORMAT_S, +                                WIG ("show12HourRadio"), "active", +                                G_SETTINGS_BIND_DEFAULT, +                                bind_hours_get, bind_hours_set, +                                GINT_TO_POINTER(TRUE), NULL); +  g_settings_bind_with_mapping (conf, SETTINGS_TIME_FORMAT_S, +                                WIG ("show24HourRadio"), "active", +                                G_SETTINGS_BIND_DEFAULT, +                                bind_hours_get, bind_hours_set, +                                GINT_TO_POINTER(FALSE), NULL); +  g_settings_bind (conf, SETTINGS_SHOW_CALENDAR_S, WIG ("showCalendarCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); +  g_settings_bind (conf, SETTINGS_SHOW_WEEK_NUMBERS_S, WIG ("includeWeekNumbersCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); +  /*g_settings_bind_(conf, SETTINGS_WEEK_BEGINS_SUNDAY_S, WIG ("startOnSundayRadio"), +                   "active", G_SETTINGS_BIND_DEFAULT);*/ +  g_settings_bind (conf, SETTINGS_SHOW_EVENTS_S, WIG ("showEventsCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); +  g_settings_bind (conf, SETTINGS_SHOW_LOCATIONS_S, WIG ("showLocationsCheck"), +                   "active", G_SETTINGS_BIND_DEFAULT); + +  /* Set up sensitivities */ +  add_widget_dependency (WIG ("showCalendarCheck"), WIG ("calendarOptions")); +  add_widget_dependency (WIG ("showClockCheck"), WIG ("clockOptions")); +  add_widget_dependency (WIG ("showLocationsCheck"), WIG ("locationsButton")); +  add_widget_dependency (WIG ("manualTimeRadio"), WIG ("manualOptions")); + +  /* Hacky proxy test for whether evolution-data-server is installed */ +  gchar * evo_path = g_find_program_in_path ("evolution"); +  gtk_widget_set_sensitive (WIG ("showEventsCheck"), (evo_path != NULL)); +  g_free (evo_path); + +  GtkWidget * dlg = WIG ("timeDateDialog"); + +#undef WIG + +  g_object_unref (conf); +  g_object_unref (builder); + +  return dlg; +} + +static UniqueResponse +message_received (UniqueApp * app, gint command, UniqueMessageData *message_data, +                  guint time, gpointer user_data) +{ +  if (command == UNIQUE_ACTIVATE) { +    gtk_window_present_with_time (GTK_WINDOW (user_data), time); +    return UNIQUE_RESPONSE_OK; +  } +  return UNIQUE_RESPONSE_PASSTHROUGH; +} + +int +main (int argc, char ** argv) +{ +	g_type_init (); + +	/* Setting up i18n and gettext.  Apparently, we need +	   all of these. */ +	setlocale (LC_ALL, ""); +	bindtextdomain (GETTEXT_PACKAGE, GNOMELOCALEDIR); +	textdomain (GETTEXT_PACKAGE); + +	gtk_init (&argc, &argv); + +	UniqueApp * app = unique_app_new ("com.canonical.indicator.datetime.preferences", NULL); + +  if (unique_app_is_running (app)) { +    unique_app_send_message (app, UNIQUE_ACTIVATE, NULL); +  } else { +    // We're first instance.  Yay! +    GtkWidget * dlg = create_dialog (); + +    g_signal_connect (app, "message-received", G_CALLBACK(message_received), dlg); +    unique_app_watch_window (app, GTK_WINDOW (dlg)); + +    gtk_widget_show_all (dlg); +    g_signal_connect (dlg, "response", G_CALLBACK(gtk_main_quit), NULL); +    gtk_main (); +  } + +  return 0; +} + diff --git a/src/datetime-service.c b/src/datetime-service.c index 0894e83..cc6c9d5 100644 --- a/src/datetime-service.c +++ b/src/datetime-service.c @@ -51,11 +51,9 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #include "datetime-interface.h"  #include "dbus-shared.h" +#include "settings-shared.h" -#define SETTINGS_INTERFACE "com.canonical.indicator.datetime" -#define SETTINGS_LOCATIONS "locations" -  static void geo_create_client (GeoclueMaster * master, GeoclueMasterClient * client, gchar * path, GError * error, gpointer user_data);  static gboolean update_appointment_menu_items (gpointer user_data);  static gboolean update_timezone_menu_items(gpointer user_data); @@ -363,7 +361,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); +	gchar ** locations = g_settings_get_strv(conf, SETTINGS_LOCATIONS_S);  	if (locations == NULL) {   		g_debug("No locations configured (NULL)");  		return FALSE; @@ -648,13 +646,13 @@ check_for_timeadmin (gpointer user_data)  {  	g_return_val_if_fail (settings != NULL, FALSE); -	gchar * timeadmin = g_find_program_in_path("time-admin"); +	gchar * timeadmin = g_find_program_in_path("indicator-datetime-preferences");  	if (timeadmin != NULL) { -		g_debug("Found the time-admin application: %s", timeadmin); +		g_debug("Found the indicator-datetime-preferences application: %s", timeadmin);  		dbusmenu_menuitem_property_set_bool(settings, DBUSMENU_MENUITEM_PROP_ENABLED, TRUE);  		g_free(timeadmin);  	} else { -		g_debug("Unable to find time-admin app."); +		g_debug("Unable to find indicator-datetime-preferences app.");  		dbusmenu_menuitem_property_set_bool(settings, DBUSMENU_MENUITEM_PROP_ENABLED, FALSE);  	} @@ -721,7 +719,7 @@ build_menus (DbusmenuMenuitem * root)  	dbusmenu_menuitem_property_set     (settings, DBUSMENU_MENUITEM_PROP_LABEL, _("Time & Date Settings..."));  	/* insensitive until we check for available apps */  	dbusmenu_menuitem_property_set_bool(settings, DBUSMENU_MENUITEM_PROP_ENABLED, FALSE); -	g_signal_connect(G_OBJECT(settings), DBUSMENU_MENUITEM_SIGNAL_ITEM_ACTIVATED, G_CALLBACK(activate_cb), "time-admin"); +	g_signal_connect(G_OBJECT(settings), DBUSMENU_MENUITEM_SIGNAL_ITEM_ACTIVATED, G_CALLBACK(activate_cb), "indicator-datetime-preferences");  	dbusmenu_menuitem_child_append(root, settings);  	g_idle_add(check_for_timeadmin, NULL); diff --git a/src/indicator-datetime.c b/src/indicator-datetime.c index 0f60428..e27158c 100644 --- a/src/indicator-datetime.c +++ b/src/indicator-datetime.c @@ -23,10 +23,6 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #include "config.h"  #endif -#include <locale.h> -#include <langinfo.h> -#include <string.h> -  /* GStuff */  #include <glib.h>  #include <glib-object.h> @@ -43,7 +39,9 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #include <libido/idocalendarmenuitem.h>  #include <libdbusmenu-gtk/menuitem.h> +#include "utils.h"  #include "dbus-shared.h" +#include "settings-shared.h"  #define INDICATOR_DATETIME_TYPE            (indicator_datetime_get_type ()) @@ -117,13 +115,6 @@ struct _indicator_item_t {  #define PROP_SHOW_DATE_S                "show-date"  #define PROP_CUSTOM_TIME_FORMAT_S       "custom-time-format" -#define SETTINGS_INTERFACE              "com.canonical.indicator.datetime" -#define SETTINGS_TIME_FORMAT_S          "time-format" -#define SETTINGS_SHOW_SECONDS_S         "show-seconds" -#define SETTINGS_SHOW_DAY_S             "show-day" -#define SETTINGS_SHOW_DATE_S            "show-date" -#define SETTINGS_CUSTOM_TIME_FORMAT_S   "custom-time-format" -  enum {  	SETTINGS_TIME_LOCALE = 0,  	SETTINGS_TIME_12_HOUR = 1, @@ -964,24 +955,6 @@ T_(const char *msg)  	return rv;  } -/* Check the system locale setting to see if the format is 24-hour -   time or 12-hour time */ -static gboolean -is_locale_12h() -{ -	static const char *formats_24h[] = {"%H", "%R", "%T", "%OH", "%k", NULL}; -	const char *t_fmt = nl_langinfo(T_FMT); -	int i; - -	for (i = 0; formats_24h[i]; ++i) { -		if (strstr(t_fmt, formats_24h[i])) { -			return FALSE; -		} -	} - -	return TRUE; -} -  /* Respond to changes in the screen to update the text gravity */  static void  update_text_gravity (GtkWidget *widget, GdkScreen *previous_screen, gpointer data) diff --git a/src/settings-shared.h b/src/settings-shared.h new file mode 100644 index 0000000..1a66688 --- /dev/null +++ b/src/settings-shared.h @@ -0,0 +1,39 @@ +/* +An indicator to show date and time information. + +Copyright 2010 Canonical Ltd. + +Authors: +    Ted Gould <ted@canonical.com> + +This program is free software: you can redistribute it and/or modify it  +under the terms of the GNU General Public License version 3, as published  +by the Free Software Foundation. + +This program is distributed in the hope that it will be useful, but  +WITHOUT ANY WARRANTY; without even the implied warranties of  +MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR  +PURPOSE.  See the GNU General Public License for more details. + +You should have received a copy of the GNU General Public License along  +with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +#ifndef __DATETIME_SETTINGS_SHARED_H__ +#define __DATETIME_SETTINGS_SHARED_H__ + +#define SETTINGS_INTERFACE              "com.canonical.indicator.datetime" +#define SETTINGS_SHOW_CLOCK_S           "show-clock" +#define SETTINGS_TIME_FORMAT_S          "time-format" +#define SETTINGS_SHOW_SECONDS_S         "show-seconds" +#define SETTINGS_SHOW_DAY_S             "show-day" +#define SETTINGS_SHOW_DATE_S            "show-date" +#define SETTINGS_CUSTOM_TIME_FORMAT_S   "custom-time-format" +#define SETTINGS_SHOW_CALENDAR_S        "show-calendar" +#define SETTINGS_SHOW_WEEK_NUMBERS_S    "show-week-numbers" +#define SETTINGS_WEEK_BEGINS_SUNDAY_S   "week-begins-sunday" +#define SETTINGS_SHOW_EVENTS_S          "show-events" +#define SETTINGS_SHOW_LOCATIONS_S       "show-locations" +#define SETTINGS_LOCATIONS_S            "locations" + +#endif diff --git a/src/utils.c b/src/utils.c new file mode 100644 index 0000000..69143b9 --- /dev/null +++ b/src/utils.c @@ -0,0 +1,45 @@ +/* -*- Mode: C; coding: utf-8; indent-tabs-mode: nil; tab-width: 2 -*- + +A dialog for setting time and date preferences. + +Copyright 2010 Canonical Ltd. + +Authors: +    Michael Terry <michael.terry@canonical.com> + +This program is free software: you can redistribute it and/or modify it  +under the terms of the GNU General Public License version 3, as published  +by the Free Software Foundation. + +This program is distributed in the hope that it will be useful, but  +WITHOUT ANY WARRANTY; without even the implied warranties of  +MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR  +PURPOSE.  See the GNU General Public License for more details. + +You should have received a copy of the GNU General Public License along  +with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +#include <locale.h> +#include <langinfo.h> +#include <string.h> +#include "utils.h" + +/* Check the system locale setting to see if the format is 24-hour +   time or 12-hour time */ +gboolean +is_locale_12h (void) +{ +	static const char *formats_24h[] = {"%H", "%R", "%T", "%OH", "%k", NULL}; +	const char *t_fmt = nl_langinfo (T_FMT); +	int i; + +	for (i = 0; formats_24h[i]; ++i) { +		if (strstr (t_fmt, formats_24h[i])) { +			return FALSE; +		} +	} + +	return TRUE; +} + diff --git a/src/utils.h b/src/utils.h new file mode 100644 index 0000000..f6305c8 --- /dev/null +++ b/src/utils.h @@ -0,0 +1,34 @@ +/* -*- Mode: C; coding: utf-8; indent-tabs-mode: nil; tab-width: 2 -*- + +A dialog for setting time and date preferences. + +Copyright 2010 Canonical Ltd. + +Authors: +    Michael Terry <michael.terry@canonical.com> + +This program is free software: you can redistribute it and/or modify it  +under the terms of the GNU General Public License version 3, as published  +by the Free Software Foundation. + +This program is distributed in the hope that it will be useful, but  +WITHOUT ANY WARRANTY; without even the implied warranties of  +MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR  +PURPOSE.  See the GNU General Public License for more details. + +You should have received a copy of the GNU General Public License along  +with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +#ifndef __DATETIME_UTILS_H__ +#define __DATETIME_UTILS_H__ + +#include <glib.h> + +G_BEGIN_DECLS + +gboolean is_locale_12h (void); + +G_END_DECLS + +#endif | 
