user: Move the language chooser to common
It will soon be used in the region panel as well.
This commit is contained in:
parent
daf2dae1ff
commit
60c8f11a12
7 changed files with 108 additions and 58 deletions
|
@ -8,7 +8,7 @@ AM_CPPFLAGS = \
|
||||||
$(PANEL_CFLAGS) \
|
$(PANEL_CFLAGS) \
|
||||||
$(LIBLANGUAGE_CFLAGS) \
|
$(LIBLANGUAGE_CFLAGS) \
|
||||||
-DDATADIR=\""$(datadir)"\" \
|
-DDATADIR=\""$(datadir)"\" \
|
||||||
-DUIDIR=\""$(pkgdatadir)/ui/user-accounts"\" \
|
-DUIDIR=\""$(pkgdatadir)/ui"\" \
|
||||||
-DLIBLOCALEDIR=\""$(prefix)/lib/locale"\" \
|
-DLIBLOCALEDIR=\""$(prefix)/lib/locale"\" \
|
||||||
-DGNOMELOCALEDIR=\""$(datadir)/locale"\" \
|
-DGNOMELOCALEDIR=\""$(datadir)/locale"\" \
|
||||||
-DUM_PIXMAP_DIR=\""$(pkgdatadir)/pixmaps"\"
|
-DUM_PIXMAP_DIR=\""$(pkgdatadir)/pixmaps"\"
|
||||||
|
@ -18,7 +18,9 @@ liblanguage_la_SOURCES = \
|
||||||
gdm-languages.c \
|
gdm-languages.c \
|
||||||
locarchive.h \
|
locarchive.h \
|
||||||
cc-common-language.c \
|
cc-common-language.c \
|
||||||
cc-common-language.h
|
cc-common-language.h \
|
||||||
|
cc-language-chooser.c \
|
||||||
|
cc-language-chooser.h
|
||||||
|
|
||||||
liblanguage_la_LIBADD = \
|
liblanguage_la_LIBADD = \
|
||||||
$(PANEL_LIBS) \
|
$(PANEL_LIBS) \
|
||||||
|
@ -40,4 +42,9 @@ list_languages_SOURCES = list-languages.c
|
||||||
list_languages_LDADD = liblanguage.la
|
list_languages_LDADD = liblanguage.la
|
||||||
list_languages_CFLAGS = $(LIBLANGUAGE_CFLAGS)
|
list_languages_CFLAGS = $(LIBLANGUAGE_CFLAGS)
|
||||||
|
|
||||||
|
uidir = $(pkgdatadir)/ui
|
||||||
|
|
||||||
|
ui_DATA = \
|
||||||
|
language-chooser.ui
|
||||||
|
|
||||||
-include $(top_srcdir)/git.mk
|
-include $(top_srcdir)/git.mk
|
||||||
|
|
|
@ -26,18 +26,17 @@
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
#include <glib/gi18n.h>
|
#include <glib/gi18n.h>
|
||||||
|
#include <gio/gio.h>
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
|
||||||
#include <fontconfig/fontconfig.h>
|
#include <fontconfig/fontconfig.h>
|
||||||
|
|
||||||
#include "um-language-dialog.h"
|
#include "cc-language-chooser.h"
|
||||||
#include "um-user-manager.h"
|
|
||||||
#include "cc-common-language.h"
|
#include "cc-common-language.h"
|
||||||
|
|
||||||
#include "gdm-languages.h"
|
#include "gdm-languages.h"
|
||||||
|
|
||||||
gchar *
|
gchar *
|
||||||
um_language_chooser_get_language (GtkWidget *chooser)
|
cc_language_chooser_get_language (GtkWidget *chooser)
|
||||||
{
|
{
|
||||||
GtkTreeView *tv;
|
GtkTreeView *tv;
|
||||||
GtkTreeSelection *selection;
|
GtkTreeSelection *selection;
|
||||||
|
@ -56,7 +55,7 @@ um_language_chooser_get_language (GtkWidget *chooser)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
um_language_chooser_clear_filter (GtkWidget *chooser)
|
cc_language_chooser_clear_filter (GtkWidget *chooser)
|
||||||
{
|
{
|
||||||
GtkEntry *entry;
|
GtkEntry *entry;
|
||||||
|
|
||||||
|
@ -73,50 +72,97 @@ row_activated (GtkTreeView *tree_view,
|
||||||
gtk_dialog_response (GTK_DIALOG (chooser), GTK_RESPONSE_OK);
|
gtk_dialog_response (GTK_DIALOG (chooser), GTK_RESPONSE_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
add_other_users_language (GHashTable *ht)
|
||||||
|
{
|
||||||
|
GVariant *variant;
|
||||||
|
GVariantIter *vi;
|
||||||
|
GError *error = NULL;
|
||||||
|
const char *str;
|
||||||
|
GDBusProxy *proxy;
|
||||||
|
|
||||||
|
proxy = g_dbus_proxy_new_for_bus_sync (G_BUS_TYPE_SYSTEM,
|
||||||
|
G_DBUS_PROXY_FLAGS_NONE,
|
||||||
|
NULL,
|
||||||
|
"org.freedesktop.Accounts",
|
||||||
|
"/org/freedesktop/Accounts",
|
||||||
|
"org.freedesktop.Accounts",
|
||||||
|
NULL,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
if (proxy == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
variant = g_dbus_proxy_call_sync (proxy,
|
||||||
|
"ListCachedUsers",
|
||||||
|
NULL,
|
||||||
|
G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
-1,
|
||||||
|
NULL,
|
||||||
|
&error);
|
||||||
|
if (variant == NULL) {
|
||||||
|
g_warning ("Failed to list existing users: %s", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
g_object_unref (proxy);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
g_variant_get (variant, "(ao)", &vi);
|
||||||
|
while (g_variant_iter_loop (vi, "o", &str)) {
|
||||||
|
GDBusProxy *user;
|
||||||
|
GVariant *props;
|
||||||
|
const char *lang;
|
||||||
|
char *name;
|
||||||
|
char *language;
|
||||||
|
|
||||||
|
user = g_dbus_proxy_new_for_bus_sync (G_BUS_TYPE_SYSTEM,
|
||||||
|
G_DBUS_PROXY_FLAGS_NONE,
|
||||||
|
NULL,
|
||||||
|
"org.freedesktop.Accounts",
|
||||||
|
str,
|
||||||
|
"org.freedesktop.Accounts.User",
|
||||||
|
NULL,
|
||||||
|
&error);
|
||||||
|
if (user == NULL) {
|
||||||
|
g_warning ("Failed to get proxy for user '%s': %s",
|
||||||
|
str, error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
error = NULL;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
props = g_dbus_proxy_get_cached_property (user, "Language");
|
||||||
|
lang = g_variant_get_string (props, NULL);
|
||||||
|
if (lang != NULL && *lang != '\0' &&
|
||||||
|
cc_common_language_has_font (lang)) {
|
||||||
|
name = gdm_normalize_language_name (lang);
|
||||||
|
language = gdm_get_language_from_name (name, NULL);
|
||||||
|
g_hash_table_insert (ht, name, language);
|
||||||
|
}
|
||||||
|
g_variant_unref (props);
|
||||||
|
g_object_unref (user);
|
||||||
|
}
|
||||||
|
g_variant_iter_free (vi);
|
||||||
|
g_variant_unref (variant);
|
||||||
|
|
||||||
|
g_object_unref (proxy);
|
||||||
|
}
|
||||||
|
|
||||||
static GHashTable *
|
static GHashTable *
|
||||||
new_ht_for_user_languages (void)
|
new_ht_for_user_languages (void)
|
||||||
{
|
{
|
||||||
GHashTable *ht;
|
GHashTable *ht;
|
||||||
UmUserManager *manager;
|
|
||||||
GSList *users, *l;
|
|
||||||
UmUser *user;
|
|
||||||
char *name;
|
char *name;
|
||||||
|
|
||||||
ht = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_free);
|
ht = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_free);
|
||||||
|
|
||||||
/* Add some common languages here */
|
/* Add some common languages first */
|
||||||
g_hash_table_insert (ht, g_strdup ("en_US.utf8"), g_strdup (_("English")));
|
g_hash_table_insert (ht, g_strdup ("en_US.utf8"), g_strdup (_("English")));
|
||||||
g_hash_table_insert (ht, g_strdup ("de_DE.utf8"), g_strdup (_("German")));
|
g_hash_table_insert (ht, g_strdup ("de_DE.utf8"), g_strdup (_("German")));
|
||||||
g_hash_table_insert (ht, g_strdup ("fr_FR.utf8"), g_strdup (_("French")));
|
g_hash_table_insert (ht, g_strdup ("fr_FR.utf8"), g_strdup (_("French")));
|
||||||
g_hash_table_insert (ht, g_strdup ("es_ES.utf8"), g_strdup (_("Spanish")));
|
g_hash_table_insert (ht, g_strdup ("es_ES.utf8"), g_strdup (_("Spanish")));
|
||||||
g_hash_table_insert (ht, g_strdup ("zh_CN.utf8"), g_strdup (_("Chinese")));
|
g_hash_table_insert (ht, g_strdup ("zh_CN.utf8"), g_strdup (_("Chinese")));
|
||||||
|
|
||||||
manager = um_user_manager_ref_default ();
|
/* Add the languages used by other users on the system */
|
||||||
users = um_user_manager_list_users (manager);
|
add_other_users_language (ht);
|
||||||
g_object_unref (manager);
|
|
||||||
|
|
||||||
for (l = users; l; l = l->next) {
|
|
||||||
const char *lang;
|
|
||||||
char *language;
|
|
||||||
|
|
||||||
user = l->data;
|
|
||||||
lang = um_user_get_language (user);
|
|
||||||
if (!lang || !cc_common_language_has_font (lang)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
name = gdm_normalize_language_name (lang);
|
|
||||||
if (g_hash_table_lookup (ht, name) != NULL) {
|
|
||||||
g_free (name);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
language = gdm_get_language_from_name (name, NULL);
|
|
||||||
|
|
||||||
g_hash_table_insert (ht, name, language);
|
|
||||||
}
|
|
||||||
|
|
||||||
g_slist_free (users);
|
|
||||||
|
|
||||||
/* Make sure the current locale is present */
|
/* Make sure the current locale is present */
|
||||||
name = cc_common_language_get_current_language ();
|
name = cc_common_language_get_current_language ();
|
||||||
|
@ -149,7 +195,7 @@ languages_foreach_cb (gpointer key,
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
um_add_user_languages (GtkTreeModel *model)
|
cc_add_user_languages (GtkTreeModel *model)
|
||||||
{
|
{
|
||||||
char *name;
|
char *name;
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
|
@ -197,7 +243,7 @@ remove_async (gpointer data)
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
finish_um_language_chooser (gpointer user_data)
|
finish_language_chooser (gpointer user_data)
|
||||||
{
|
{
|
||||||
GtkWidget *chooser = (GtkWidget *) user_data;
|
GtkWidget *chooser = (GtkWidget *) user_data;
|
||||||
GtkWidget *list;
|
GtkWidget *list;
|
||||||
|
@ -301,7 +347,7 @@ filter_languages (GtkTreeModel *model,
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget *
|
GtkWidget *
|
||||||
um_language_chooser_new (GtkWidget *parent)
|
cc_language_chooser_new (GtkWidget *parent)
|
||||||
{
|
{
|
||||||
GtkBuilder *builder;
|
GtkBuilder *builder;
|
||||||
const char *filename;
|
const char *filename;
|
||||||
|
@ -358,9 +404,11 @@ um_language_chooser_new (GtkWidget *parent)
|
||||||
gdk_window_set_cursor (gtk_widget_get_window (parent), cursor);
|
gdk_window_set_cursor (gtk_widget_get_window (parent), cursor);
|
||||||
g_object_unref (cursor);
|
g_object_unref (cursor);
|
||||||
|
|
||||||
|
gtk_window_set_transient_for (GTK_WINDOW (chooser), GTK_WINDOW (parent));
|
||||||
|
|
||||||
g_object_set_data_full (G_OBJECT (chooser), "user-langs",
|
g_object_set_data_full (G_OBJECT (chooser), "user-langs",
|
||||||
user_langs, (GDestroyNotify) g_hash_table_destroy);
|
user_langs, (GDestroyNotify) g_hash_table_destroy);
|
||||||
timeout = g_idle_add ((GSourceFunc) finish_um_language_chooser, chooser);
|
timeout = g_idle_add ((GSourceFunc) finish_language_chooser, chooser);
|
||||||
g_object_set_data (G_OBJECT (chooser), "timeout", GUINT_TO_POINTER (timeout));
|
g_object_set_data (G_OBJECT (chooser), "timeout", GUINT_TO_POINTER (timeout));
|
||||||
g_object_weak_ref (G_OBJECT (chooser), (GWeakNotify) remove_timeout, GUINT_TO_POINTER (timeout));
|
g_object_weak_ref (G_OBJECT (chooser), (GWeakNotify) remove_timeout, GUINT_TO_POINTER (timeout));
|
||||||
|
|
|
@ -19,19 +19,18 @@
|
||||||
* Written by: Matthias Clasen <mclasen@redhat.com>
|
* Written by: Matthias Clasen <mclasen@redhat.com>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __UM_LANGUAGE_DIALOG_H__
|
#ifndef __CC_LANGUAGE_CHOOSER_H__
|
||||||
#define __UM_LANGUAGE_DIALOG_H__
|
#define __CC_LANGUAGE_CHOOSER_H__
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
#include "um-user.h"
|
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
void um_add_user_languages (GtkTreeModel *model);
|
void cc_add_user_languages (GtkTreeModel *model);
|
||||||
|
|
||||||
GtkWidget *um_language_chooser_new (GtkWidget *parent);
|
GtkWidget *cc_language_chooser_new (GtkWidget *parent);
|
||||||
void um_language_chooser_clear_filter (GtkWidget *chooser);
|
void cc_language_chooser_clear_filter (GtkWidget *chooser);
|
||||||
gchar *um_language_chooser_get_language (GtkWidget *chooser);
|
gchar *cc_language_chooser_get_language (GtkWidget *chooser);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
|
@ -40,8 +40,6 @@ libuser_accounts_la_SOURCES = \
|
||||||
um-user-manager.c \
|
um-user-manager.c \
|
||||||
um-account-dialog.h \
|
um-account-dialog.h \
|
||||||
um-account-dialog.c \
|
um-account-dialog.c \
|
||||||
um-language-dialog.h \
|
|
||||||
um-language-dialog.c \
|
|
||||||
um-password-dialog.h \
|
um-password-dialog.h \
|
||||||
um-password-dialog.c \
|
um-password-dialog.c \
|
||||||
um-photo-dialog.h \
|
um-photo-dialog.h \
|
||||||
|
|
|
@ -3,7 +3,6 @@ SUBDIRS = faces icons
|
||||||
uidir = $(pkgdatadir)/ui/user-accounts
|
uidir = $(pkgdatadir)/ui/user-accounts
|
||||||
ui_DATA = \
|
ui_DATA = \
|
||||||
account-dialog.ui \
|
account-dialog.ui \
|
||||||
language-chooser.ui \
|
|
||||||
password-dialog.ui \
|
password-dialog.ui \
|
||||||
photo-dialog.ui \
|
photo-dialog.ui \
|
||||||
user-accounts-dialog.ui \
|
user-accounts-dialog.ui \
|
||||||
|
|
|
@ -49,7 +49,7 @@
|
||||||
#include "um-editable-combo.h"
|
#include "um-editable-combo.h"
|
||||||
|
|
||||||
#include "um-account-dialog.h"
|
#include "um-account-dialog.h"
|
||||||
#include "um-language-dialog.h"
|
#include "cc-language-chooser.h"
|
||||||
#include "um-password-dialog.h"
|
#include "um-password-dialog.h"
|
||||||
#include "um-photo-dialog.h"
|
#include "um-photo-dialog.h"
|
||||||
#include "um-fingerprint-dialog.h"
|
#include "um-fingerprint-dialog.h"
|
||||||
|
@ -582,7 +582,7 @@ show_user (UmUser *user, UmUserPanelPrivate *d)
|
||||||
|
|
||||||
widget = get_widget (d, "account-language-combo");
|
widget = get_widget (d, "account-language-combo");
|
||||||
model = um_editable_combo_get_model (UM_EDITABLE_COMBO (widget));
|
model = um_editable_combo_get_model (UM_EDITABLE_COMBO (widget));
|
||||||
um_add_user_languages (model);
|
cc_add_user_languages (model);
|
||||||
|
|
||||||
lang = g_strdup (um_user_get_language (user));
|
lang = g_strdup (um_user_get_language (user));
|
||||||
if (!lang)
|
if (!lang)
|
||||||
|
@ -673,7 +673,7 @@ language_response (GtkDialog *dialog,
|
||||||
model = um_editable_combo_get_model (UM_EDITABLE_COMBO (combo));
|
model = um_editable_combo_get_model (UM_EDITABLE_COMBO (combo));
|
||||||
|
|
||||||
if (response_id == GTK_RESPONSE_OK) {
|
if (response_id == GTK_RESPONSE_OK) {
|
||||||
lang = um_language_chooser_get_language (GTK_WIDGET (dialog));
|
lang = cc_language_chooser_get_language (GTK_WIDGET (dialog));
|
||||||
um_user_set_language (user, lang);
|
um_user_set_language (user, lang);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -714,15 +714,14 @@ language_changed (UmEditableCombo *combo,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (d->language_chooser) {
|
if (d->language_chooser) {
|
||||||
um_language_chooser_clear_filter (d->language_chooser);
|
cc_language_chooser_clear_filter (d->language_chooser);
|
||||||
gtk_window_present (GTK_WINDOW (d->language_chooser));
|
gtk_window_present (GTK_WINDOW (d->language_chooser));
|
||||||
gtk_widget_set_sensitive (GTK_WIDGET (combo), FALSE);
|
gtk_widget_set_sensitive (GTK_WIDGET (combo), FALSE);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
d->language_chooser = um_language_chooser_new (gtk_widget_get_toplevel (d->main_box));
|
d->language_chooser = cc_language_chooser_new (gtk_widget_get_toplevel (d->main_box));
|
||||||
gtk_window_set_transient_for (GTK_WINDOW (d->language_chooser),
|
|
||||||
GTK_WINDOW (gtk_widget_get_toplevel (d->main_box)));
|
|
||||||
g_signal_connect (d->language_chooser, "response",
|
g_signal_connect (d->language_chooser, "response",
|
||||||
G_CALLBACK (language_response), d);
|
G_CALLBACK (language_response), d);
|
||||||
g_signal_connect (d->language_chooser, "delete-event",
|
g_signal_connect (d->language_chooser, "delete-event",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue