aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--widgets/misc/ChangeLog6
-rw-r--r--widgets/misc/e-multi-config-dialog.c137
2 files changed, 44 insertions, 99 deletions
diff --git a/widgets/misc/ChangeLog b/widgets/misc/ChangeLog
index 1469b80d87..7127146d30 100644
--- a/widgets/misc/ChangeLog
+++ b/widgets/misc/ChangeLog
@@ -1,3 +1,9 @@
+2002-03-12 Christopher James Lahey <clahey@ximian.com>
+
+ * e-multi-config-dialog.c (init): Use Use e_table_memory_store
+ instead of e_table_memory_callbacks. Use e_cell_vbox to include a
+ pixbuf cell and a text cell.
+
2002-03-11 Ettore Perazzoli <ettore@ximian.com>
* e-multi-config-dialog.c (init): Use GNOME_STOCK_BUTTON_CLOSE,
diff --git a/widgets/misc/e-multi-config-dialog.c b/widgets/misc/e-multi-config-dialog.c
index a843a0178c..df773f90f1 100644
--- a/widgets/misc/e-multi-config-dialog.c
+++ b/widgets/misc/e-multi-config-dialog.c
@@ -29,7 +29,10 @@
#include "e-clipped-label.h"
#include <gal/e-table/e-table-scrolled.h>
-#include <gal/e-table/e-table-memory-callbacks.h>
+#include <gal/e-table/e-table-memory-store.h>
+#include <gal/e-table/e-cell-pixbuf.h>
+#include <gal/e-table/e-cell-vbox.h>
+#include <gal/e-table/e-cell-text.h>
#include <gdk-pixbuf/gdk-pixbuf.h>
@@ -63,10 +66,12 @@ struct _EMultiConfigDialogPrivate {
static char *list_e_table_spec =
"<ETableSpecification cursor-mode=\"line\""
" selection-mode=\"browse\""
- " no-headers=\"true\">"
+ " no-headers=\"true\""
+/* " horizontal-resize=\"true\""*/
+ ">"
" <ETableColumn model_col=\"0\""
" expansion=\"1.0\""
- " cell=\"string\""
+ " cell=\"vbox\""
" minimum_width=\"32\""
" resizable=\"true\""
" _title=\"blah\""
@@ -218,89 +223,6 @@ do_ok (EMultiConfigDialog *dialog)
}
-/* ETable mess. */
-
-static int
-table_model_column_count (ETableModel *etm,
- void *data)
-{
- return 1;
-}
-
-static void *
-table_model_value_at (ETableModel *etm,
- int col,
- int row,
- void *model_data)
-{
- EMultiConfigDialog *dialog;
- EMultiConfigDialogPrivate *priv;
- const Page *page;
- GSList *p;
-
- dialog = E_MULTI_CONFIG_DIALOG (model_data);
- priv = dialog->priv;
-
- p = g_slist_nth (priv->pages, row);
- if (p == NULL)
- return NULL;
-
- page = (const Page *) p->data;
- return page->title;
-}
-
-static gboolean
-table_model_is_editable (ETableModel *etm,
- int col,
- int row,
- void *model_data)
-{
- return FALSE;
-}
-
-static void *
-table_model_duplicate_value (ETableModel *etm,
- int col,
- const void *value,
- void *data)
-{
- return g_strdup (value);
-}
-
-static void
-table_model_free_value (ETableModel *etm,
- int col,
- void *value,
- void *data)
-{
- g_free (value);
-}
-
-static void *
-table_model_initialize_value (ETableModel *etm,
- int col,
- void *data)
-{
- return g_strdup ("");
-}
-
-static gboolean
-table_model_value_is_empty (ETableModel *etm,
- int col,
- const void *value,
- void *data)
-{
- return !(value && *(char *)value);
-}
-
-static char *
-table_model_value_to_string (ETableModel *etm,
- int col,
- const void *value,
- void *data)
-{
- return (char *)value;
-}
/* ETable signals. */
@@ -387,6 +309,12 @@ class_init (EMultiConfigDialogClass *class)
parent_class = gtk_type_class (PARENT_TYPE);
}
+ETableMemoryStoreColumnInfo columns[] = {
+ E_TABLE_MEMORY_STORE_STRING,
+ E_TABLE_MEMORY_STORE_PIXBUF,
+ E_TABLE_MEMORY_STORE_TERMINATOR
+};
+
static void
init (EMultiConfigDialog *multi_config_dialog)
{
@@ -396,27 +324,38 @@ init (EMultiConfigDialog *multi_config_dialog)
GtkWidget *hbox;
GtkWidget *notebook;
GtkWidget *list_e_table;
+ ETableExtras *extras;
+ ECell *pixbuf;
+ ECell *text;
+ ECell *vbox;
hbox = gtk_hbox_new (FALSE, 2);
gnome_dialog_vbox = GNOME_DIALOG (multi_config_dialog)->vbox;
gtk_container_add (GTK_CONTAINER (gnome_dialog_vbox), hbox);
- list_e_table_model = e_table_memory_callbacks_new (table_model_column_count,
- table_model_value_at,
- NULL, /* set_value_at */
- table_model_is_editable,
- table_model_duplicate_value,
- table_model_free_value,
- table_model_initialize_value,
- table_model_value_is_empty,
- table_model_value_to_string,
- multi_config_dialog);
-
- list_e_table = e_table_scrolled_new (list_e_table_model, NULL, list_e_table_spec, NULL);
+ list_e_table_model = e_table_memory_store_new (columns);
+
+ vbox = e_cell_vbox_new ();
+
+ pixbuf = e_cell_pixbuf_new();
+ e_cell_vbox_append (E_CELL_VBOX (vbox), pixbuf, 1);
+ gtk_object_unref (GTK_OBJECT (pixbuf));
+
+ text = e_cell_text_new (NULL, GTK_JUSTIFY_CENTER);
+ e_cell_vbox_append (E_CELL_VBOX (vbox), text, 0);
+ gtk_object_unref (GTK_OBJECT (text));
+
+ extras = e_table_extras_new ();
+ e_table_extras_add_cell (extras, "vbox", vbox);
+
+ list_e_table = e_table_scrolled_new (list_e_table_model, extras, list_e_table_spec, NULL);
+ e_scroll_frame_set_policy (E_SCROLL_FRAME (list_e_table), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
gtk_signal_connect (GTK_OBJECT (e_table_scrolled_get_table (E_TABLE_SCROLLED (list_e_table))),
"cursor_change", GTK_SIGNAL_FUNC (table_cursor_change_callback),
multi_config_dialog);
+ gtk_object_unref (GTK_OBJECT (extras));
+
gtk_widget_set_usize (list_e_table, 150, -1);
gtk_box_pack_start (GTK_BOX (hbox), list_e_table, FALSE, TRUE, 0);
@@ -495,7 +434,7 @@ e_multi_config_dialog_add_page (EMultiConfigDialog *dialog,
e_selection_model_select_all (e_table_get_selection_model (table));
}
- e_table_memory_insert (E_TABLE_MEMORY (priv->list_e_table_model), -1, new_page->title);
+ e_table_memory_store_insert_list (E_TABLE_MEMORY_STORE (priv->list_e_table_model), -1, NULL, title, icon);
gtk_notebook_append_page (GTK_NOTEBOOK (priv->notebook),
create_page_container (new_page->description, GTK_WIDGET (page_widget)),