aboutsummaryrefslogtreecommitdiffstats
path: root/widgets/table
diff options
context:
space:
mode:
Diffstat (limited to 'widgets/table')
-rw-r--r--widgets/table/e-table-config.c86
1 files changed, 52 insertions, 34 deletions
diff --git a/widgets/table/e-table-config.c b/widgets/table/e-table-config.c
index af31e1e788..a8c413dd98 100644
--- a/widgets/table/e-table-config.c
+++ b/widgets/table/e-table-config.c
@@ -56,6 +56,21 @@ config_clear_group (GtkWidget *widget, ETableConfig *config)
gtk_object_unref (GTK_OBJECT (config));
}
+static ETableColumnSpecification *
+find_column_in_spec (ETableSpecification *spec, int model_col)
+{
+ ETableColumnSpecification **column;
+
+ for (column = spec->columns; *column; column++){
+ if ((*column)->model_col != model_col)
+ continue;
+
+ return *column;
+ }
+
+ return NULL;
+}
+
static void
config_sort_config_show (GtkWidget *widget, ETableConfig *config)
{
@@ -71,6 +86,13 @@ config_sort_config_show (GtkWidget *widget, ETableConfig *config)
gboolean sensitive = (i <= count);
gtk_widget_set_sensitive (config->frames [i], sensitive);
+
+ /*
+ * Sorting is set, auto select the text
+ */
+ if ((i + 1) >= count){
+
+ }
}
button = gnome_dialog_run (dialog);
@@ -86,30 +108,29 @@ config_sort_info_update (ETableConfig *config)
{
ETableSortInfo *info = config->state->sort_info;
GString *res;
- int count, i, items = 0;
+ int count, i;
count = e_table_sort_info_sorting_get_count (info);
res = g_string_new ("");
for (i = 0; i < count; i++) {
ETableSortColumn col = e_table_sort_info_sorting_get_nth (info, i);
- ETableColumnSpecification **column;
-
- for (column = config->spec->columns; *column; column++) {
- if (col.column != (*column)->model_col)
- continue;
-
- g_string_append (res, _((*column)->title));
- g_string_append_c (res, ' ');
- g_string_append (
- res,
- col.ascending ?
- _("(Ascending)") : _("(Descending)"));
- items++;
- if (items > 4)
- g_string_append_c (res, '\n');
+ ETableColumnSpecification *column;
+
+ column = find_column_in_spec (config->spec, col.column);
+ if (!column){
+ g_warning ("Could not find column model in specification");
+ continue;
}
+
+ g_string_append (res, gettext ((column)->title));
+ g_string_append_c (res, ' ');
+ g_string_append (
+ res,
+ col.ascending ?
+ _("(Ascending)") : _("(Descending)"));
}
+
if (res->str [0] == 0)
g_string_append (res, _("Not sorted"));
@@ -123,30 +144,27 @@ config_group_info_update (ETableConfig *config)
{
ETableSortInfo *info = config->state->sort_info;
GString *res;
- int count, i, items = 0;
+ int count, i;
count = e_table_sort_info_grouping_get_count (info);
res = g_string_new ("");
for (i = 0; i < count; i++) {
ETableSortColumn col = e_table_sort_info_grouping_get_nth (info, i);
- ETableColumnSpecification **column;
+ ETableColumnSpecification *column;
- for (column = config->spec->columns; *column; column++) {
- if (col.column != (*column)->model_col)
- continue;
-
- g_string_append (res, _((*column)->title));
- g_string_append_c (res, ' ');
- g_string_append (
- res,
- col.ascending ?
- _("(Ascending)") : _("(Descending)"));
-
- items++;
- if (items > 4)
- g_string_append_c (res, '\n');
+ column = find_column_in_spec (config->spec, col.column);
+ if (!column){
+ g_warning ("Could not find model column in specification");
+ continue;
}
+
+ g_string_append (res, gettext ((column)->title));
+ g_string_append_c (res, ' ');
+ g_string_append (
+ res,
+ col.ascending ?
+ _("(Ascending)") : _("(Descending)"));
}
if (res->str [0] == 0)
g_string_append (res, _("No grouping"));
@@ -168,7 +186,7 @@ config_fields_info_update (ETableConfig *config)
if (config->state->columns [i] != (*column)->model_col)
continue;
- g_string_append (res, _((*column)->title));
+ g_string_append (res, gettext ((*column)->title));
if (column [1])
g_string_append (res, ", ");
items++;
@@ -249,7 +267,7 @@ configure_sort_dialog (ETableConfig *config, GladeXML *gui)
for (i = 0; i < 4; i++){
gtk_combo_text_add_item (
config->sort_combos [i],
- _(label), label);
+ gettext (label), label);
}
}
}