improving layout, b.g.o#455353

svn path=/trunk/; revision=7845
This commit is contained in:
Sergey V. Udaltsov 2007-07-11 10:40:54 +00:00
parent f221453b2e
commit beafb880cb
5 changed files with 305 additions and 319 deletions

View file

@ -1,3 +1,10 @@
2007-07-11 Sergey Udaltsov <svu@gnome.org>
* gnome-keyboard-properties-xkb.h, gnome-keyboard-properties-xkbpv.c,
gnome-keyboard-properties.glade, gnome-keyboard-properties-xkbltadd.c:
improving the layout and sorting, thanks to Christian,
http://bugzilla.gnome.org/show_bug.cgi?id=455353
2007-05-19 Sergey Udaltsov <svu@gnome.org> 2007-05-19 Sergey Udaltsov <svu@gnome.org>
* gnome-keyboard-properties-xkbmc.c: make things buildable with * gnome-keyboard-properties-xkbmc.c: make things buildable with

View file

@ -84,7 +84,7 @@ extern GtkWidget *xkb_layout_preview_create_widget (GladeXML *
extern void xkb_layout_preview_update (GladeXML * chooser_dialog); extern void xkb_layout_preview_update (GladeXML * chooser_dialog);
extern const gchar *xkb_layout_chooser_get_selected_id (GladeXML * extern gchar *xkb_layout_chooser_get_selected_id (GladeXML *
chooser_dialog); chooser_dialog);
G_END_DECLS G_END_DECLS

View file

@ -40,9 +40,16 @@
#define DEFAULT_GROUP_SWITCH "grp:alts_toggle" #define DEFAULT_GROUP_SWITCH "grp:alts_toggle"
#define DEFAULT_VARIANT_ID "__default__" #define DEFAULT_VARIANT_ID "__default__"
#define COMBO_BOX_MODEL_COL_DESCRIPTION 0 enum {
#define COMBO_BOX_MODEL_COL_ID 1 COMBO_BOX_MODEL_COL_DESCRIPTION,
#define COMBO_BOX_MODEL_COL_SORTING 2 COMBO_BOX_MODEL_COL_ID,
COMBO_BOX_MODEL_COL_IS_DEFAULT
};
typedef struct {
GtkListStore *list_store;
guint n_items;
} AddVariantData;
static void static void
xkb_layout_chooser_available_layouts_fill (GladeXML * chooser_dialog); xkb_layout_chooser_available_layouts_fill (GladeXML * chooser_dialog);
@ -55,42 +62,23 @@ xkb_layout_chooser_add_variant_to_available_variants (XklConfigRegistry *
config_registry, config_registry,
XklConfigItem * XklConfigItem *
config_item, config_item,
GladeXML * AddVariantData *
chooser_dialog) data)
{ {
GtkWidget *cbe = CWID ("xkb_variants_available");
GtkTreeIter iter;
GtkTreeModel *model =
gtk_combo_box_get_model (GTK_COMBO_BOX (cbe));
GtkTreeStore *tree_store =
GTK_TREE_STORE (gtk_tree_model_sort_get_model
(GTK_TREE_MODEL_SORT (model)));
gtk_tree_store_append (tree_store, &iter, NULL);
if (config_item != NULL) {
char *utf_variant_name = xci_desc_to_utf8 (config_item); char *utf_variant_name = xci_desc_to_utf8 (config_item);
GtkTreeIter iter;
gtk_tree_store_set (tree_store, &iter, gtk_list_store_insert_with_values (data->list_store, &iter, -1,
COMBO_BOX_MODEL_COL_DESCRIPTION, COMBO_BOX_MODEL_COL_DESCRIPTION,
utf_variant_name, utf_variant_name,
COMBO_BOX_MODEL_COL_ID, COMBO_BOX_MODEL_COL_ID,
config_item->name, config_item->name,
COMBO_BOX_MODEL_COL_SORTING, COMBO_BOX_MODEL_COL_IS_DEFAULT,
utf_variant_name, -1); FALSE,
-1);
g_free (utf_variant_name); g_free (utf_variant_name);
} else {
gtk_tree_store_set (tree_store, &iter, data->n_items++;
COMBO_BOX_MODEL_COL_DESCRIPTION,
_("Default"), COMBO_BOX_MODEL_COL_ID,
DEFAULT_VARIANT_ID,
COMBO_BOX_MODEL_COL_SORTING, "_", -1);
gtk_tree_store_append (tree_store, &iter, NULL);
gtk_tree_store_set (tree_store, &iter,
COMBO_BOX_MODEL_COL_DESCRIPTION,
"***", COMBO_BOX_MODEL_COL_ID,
DEFAULT_VARIANT_ID,
COMBO_BOX_MODEL_COL_SORTING, "__", -1);
}
} }
static void static void
@ -98,21 +86,15 @@ xkb_layout_chooser_add_layout_to_available_layouts (XklConfigRegistry *
config_registry, config_registry,
XklConfigItem * XklConfigItem *
config_item, config_item,
GladeXML * GtkListStore *list_store)
chooser_dialog)
{ {
GtkWidget *cbe = CWID ("xkb_layouts_available");
GtkTreeStore *tree_store =
GTK_TREE_STORE (gtk_combo_box_get_model (GTK_COMBO_BOX (cbe)));
char *utf_layout_name = xci_desc_to_utf8 (config_item); char *utf_layout_name = xci_desc_to_utf8 (config_item);
GtkTreeIter iter; GtkTreeIter iter;
gtk_tree_store_append (tree_store, &iter, NULL); gtk_list_store_insert_with_values (list_store, &iter, -1,
gtk_tree_store_set (tree_store, &iter, COMBO_BOX_MODEL_COL_DESCRIPTION, utf_layout_name,
COMBO_BOX_MODEL_COL_DESCRIPTION, COMBO_BOX_MODEL_COL_ID, config_item->name,
utf_layout_name, COMBO_BOX_MODEL_COL_ID, -1);
config_item->name, -1);
g_free (utf_layout_name); g_free (utf_layout_name);
} }
@ -121,9 +103,10 @@ xkb_layout_chooser_enable_disable_buttons (GladeXML * chooser_dialog)
{ {
GtkWidget *cbel = CWID ("xkb_layouts_available"); GtkWidget *cbel = CWID ("xkb_layouts_available");
GtkWidget *cbev = CWID ("xkb_variants_available"); GtkWidget *cbev = CWID ("xkb_variants_available");
GtkTreeIter liter, viter;
gboolean enable_ok = gboolean enable_ok =
(gtk_combo_box_get_active (GTK_COMBO_BOX (cbel)) != -1) gtk_combo_box_get_active_iter (GTK_COMBO_BOX (cbel), &liter)
&& (gtk_combo_box_get_active (GTK_COMBO_BOX (cbev)) != -1); && gtk_combo_box_get_active_iter (GTK_COMBO_BOX (cbev), &viter);
gtk_dialog_set_response_sensitive (GTK_DIALOG gtk_dialog_set_response_sensitive (GTK_DIALOG
(CWID ("xkb_layout_chooser")), (CWID ("xkb_layout_chooser")),
@ -144,19 +127,42 @@ xkb_layout_chooser_available_layout_changed (GladeXML * chooser_dialog)
xkb_layout_chooser_available_variant_changed (chooser_dialog); xkb_layout_chooser_available_variant_changed (chooser_dialog);
} }
static void static gint
xkb_layout_chooser_sort_combo_box (GtkWidget * combo_box, int sort_column) xkb_layout_chooser_variant_compare_func (GtkTreeModel *model,
GtkTreeIter *a,
GtkTreeIter *b,
gpointer user_data)
{ {
GtkTreeModel *model = gchar *desc_a = NULL, *desc_b = NULL;
gtk_combo_box_get_model (GTK_COMBO_BOX (combo_box)); gboolean a_is_default, b_is_default;
/* replace the store with the sorted version */ gint retval;
GtkTreeModel *sorted_model =
gtk_tree_model_sort_new_with_model (model); gtk_tree_model_get (model, a,
gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE COMBO_BOX_MODEL_COL_DESCRIPTION, &desc_a,
(sorted_model), COMBO_BOX_MODEL_COL_IS_DEFAULT, &a_is_default,
sort_column, -1);
GTK_SORT_ASCENDING); gtk_tree_model_get (model, b,
gtk_combo_box_set_model (GTK_COMBO_BOX (combo_box), sorted_model); COMBO_BOX_MODEL_COL_DESCRIPTION, &desc_b,
COMBO_BOX_MODEL_COL_IS_DEFAULT, &b_is_default,
-1);
if (a_is_default || b_is_default)
retval = b_is_default - a_is_default;
else if (desc_a != NULL && desc_b != NULL)
retval = g_utf8_collate (desc_a, desc_b);
else if (desc_a != NULL)
/* desc_b == NULL hence b is the separator, and a is not the default => b < a */
retval = 1;
else if (desc_b != NULL)
/* desc_a == NULL hence a is the separator, and b is not the default => a < b */
retval = -1;
else
retval = 0;
g_free (desc_a);
g_free (desc_b);
return retval;
} }
static gboolean static gboolean
@ -164,11 +170,13 @@ xkl_layout_chooser_separate_default_variant (GtkTreeModel * model,
GtkTreeIter * iter, GtkTreeIter * iter,
GladeXML * chooser_dialog) GladeXML * chooser_dialog)
{ {
GtkTreePath *path = gtk_tree_model_get_path (model, iter); gchar *id;
gint *idxs = gtk_tree_path_get_indices (path);
gint idx = idxs[0]; /* Rows with COMBO_BOX_MODEL_COL_DESCRIPTION value NULL are separators */
gtk_tree_path_free (path); gtk_tree_model_get (model, iter, COMBO_BOX_MODEL_COL_DESCRIPTION, &id, -1);
return idx == 1; g_free (id);
return id == NULL;
} }
static void static void
@ -178,23 +186,110 @@ xkb_layout_chooser_available_variants_fill (GladeXML * chooser_dialog)
GtkWidget *cbev = CWID ("xkb_variants_available"); GtkWidget *cbev = CWID ("xkb_variants_available");
GtkTreeModel *model = GtkTreeModel *model =
gtk_combo_box_get_model (GTK_COMBO_BOX (cbev)); gtk_combo_box_get_model (GTK_COMBO_BOX (cbev));
gint selected_layout_idx; GtkTreeIter liter, vdefault_iter;
gboolean set_default = FALSE;
if (model == NULL) { model = GTK_TREE_MODEL (gtk_list_store_new
model =
GTK_TREE_MODEL (gtk_tree_store_new
(3, G_TYPE_STRING, G_TYPE_STRING, (3, G_TYPE_STRING, G_TYPE_STRING,
G_TYPE_STRING)); G_TYPE_BOOLEAN));
gtk_combo_box_set_model (GTK_COMBO_BOX (cbev), if (gtk_combo_box_get_active_iter (GTK_COMBO_BOX (cbel), &liter)) {
GTK_TREE_MODEL (model)); GtkTreeModel *lm =
gtk_combo_box_get_model (GTK_COMBO_BOX (cbel));
GtkTreeIter viter;
gchar *value;
AddVariantData data = { GTK_LIST_STORE (model), 0 };
gtk_combo_box_entry_set_text_column (GTK_COMBO_BOX_ENTRY /* The 'Default' row */
(cbev), gtk_list_store_insert_with_values (GTK_LIST_STORE (model), &vdefault_iter, -1,
COMBO_BOX_MODEL_COL_DESCRIPTION); COMBO_BOX_MODEL_COL_DESCRIPTION,
_("Default"),
COMBO_BOX_MODEL_COL_ID,
DEFAULT_VARIANT_ID,
COMBO_BOX_MODEL_COL_IS_DEFAULT, TRUE,
-1);
set_default = TRUE;
xkb_layout_chooser_sort_combo_box (cbev, /* Now the variants of the selected lang */
COMBO_BOX_MODEL_COL_SORTING); gtk_tree_model_get (lm, &liter,
COMBO_BOX_MODEL_COL_ID, &value,
-1);
g_assert (value != NULL);
xkl_config_registry_foreach_layout_variant
(config_registry, value,
(ConfigItemProcessFunc)
xkb_layout_chooser_add_variant_to_available_variants,
&data);
g_free (value);
/* Add a separator row, but only if we have any non-default items */
if (data.n_items > 0)
gtk_list_store_insert_with_values (GTK_LIST_STORE (model), &viter, -1,
COMBO_BOX_MODEL_COL_DESCRIPTION,
NULL,
COMBO_BOX_MODEL_COL_ID,
NULL,
COMBO_BOX_MODEL_COL_IS_DEFAULT, FALSE,
-1);
}
/* Turn on sorting after filling the store, since that's faster */
gtk_tree_sortable_set_sort_func (GTK_TREE_SORTABLE (model),
COMBO_BOX_MODEL_COL_DESCRIPTION,
(GtkTreeIterCompareFunc)
xkb_layout_chooser_variant_compare_func,
NULL, NULL);
gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE (model),
COMBO_BOX_MODEL_COL_DESCRIPTION,
GTK_SORT_ASCENDING);
gtk_combo_box_set_model (GTK_COMBO_BOX (cbev), model);
/* Select the default variant */
if (set_default) {
gtk_combo_box_set_active_iter (GTK_COMBO_BOX (cbev), &vdefault_iter);
}
}
static void
xkb_layout_chooser_available_layouts_fill (GladeXML * chooser_dialog)
{
GtkWidget *cbe = CWID ("xkb_layouts_available");
GtkWidget *cbev = CWID ("xkb_variants_available");
GtkCellRenderer *renderer;
GtkTreeModel *model =
GTK_TREE_MODEL (gtk_list_store_new (2, G_TYPE_STRING, G_TYPE_STRING));
gtk_combo_box_set_model (GTK_COMBO_BOX (cbe), model);
renderer = gtk_cell_renderer_text_new ();
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (cbe), renderer, TRUE);
gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (cbe), renderer,
"text", COMBO_BOX_MODEL_COL_DESCRIPTION,
NULL);
xkl_config_registry_foreach_layout (config_registry,
(ConfigItemProcessFunc)
xkb_layout_chooser_add_layout_to_available_layouts,
model);
/* Turn on sorting after filling the model since that's faster */
gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE (model),
COMBO_BOX_MODEL_COL_DESCRIPTION,
GTK_SORT_ASCENDING);
g_signal_connect_swapped (G_OBJECT (cbe), "changed",
G_CALLBACK
(xkb_layout_chooser_available_layout_changed),
chooser_dialog);
/* Setup the variants combo */
renderer = gtk_cell_renderer_text_new ();
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (cbev), renderer, TRUE);
gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (cbev), renderer,
"text", COMBO_BOX_MODEL_COL_DESCRIPTION,
NULL);
g_signal_connect_swapped (G_OBJECT (cbev), "changed", g_signal_connect_swapped (G_OBJECT (cbev), "changed",
G_CALLBACK G_CALLBACK
@ -205,71 +300,6 @@ xkb_layout_chooser_available_variants_fill (GladeXML * chooser_dialog)
xkl_layout_chooser_separate_default_variant, xkl_layout_chooser_separate_default_variant,
chooser_dialog, chooser_dialog,
NULL); NULL);
} else {
model =
gtk_tree_model_sort_get_model (GTK_TREE_MODEL_SORT
(model));
gtk_tree_store_clear (GTK_TREE_STORE (model));
}
selected_layout_idx =
gtk_combo_box_get_active (GTK_COMBO_BOX (cbel));
if (selected_layout_idx != -1) {
GtkTreeModel *lm =
gtk_combo_box_get_model (GTK_COMBO_BOX (cbel));
GtkTreeIter iter;
GValue val;
memset (&val, 0, sizeof (val));
gtk_tree_model_iter_nth_child (lm, &iter, NULL,
selected_layout_idx);
gtk_tree_model_get_value (lm, &iter,
COMBO_BOX_MODEL_COL_ID, &val);
xkl_config_registry_foreach_layout_variant
(config_registry, g_value_get_string (&val),
(ConfigItemProcessFunc)
xkb_layout_chooser_add_variant_to_available_variants,
chooser_dialog);
xkb_layout_chooser_add_variant_to_available_variants
(config_registry, NULL, chooser_dialog);
g_value_unset (&val);
/* set default variant as selected */
gtk_combo_box_set_active (GTK_COMBO_BOX (cbev), 0);
}
}
static void
xkb_layout_chooser_available_layouts_fill (GladeXML * chooser_dialog)
{
GtkWidget *cbe = CWID ("xkb_layouts_available");
GtkTreeStore *model =
gtk_tree_store_new (2, G_TYPE_STRING, G_TYPE_STRING);
gtk_combo_box_set_model (GTK_COMBO_BOX (cbe),
GTK_TREE_MODEL (model));
gtk_combo_box_entry_set_text_column (GTK_COMBO_BOX_ENTRY (cbe),
COMBO_BOX_MODEL_COL_DESCRIPTION);
xkl_config_registry_foreach_layout (config_registry,
(ConfigItemProcessFunc)
xkb_layout_chooser_add_layout_to_available_layouts,
chooser_dialog);
xkb_layout_chooser_sort_combo_box (cbe,
COMBO_BOX_MODEL_COL_DESCRIPTION);
g_signal_connect_swapped (G_OBJECT (cbe), "changed",
G_CALLBACK
(xkb_layout_chooser_available_layout_changed),
chooser_dialog);
} }
void void
@ -372,7 +402,7 @@ xkb_layout_choose (GladeXML * dialog)
if (!strcmp (xkl_engine_get_backend_name (engine), "XKB")) { if (!strcmp (xkl_engine_get_backend_name (engine), "XKB")) {
kbdraw = xkb_layout_preview_create_widget (chooser_dialog); kbdraw = xkb_layout_preview_create_widget (chooser_dialog);
g_object_set_data (G_OBJECT (chooser), "kbdraw", kbdraw); g_object_set_data (G_OBJECT (chooser), "kbdraw", kbdraw);
gtk_container_add (GTK_CONTAINER (CWID ("vboxPreview")), gtk_container_add (GTK_CONTAINER (CWID ("previewFrame")),
kbdraw); kbdraw);
gtk_widget_show_all (kbdraw); gtk_widget_show_all (kbdraw);
} else } else
@ -402,47 +432,36 @@ xkb_layout_choose (GladeXML * dialog)
gtk_widget_destroy (chooser); gtk_widget_destroy (chooser);
} }
const gchar * gchar *
xkb_layout_chooser_get_selected_id (GladeXML * chooser_dialog) xkb_layout_chooser_get_selected_id (GladeXML * chooser_dialog)
{ {
GtkWidget *cbel = CWID ("xkb_layouts_available"); GtkWidget *cbel = CWID ("xkb_layouts_available");
GtkWidget *cbev = CWID ("xkb_variants_available"); GtkWidget *cbev = CWID ("xkb_variants_available");
GtkTreeModel *lm = gtk_combo_box_get_model (GTK_COMBO_BOX (cbel)); GtkTreeModel *lm = gtk_combo_box_get_model (GTK_COMBO_BOX (cbel));
GtkTreeModel *vm = gtk_combo_box_get_model (GTK_COMBO_BOX (cbev)); GtkTreeModel *vm = gtk_combo_box_get_model (GTK_COMBO_BOX (cbev));
gint lidx = gtk_combo_box_get_active (GTK_COMBO_BOX (cbel)); GtkTreeIter liter, viter;
gint vidx = gtk_combo_box_get_active (GTK_COMBO_BOX (cbev)); gchar *lname, *vname;
gchar *retval;
GtkTreeIter iter; if (!gtk_combo_box_get_active_iter (GTK_COMBO_BOX (cbel), &liter) ||
GValue lval, vval; !gtk_combo_box_get_active_iter (GTK_COMBO_BOX (cbev), &viter))
const gchar *lname, *vname;
static gchar retval[2 * XKL_MAX_CI_NAME_LENGTH];
if (lidx == -1 || vidx == -1)
return NULL; return NULL;
memset (&lval, 0, sizeof (lval)); gtk_tree_model_get (lm, &liter,
memset (&vval, 0, sizeof (vval)); COMBO_BOX_MODEL_COL_ID, &lname,
-1);
gtk_tree_model_iter_nth_child (lm, &iter, NULL, lidx); gtk_tree_model_get (vm, &viter,
gtk_tree_model_get_value (lm, &iter, COMBO_BOX_MODEL_COL_ID, &vname,
COMBO_BOX_MODEL_COL_ID, &lval); -1);
gtk_tree_model_iter_nth_child (vm, &iter, NULL, vidx); if (strcmp (vname, DEFAULT_VARIANT_ID))
gtk_tree_model_get_value (vm, &iter, retval = g_strdup (gkbd_keyboard_config_merge_items (lname, vname));
COMBO_BOX_MODEL_COL_ID, &vval); else
retval = g_strdup (lname);
lname = g_value_get_string (&lval); g_free (lname);
vname = g_value_get_string (&vval); g_free (vname);
g_snprintf (retval, sizeof (retval),
strcmp (vname,
DEFAULT_VARIANT_ID) ?
gkbd_keyboard_config_merge_items (lname,
vname) : lname);
g_value_unset (&lval);
g_value_unset (&vval);
return retval; return retval;
} }

