diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/Makefile.am | 22 | ||||
| -rw-r--r-- | src/datetime-prefs-locations.c | 137 | ||||
| -rw-r--r-- | src/datetime-prefs-locations.h | 34 | ||||
| -rw-r--r-- | src/datetime-prefs.c | 467 | ||||
| -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 | 
9 files changed, 785 insertions, 38 deletions
| diff --git a/src/Makefile.am b/src/Makefile.am index 7a290c6..94d179d 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,21 @@ libdatetime_la_LDFLAGS = \  	-module \  	-avoid-version +indicator_datetime_preferences_SOURCES =\ +	datetime-prefs.c \ +	datetime-prefs-locations.c \ +	datetime-prefs-locations.h \ +	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-locations.c b/src/datetime-prefs-locations.c new file mode 100644 index 0000000..24efd04 --- /dev/null +++ b/src/datetime-prefs-locations.c @@ -0,0 +1,137 @@ +/* -*- 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: +    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 <glib/gi18n.h> +#include <gtk/gtk.h> + +#include "datetime-prefs-locations.h" +#include "settings-shared.h" + +#define DATETIME_DIALOG_UI_FILE PKGDATADIR "/datetime-dialog.ui" + +static void +handle_add (GtkWidget * button, gpointer user_data) +{ +} + +static void +handle_remove (GtkWidget * button, gpointer user_data) +{ +} + +static void +fill_from_settings (GObject * store, GSettings * conf) +{ +  gchar ** locations = g_settings_get_strv (conf, SETTINGS_LOCATIONS_S); + +  gtk_list_store_clear (GTK_LIST_STORE (store)); + +  gchar ** striter; +  GtkTreeIter iter; +  for (striter = locations; *striter; ++striter) { +    gtk_list_store_append (GTK_LIST_STORE (store), &iter); +    gtk_list_store_set (GTK_LIST_STORE (store), &iter, 0, *striter, -1); +  } + +  g_strfreev (locations); +} + +static void +save_to_settings (GtkWidget * dlg, GObject * store) +{ +  GVariantBuilder builder; +  g_variant_builder_init (&builder, G_VARIANT_TYPE_ARRAY); + +  GtkTreeIter iter; +  if (gtk_tree_model_get_iter_first (GTK_TREE_MODEL (store), &iter)) { +    do { +      GValue value = {0}; +      gtk_tree_model_get_value (GTK_TREE_MODEL (store), &iter, 0, &value); +      g_variant_builder_add (&builder, "s", g_value_get_string (&value)); +      g_value_unset (&value); +    } while (gtk_tree_model_iter_next (GTK_TREE_MODEL (store), &iter)); +  } + +  GVariant * locations = g_variant_builder_end (&builder); + +  GSettings * conf = G_SETTINGS (g_object_get_data (G_OBJECT (dlg), "conf")); +  g_settings_set_strv (conf, SETTINGS_LOCATIONS_S, g_variant_get_strv (locations, NULL)); + +  g_variant_unref (locations); +} + +GtkWidget * +datetime_setup_locations_dialog (GtkWindow * parent) +{ +  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)) + +  GtkWidget * dlg = WIG ("locationsDialog"); +  GtkWidget * tree = WIG ("locationsView"); +  GObject * store = gtk_builder_get_object (builder, "locationsStore"); + +  /* Configure tree */ +  GtkCellRenderer * cell = gtk_cell_renderer_text_new (); +  g_object_set (cell, "editable", TRUE, NULL); +  gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (tree), -1, +                                               _("Location"), cell, +                                               "text", 0, NULL); +  cell = gtk_cell_renderer_text_new (); +  gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (tree), -1, +                                               _("Time"), cell, +                                               "text", 1, NULL); +  gtk_tree_selection_set_mode (gtk_tree_view_get_selection (GTK_TREE_VIEW (tree)), GTK_SELECTION_MULTIPLE); + +  g_signal_connect (WIG ("addButton"), "clicked", G_CALLBACK (handle_add), NULL); +  g_signal_connect (WIG ("removeButton"), "clicked", G_CALLBACK (handle_remove), NULL); + +  fill_from_settings (store, conf); +  g_object_set_data_full (G_OBJECT (dlg), "conf", g_object_ref (conf), g_object_unref); +  g_signal_connect (dlg, "destroy", G_CALLBACK (save_to_settings), store); + +  gtk_window_set_transient_for (GTK_WINDOW (dlg), parent); + +#undef WIG + +  g_object_unref (conf); +  g_object_unref (builder); + +  return dlg; +} + diff --git a/src/datetime-prefs-locations.h b/src/datetime-prefs-locations.h new file mode 100644 index 0000000..d5dd534 --- /dev/null +++ b/src/datetime-prefs-locations.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 2011 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_PREFS_LOCATIONS_H__ +#define __DATETIME_PREFS_LOCATIONS_H__ + +#include <gtk/gtk.h> + +G_BEGIN_DECLS + +GtkWidget * datetime_setup_locations_dialog (GtkWindow * parent); + +G_END_DECLS + +#endif diff --git a/src/datetime-prefs.c b/src/datetime-prefs.c new file mode 100644 index 0000000..97b106d --- /dev/null +++ b/src/datetime-prefs.c @@ -0,0 +1,467 @@ +/* -*- 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 <langinfo.h> +#include <glib/gi18n.h> +#include <gtk/gtk.h> +#include <unique/unique.h> +#include <polkitgtk/polkitgtk.h> + +#include "settings-shared.h" +#include "utils.h" +#include "datetime-prefs-locations.h" + +#define DATETIME_DIALOG_UI_FILE PKGDATADIR "/datetime-dialog.ui" + +GDBusProxy * proxy = NULL; + +/* 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 void +polkit_dependency_cb (GtkWidget * parent, GParamSpec *pspec, GtkWidget * dependent) +{ +  gboolean authorized, sensitive; +  g_object_get (G_OBJECT (parent), +                "is-authorized", &authorized, +                "sensitive", &sensitive, NULL); +  gtk_widget_set_sensitive (dependent, authorized && sensitive); +} + +static void +add_polkit_dependency (GtkWidget * parent, GtkWidget * dependent) +{ +  g_signal_connect (parent, "notify::is-authorized", G_CALLBACK(polkit_dependency_cb), +                    dependent); +  g_signal_connect (parent, "notify::sensitive", G_CALLBACK(polkit_dependency_cb), +                    dependent); +  polkit_dependency_cb (parent, NULL, dependent); +} + +void dbus_set_answered (GObject *object, GAsyncResult *res, gpointer command) +{ +  GError * error = NULL; +  GVariant * answers = g_dbus_proxy_call_finish (proxy, res, &error); + +  if (error != NULL) { +    g_warning("Could not set '%s' for SettingsDaemon: %s", (gchar *)command, error->message); +    g_error_free(error); +    return; +  } + +  g_variant_unref (answers); +} + +static void +toggle_ntp (GtkWidget * autoRadio, GParamSpec * pspec, gpointer user_data) +{ +  gboolean active = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (autoRadio)); + +  g_dbus_proxy_call (proxy, "SetUsingNtp", g_variant_new ("(b)", active), +                     G_DBUS_CALL_FLAGS_NONE, -1, NULL, dbus_set_answered, "using_ntp"); +} + +void ntp_query_answered (GObject *object, GAsyncResult *res, gpointer autoRadio) +{ +  GError * error = NULL; +  GVariant * answers = g_dbus_proxy_call_finish (proxy, res, &error); + +  if (error != NULL) { +    g_warning("Could not query DBus proxy for SettingsDaemon: %s", error->message); +    g_error_free(error); +    return; +  } + +  gboolean can_use_ntp, is_using_ntp; +  g_variant_get (answers, "(bb)", &can_use_ntp, &is_using_ntp); + +  gtk_widget_set_sensitive (GTK_WIDGET (autoRadio), can_use_ntp); +  gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (autoRadio), is_using_ntp); + +  g_signal_connect (autoRadio, "notify::active", G_CALLBACK(toggle_ntp), NULL); + +  g_variant_unref (answers); +} + +void proxy_ready (GObject *object, GAsyncResult *res, gpointer autoRadio) +{ +  GError * error = NULL; + +  proxy = g_dbus_proxy_new_for_bus_finish (res, &error); + +  if (error != NULL) { +    g_critical("Could not grab DBus proxy for SettingsDaemon: %s", error->message); +    g_error_free(error); +    return; +  } + +  /* And now, do initial proxy configuration */ +  g_dbus_proxy_call (proxy, "GetUsingNtp", NULL, G_DBUS_CALL_FLAGS_NONE, -1, +                     NULL, ntp_query_answered, autoRadio); +} + +static int +input_time_text (GtkWidget * spinner, gdouble *value, gpointer user_data) +{ +  gboolean is_time = (gboolean)GPOINTER_TO_INT (g_object_get_data (G_OBJECT (spinner), "is-time")); +  const gchar * text = gtk_entry_get_text (GTK_ENTRY (spinner)); + +  GDateTime * now = g_date_time_new_now_local (); +  gint year, month, day, hour, minute, second; +  year = g_date_time_get_year (now); +  month = g_date_time_get_month (now); +  day = g_date_time_get_day_of_month (now); +  hour = g_date_time_get_hour (now); +  minute = g_date_time_get_minute (now); +  second = g_date_time_get_second (now); +  g_date_time_unref (now); + +  /* Parse this string as if it were in the output format */ +  gint scanned = 0; +  gboolean passed = TRUE, skip = FALSE; +  if (is_time) { +    gint hour_in, minute_in, second_in; + +    if (is_locale_12h ()) { // TODO: make this look-at/watch gsettings? +      char ampm[51]; + +      scanned = sscanf (text, "%u:%u:%u %50s", &hour_in, &minute_in, &second_in, ampm); +      passed = (scanned == 4); + +      if (passed) { +        const char *pm_str = nl_langinfo (PM_STR); +        if (g_ascii_strcasecmp (pm_str, ampm) == 0) { +          hour_in += 12; +        } +      } +    } else { +      scanned = sscanf (text, "%u:%u:%u", &hour_in, &minute_in, &second_in); +      passed = (scanned == 3); +    } + +    if (passed && (hour_in > 23 || minute_in > 59 || second_in > 59)) { +      passed = FALSE; +    } +    if (passed && hour == hour_in && minute == minute_in && second == second_in) { +      skip = TRUE; // no change +    } else { +      hour = hour_in; +      minute = minute_in; +      second = second_in; +    } +  } +  else { +    gint year_in, month_in, day_in; + +    scanned = sscanf (text, "%u-%u-%u", &year_in, &month_in, &day_in); + +    if (scanned != 3 || year_in < 1 || year_in > 9999 || +        month_in < 1 || month_in > 12 || day_in < 1 || day_in > 31) { +      passed = FALSE; +    } +    if (passed && year == year_in && month == month_in && day == day_in) { +      skip = TRUE; // no change +    } else { +      year = year_in; +      month = month_in; +      day = day_in; +    } +  } + +  if (!passed) { +    g_warning ("Could not understand %s", text); +    return TRUE; +  } + +  if (skip) { +    return TRUE; +  } + +  GDateTime * datetime = g_date_time_new_local (year, month, day, hour, minute, second); + +  g_dbus_proxy_call (proxy, "SetTime", g_variant_new ("(x)", g_date_time_to_unix (datetime)), +                     G_DBUS_CALL_FLAGS_NONE, -1, NULL, dbus_set_answered, "time"); + +  return TRUE; +} + +static gboolean +format_time_text (GtkWidget * spinner, gpointer user_data) +{ +  if (gtk_widget_has_focus (spinner)) { +    /* Don't do anything if we have focus, user is likely editing us */ +    return TRUE; +  } + +  GDateTime * datetime = (GDateTime *)g_object_get_data (G_OBJECT (spinner), "datetime"); +  gboolean is_time = (gboolean)GPOINTER_TO_INT (g_object_get_data (G_OBJECT (spinner), "is-time")); + +  const gchar * format; +  if (is_time) { +    if (is_locale_12h ()) { // TODO: make this look-at/watch gsettings? +      format = "%I:%M:%S %p"; +    } else { +      format = "%H:%M:%S"; +    } +  } +  else { +    format = "%Y-%m-%d"; +  } + +  gchar * formatted = g_date_time_format (datetime, format); +  gtk_entry_set_text (GTK_ENTRY (spinner), formatted); + +  return TRUE; +} + +static gboolean +update_spinner (GtkWidget * spinner) +{ +  /* Add datetime object to spinner, which will hold the real time value, rather +     then using the value of the spinner itself. */ +  GDateTime * datetime = g_date_time_new_now_local (); +  g_object_set_data_full (G_OBJECT (spinner), "datetime", datetime, (GDestroyNotify)g_date_time_unref); + +  format_time_text (spinner, NULL); + +  return TRUE; +} + +static void +setup_time_spinner (GtkWidget * spinner, GtkWidget * other, gboolean is_time) +{ +  /* Set up spinner to have reasonable behavior */ +  gtk_spin_button_set_numeric (GTK_SPIN_BUTTON (spinner), FALSE); +  g_signal_connect (spinner, "input", G_CALLBACK (input_time_text), other); +  g_signal_connect (spinner, "output", G_CALLBACK (format_time_text), other); +  g_object_set_data (G_OBJECT (spinner), "is-time", GINT_TO_POINTER (is_time)); + +  /* 2 seconds is what the indicator itself uses */ +  guint time_id = g_timeout_add_seconds (2, (GSourceFunc)update_spinner, spinner); +  g_signal_connect_swapped (spinner, "destroy", G_CALLBACK (g_source_remove), GINT_TO_POINTER (time_id)); + +  update_spinner (spinner); +} + +static void +show_locations (GtkWidget * button, GtkWidget * dlg) +{ +  GtkWidget * locationsDlg = datetime_setup_locations_dialog (GTK_WINDOW (dlg)); +  gtk_widget_show_all (locationsDlg); +} + +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)) + +  /* Add policykit button */ +  GtkWidget * polkit_button = polkit_lock_button_new ("org.gnome.settingsdaemon.datetimemechanism.configure"); +  polkit_lock_button_set_unlock_text (POLKIT_LOCK_BUTTON (polkit_button), _("Unlock to change these settings")); +  polkit_lock_button_set_lock_text (POLKIT_LOCK_BUTTON (polkit_button), _("Lock to prevent further changes")); +  gtk_box_pack_start (GTK_BOX (WIG ("timeDateBox")), polkit_button, FALSE, TRUE, 0); + +  /* 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")); +  add_polkit_dependency (polkit_button, WIG ("timeDateOptions")); + +  /* 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); + +  setup_time_spinner (WIG ("timeSpinner"), WIG ("dateSpinner"), TRUE); +  setup_time_spinner (WIG ("dateSpinner"), WIG ("timeSpinner"), FALSE); + +  GtkWidget * dlg = WIG ("timeDateDialog"); + +  g_signal_connect (WIG ("locationsButton"), "clicked", G_CALLBACK (show_locations), dlg); + +  /* Grab proxy for settings daemon */ +  g_dbus_proxy_new_for_bus (G_BUS_TYPE_SYSTEM, G_DBUS_PROXY_FLAGS_NONE, NULL, +                            "org.gnome.SettingsDaemon.DateTimeMechanism", +                            "/",                             +                            "org.gnome.SettingsDaemon.DateTimeMechanism", +                            NULL, proxy_ready, WIG ("automaticTimeRadio")); + +#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 d16837c..1f3eac6 100644 --- a/src/datetime-service.c +++ b/src/datetime-service.c @@ -52,11 +52,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); @@ -359,7 +357,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; @@ -716,13 +714,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);  	} @@ -788,7 +786,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 045ab78..5e73612 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 ()) @@ -121,13 +119,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, @@ -1031,24 +1022,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 | 