View file

@ -74,7 +74,7 @@ xkb_layout_preview_update (GladeXML * chooser_dialog)
GtkWidget *chooser = CWID ("xkb_layout_chooser"); GtkWidget *chooser = CWID ("xkb_layout_chooser");
GtkWidget *kbdraw = GtkWidget *kbdraw =
GTK_WIDGET (g_object_get_data (G_OBJECT (chooser), "kbdraw")); GTK_WIDGET (g_object_get_data (G_OBJECT (chooser), "kbdraw"));
const gchar *id = gchar *id =
xkb_layout_chooser_get_selected_id (chooser_dialog); xkb_layout_chooser_get_selected_id (chooser_dialog);
if (kbdraw != NULL && id != NULL) { if (kbdraw != NULL && id != NULL) {
@ -119,5 +119,7 @@ xkb_layout_preview_update (GladeXML * chooser_dialog)
} }
g_object_unref (G_OBJECT (data)); g_object_unref (G_OBJECT (data));
} }
g_free (id);
#endif #endif
} }

View file

@ -461,11 +461,7 @@
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkHBox" id="xkb_layouts_panels"> <widget class="GtkVBox" id="vbox41">
<property name="visible">True</property>
<property name="spacing">6</property>
<child>
<widget class="GtkVBox" id="vbox39">
<property name="visible">True</property> <property name="visible">True</property>
<property name="spacing">6</property> <property name="spacing">6</property>
<child> <child>
@ -481,6 +477,10 @@
<property name="fill">False</property> <property name="fill">False</property>
</packing> </packing>
</child> </child>
<child>
<widget class="GtkHBox" id="xkb_layouts_panels">
<property name="visible">True</property>
<property name="spacing">6</property>
<child> <child>
<widget class="GtkScrolledWindow" id="scrolledwindow1"> <widget class="GtkScrolledWindow" id="scrolledwindow1">
<property name="visible">True</property> <property name="visible">True</property>
@ -495,38 +495,19 @@
</widget> </widget>
</child> </child>
</widget> </widget>
<packing>
<property name="position">1</property>
</packing>
</child>
</widget>
</child> </child>
<child> <child>
<widget class="GtkVBox" id="vbox35"> <widget class="GtkVButtonBox" id="vbuttonbox1">
<property name="visible">True</property> <property name="visible">True</property>
<property name="border_width">6</property> <property name="spacing">6</property>
<property name="spacing">12</property> <property name="layout_style">GTK_BUTTONBOX_START</property>
<child>
<widget class="GtkLabel" id="label54">
<property name="visible">True</property>
</widget>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
</packing>
</child>
<child> <child>
<widget class="GtkButton" id="xkb_layouts_add"> <widget class="GtkButton" id="xkb_layouts_add">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="label" translatable="true">_Add...</property> <property name="label">_Add...</property>
<property name="use_underline">True</property> <property name="use_underline">True</property>
</widget> </widget>
<packing>
<property name="expand">False</property>
<property name="fill">False</property>
<property name="position">1</property>
</packing>
</child> </child>
<child> <child>
<widget class="GtkButton" id="xkb_layouts_remove"> <widget class="GtkButton" id="xkb_layouts_remove">
@ -536,9 +517,7 @@
<property name="use_stock">True</property> <property name="use_stock">True</property>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="position">1</property>
<property name="fill">False</property>
<property name="position">2</property>
</packing> </packing>
</child> </child>
<child> <child>
@ -549,9 +528,7 @@
<property name="use_stock">True</property> <property name="use_stock">True</property>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="position">2</property>
<property name="fill">False</property>
<property name="position">3</property>
</packing> </packing>
</child> </child>
<child> <child>
@ -562,14 +539,9 @@
<property name="use_stock">True</property> <property name="use_stock">True</property>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="position">3</property>
<property name="fill">False</property>
<property name="position">4</property>
</packing> </packing>
</child> </child>
<child>
<placeholder/>
</child>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
@ -582,6 +554,11 @@
<property name="position">1</property> <property name="position">1</property>
</packing> </packing>
</child> </child>
</widget>
<packing>
<property name="position">1</property>
</packing>
</child>
<child> <child>
<widget class="GtkCheckButton" id="chk_separate_group_per_window"> <widget class="GtkCheckButton" id="chk_separate_group_per_window">
<property name="visible">True</property> <property name="visible">True</property>
@ -1064,106 +1041,77 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="spacing">2</property> <property name="spacing">2</property>
<child> <child>
<widget class="GtkVBox" id="vbox1"> <widget class="GtkVBox" id="vbox40">
<property name="visible">True</property> <property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property> <property name="border_width">5</property>
<child>
<widget class="GtkHBox" id="hbox1">
<property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<property name="spacing">3</property>
<child>
<widget class="GtkVBox" id="vbox4">
<property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<property name="spacing">6</property> <property name="spacing">6</property>
<child> <child>
<widget class="GtkLabel" id="label3"> <widget class="GtkTable" id="table1">
<property name="visible">True</property>
<property name="n_rows">2</property>
<property name="n_columns">2</property>
<property name="column_spacing">12</property>
<property name="row_spacing">6</property>
<child>
<widget class="GtkComboBox" id="xkb_variants_available">
<property name="visible">True</property> <property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<property name="xalign">0</property>
<property name="label" translatable="yes">_Layouts:</property>
<property name="use_underline">True</property>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="left_attach">1</property>
<property name="fill">False</property> <property name="right_attach">2</property>
<property name="top_attach">1</property>
<property name="bottom_attach">2</property>
<property name="x_options">GTK_FILL</property>
<property name="y_options">GTK_FILL</property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkComboBoxEntry" id="xkb_layouts_available"> <widget class="GtkComboBox" id="xkb_layouts_available">
<property name="visible">True</property> <property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<child internal-child="entry">
<widget class="GtkEntry" id="comboboxentry-entry1">
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<property name="editable">False</property>
</widget>
</child>
</widget> </widget>
<packing> <packing>
<property name="position">1</property> <property name="left_attach">1</property>
<property name="right_attach">2</property>
<property name="x_options">GTK_FILL</property>
<property name="y_options">GTK_FILL</property>
</packing> </packing>
</child> </child>
</widget>
<packing>
<property name="padding">3</property>
</packing>
</child>
<child>
<widget class="GtkVBox" id="vbox5">
<property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<property name="spacing">3</property>
<child> <child>
<widget class="GtkLabel" id="label4"> <widget class="GtkLabel" id="label4">
<property name="visible">True</property> <property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<property name="xalign">0</property> <property name="xalign">0</property>
<property name="label" translatable="yes">_Variants:</property> <property name="label" translatable="yes">_Variants:</property>
<property name="use_underline">True</property> <property name="use_underline">True</property>
<property name="mnemonic_widget">xkb_variants_available</property>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="top_attach">1</property>
<property name="fill">False</property> <property name="bottom_attach">2</property>
<property name="x_options">GTK_FILL</property>
<property name="y_options"></property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkComboBoxEntry" id="xkb_variants_available"> <widget class="GtkLabel" id="label3">
<property name="visible">True</property> <property name="visible">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property> <property name="xalign">0</property>
<child internal-child="entry"> <property name="label" translatable="yes">_Layouts:</property>
<widget class="GtkEntry" id="comboboxentry-entry2"> <property name="use_underline">True</property>
<property name="visible">True</property> <property name="mnemonic_widget">xkb_layouts_available</property>
<property name="can_focus">True</property>
<property name="events">GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK</property>
<property name="editable">False</property>
</widget>
</child>
</widget> </widget>
<packing> <packing>
<property name="position">1</property> <property name="x_options">GTK_FILL</property>
</packing> <property name="y_options"></property>
</child>
</widget>
<packing>
<property name="padding">3</property>
<property name="position">1</property>
</packing> </packing>
</child> </child>
</widget> </widget>
<packing> <packing>
<property name="expand">False</property> <property name="expand">False</property>
<property name="fill">False</property>
<property name="padding">3</property>
</packing> </packing>
</child> </child>
<child> <child>
<widget class="GtkVBox" id="vboxPreview"> <widget class="GtkVBox" id="vboxPreview">
<property name="visible">True</property> <property name="visible">True</property>
<property name="border_width">5</property>
<property name="spacing">6</property> <property name="spacing">6</property>
<child> <child>
<widget class="GtkLabel" id="label2"> <widget class="GtkLabel" id="label2">
@ -1176,6 +1124,11 @@
<property name="fill">False</property> <property name="fill">False</property>
</packing> </packing>
</child> </child>
<child>
<widget class="GtkFrame" id="previewFrame">
<property name="visible">True</property>
<property name="label_xalign">0</property>
<property name="shadow_type">GTK_SHADOW_IN</property>
<child> <child>
<placeholder/> <placeholder/>
</child> </child>
@ -1189,6 +1142,11 @@
<property name="position">1</property> <property name="position">1</property>
</packing> </packing>
</child> </child>
</widget>
<packing>
<property name="position">1</property>
</packing>
</child>
<child internal-child="action_area"> <child internal-child="action_area">
<widget class="GtkHButtonBox" id="dialog-action_area2"> <widget class="GtkHButtonBox" id="dialog-action_area2">
<property name="visible">True</property> <property name="visible">True</property>
@ -1208,7 +1166,7 @@
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="can_default">True</property> <property name="can_default">True</property>
<property name="label">gtk-ok</property> <property name="label">gtk-add</property>
<property name="use_stock">True</property> <property name="use_stock">True</property>
<property name="response_id">-5</property> <property name="response_id">-5</property>
</widget> </widget>