#include "defs.h"
#include <glib.h>
+#include <glib/gi18n.h>
#include <gtk/gtk.h>
#include <gtk/gtkoptionmenu.h>
#include <gdk/gdkkeysyms.h>
#include <stdio.h>
#include <stdlib.h>
-#include "intl.h"
#include "stock_pixmap.h"
#include "manage_window.h"
#include "gtkutils.h"
#include "toolbar.h"
#include "prefs_toolbar.h"
+#include "prefswindow.h"
+#include "prefs_gtk.h"
-typedef enum
+enum
{
- COL_ICON = 0,
- COL_FILENAME = 1,
- COL_TEXT = 2,
- COL_EVENT = 3
-} DisplayedItemsColumnPos;
-
-# define N_DISPLAYED_ITEMS_COLS 4
+ SET_ICON = 0,
+ SET_FILENAME = 1,
+ SET_TEXT = 2,
+ SET_EVENT = 3,
+ SET_ICON_TEXT = 4, /*!< "icon" text (separator) */
+ SET_ICON_IS_TEXT = 5, /*!< icon is text representation */
+ N_SET_COLUMNS
+};
+
+typedef struct _ToolbarPage
+{
+ PrefsPage page;
-static struct _Toolbar {
- GtkWidget *window;
+ GtkWidget *window; /* do not modify */
- GtkWidget *clist_icons;
- GtkWidget *clist_set;
+ GtkWidget *list_view_icons;
+ GtkWidget *list_view_set;
GtkWidget *combo_action;
GtkWidget *combo_entry;
GtkWidget *combo_list;
GtkWidget *combo_syl_list;
GtkWidget *combo_syl_entry;
- Toolbar source;
- GList *combo_action_list;
+ ToolbarType source;
+ GList *combo_action_list;
-}toolbar;
+} ToolbarPage;
-#define CELL_SPACING 24
#define ERROR_MSG _("Selected Action already set.\nPlease choose another Action from List")
-static void prefs_toolbar_populate (void);
-static gboolean is_duplicate (gchar *chosen_action);
-static void prefs_toolbar_save (void);
+static void prefs_toolbar_populate (ToolbarPage *prefs_toolbar);
+static gboolean is_duplicate (ToolbarPage *prefs_toolbar,
+ gchar *chosen_action);
+static void prefs_toolbar_save (PrefsPage *_page);
-static void prefs_toolbar_ok (GtkButton *button,
- gpointer data);
-static void prefs_toolbar_cancel (GtkButton *button,
- gpointer data);
-static void prefs_toolbar_default (GtkButton *button,
- gpointer data);
+static void prefs_toolbar_register (GtkButton *button,
+ ToolbarPage *prefs_toolbar);
+static void prefs_toolbar_substitute (GtkButton *button,
+ ToolbarPage *prefs_toolbar);
+static void prefs_toolbar_delete (GtkButton *button,
+ ToolbarPage *prefs_toolbar);
-static void prefs_toolbar_register (GtkButton *button,
- gpointer data);
-static void prefs_toolbar_substitute (GtkButton *button,
- gpointer data);
-static void prefs_toolbar_delete (GtkButton *button,
- gpointer data);
+static void prefs_toolbar_up (GtkButton *button,
+ ToolbarPage *prefs_toolbar);
-static void prefs_toolbar_up (GtkButton *button,
- gpointer data);
+static void prefs_toolbar_down (GtkButton *button,
+ ToolbarPage *prefs_toolbar);
-static void prefs_toolbar_down (GtkButton *button,
- gpointer data);
+static void prefs_toolbar_create (ToolbarPage *prefs_toolbar);
-static void prefs_toolbar_select_row_set (GtkCList *clist,
- gint row,
- gint column,
- GdkEvent *event,
- gpointer user_data);
+static void prefs_toolbar_selection_changed (GtkList *list,
+ ToolbarPage *prefs_toolbar);
-static void prefs_toolbar_select_row_icons (GtkCList *clist,
- gint row,
- gint column,
- GdkEvent *event,
- gpointer user_data);
+static GtkWidget *create_icon_list_view (ToolbarPage *prefs_toolbar);
-static void prefs_toolbar_create (void);
+static GtkWidget *create_set_list_view (ToolbarPage *prefs_toolbar);
-static void prefs_toolbar_selection_changed (GtkList *list,
- gpointer user_data);
+static gboolean icon_list_selected (GtkTreeSelection *selector,
+ GtkTreeModel *model,
+ GtkTreePath *path,
+ gboolean currently_selected,
+ ToolbarPage *prefs_toolbar);
-static gint prefs_toolbar_key_pressed (GtkWidget *widget,
- GdkEventKey *event,
- gpointer data);
+static gboolean set_list_selected (GtkTreeSelection *selector,
+ GtkTreeModel *model,
+ GtkTreePath *path,
+ gboolean currently_selected,
+ ToolbarPage *prefs_toolbar);
-void prefs_toolbar(Toolbar source)
+void prefs_toolbar_create_widget(PrefsPage *_page, GtkWindow *window, gpointer data)
{
- gchar *win_titles[2];
- win_titles[TOOLBAR_MAIN] = _("Main Toolbar Configuration");
- win_titles[TOOLBAR_COMPOSE] = _("Compose Toolbar Configuration");
+ ToolbarPage *prefs_toolbar = (ToolbarPage *) _page;
+ gchar *win_titles[3];
+ win_titles[TOOLBAR_MAIN] = _("Main toolbar configuration");
+ win_titles[TOOLBAR_COMPOSE] = _("Compose toolbar configuration");
+ win_titles[TOOLBAR_MSGVIEW] = _("Message view toolbar configuration");
- toolbar.source = source;
+ prefs_toolbar->window = GTK_WIDGET(window);
- toolbar_read_config_file(toolbar.source);
+ toolbar_read_config_file(prefs_toolbar->source);
- if (!toolbar.window)
- prefs_toolbar_create();
-
- manage_window_set_transient(GTK_WINDOW(toolbar.window));
- prefs_toolbar_populate();
- gtk_window_set_title(GTK_WINDOW(toolbar.window), win_titles[toolbar.source]);
- gtk_widget_show(toolbar.window);
+ prefs_toolbar_create(prefs_toolbar);
+ prefs_toolbar_populate(prefs_toolbar);
}
-void prefs_toolbar_close(void)
+void prefs_toolbar_save(PrefsPage *_page)
{
- gtk_widget_hide(toolbar.window);
- if (toolbar.source == TOOLBAR_MAIN)
+ ToolbarPage *prefs_toolbar = (ToolbarPage *) _page;
+ GtkTreeView *list_view = GTK_TREE_VIEW(prefs_toolbar->list_view_set);
+ GtkTreeModel *model = gtk_tree_view_get_model(list_view);
+ GtkTreeIter iter;
+
+ toolbar_clear_list(prefs_toolbar->source);
+
+ if (!gtk_tree_model_iter_n_children(model, NULL)
+ || !gtk_tree_model_get_iter_first(model, &iter))
+ toolbar_set_default(prefs_toolbar->source);
+ else {
+ do {
+ ToolbarItem *item;
+ gchar *fname, *text, *event;
+
+ item = g_new0(ToolbarItem, 1);
+
+ gtk_tree_model_get(model, &iter,
+ SET_FILENAME, &fname,
+ SET_TEXT, &text,
+ SET_EVENT, &event,
+ -1);
+
+ /* XXX: remember that G_TYPE_STRING returned by model
+ * is owned by caller of gtk_tree_model_get() */
+ item->file = fname;
+ item->text = text;
+ item->index = toolbar_ret_val_from_descr(event);
+ g_free(event);
+
+ /* TODO: save A_SYL_ACTIONS only if they are still active */
+ toolbar_set_list_item(item, prefs_toolbar->source);
+
+ g_free(item->file);
+ g_free(item->text);
+ g_free(item);
+ } while (gtk_tree_model_iter_next(model, &iter));
+ }
+
+ toolbar_save_config_file(prefs_toolbar->source);
+
+ if (prefs_toolbar->source == TOOLBAR_MAIN)
main_window_reflect_prefs_all_real(TRUE);
- else if (toolbar.source == TOOLBAR_COMPOSE)
+ else if (prefs_toolbar->source == TOOLBAR_COMPOSE)
compose_reflect_prefs_pixmap_theme();
-
- g_list_free(toolbar.combo_action_list);
-
+ else if (prefs_toolbar->source == TOOLBAR_MSGVIEW)
+ messageview_reflect_prefs_pixmap_theme();
}
-static void prefs_toolbar_set_displayed(void)
+static void prefs_toolbar_destroy_widget(PrefsPage *_page)
+{
+ ToolbarPage *prefs_toolbar = (ToolbarPage *) _page;
+
+ g_list_free(prefs_toolbar->combo_action_list);
+ prefs_toolbar->combo_action_list = NULL;
+}
+
+static void prefs_toolbar_set_displayed(ToolbarPage *prefs_toolbar)
{
- GdkPixmap *xpm;
- GdkBitmap *xpmmask;
- gchar *activ[4];
GSList *cur;
- GtkCList *clist_set = GTK_CLIST(toolbar.clist_set);
- GSList *toolbar_list = toolbar_get_list(toolbar.source);
+ GtkTreeView *list_view_set = GTK_TREE_VIEW(prefs_toolbar->list_view_set);
+ GtkListStore *store = GTK_LIST_STORE(gtk_tree_view_get_model
+ (list_view_set));
+ GSList *toolbar_list = toolbar_get_list(prefs_toolbar->source);
+ GtkTreeIter iter;
- gtk_clist_clear(clist_set);
- gtk_clist_freeze(clist_set);
+ gtk_list_store_clear(store);
/* set currently active toolbar entries */
for (cur = toolbar_list; cur != NULL; cur = cur->next) {
ToolbarItem *item = (ToolbarItem*) cur->data;
+
+ gtk_list_store_append(store, &iter);
- if (g_strcasecmp(item->file, SEPARATOR) != 0) {
- gint row_num;
+ if (item->index != A_SEPARATOR) {
+ GdkPixbuf *pix;
StockPixmap icon = stock_pixmap_get_icon(item->file);
- stock_pixmap_gdk(toolbar.clist_set, icon,
- &xpm, &xpmmask);
- activ[0] = g_strdup("");
- activ[1] = g_strdup(item->file);
- activ[2] = g_strdup(item->text);
- activ[3] = g_strdup(toolbar_ret_descr_from_val(item->index));
- row_num = gtk_clist_append(clist_set, activ);
- gtk_clist_set_pixmap(clist_set,
- row_num, 0, xpm, xpmmask);
-
+ stock_pixbuf_gdk(prefs_toolbar->window, icon, &pix);
+
+ gtk_list_store_set(store, &iter,
+ SET_ICON, pix,
+ SET_FILENAME, item->file,
+ SET_TEXT, item->text,
+ SET_EVENT, toolbar_ret_descr_from_val(item->index),
+ SET_ICON_TEXT, NULL,
+ SET_ICON_IS_TEXT, FALSE,
+ -1);
} else {
- activ[0] = g_strdup(SEPARATOR_PIXMAP);
- activ[1] = g_strdup(item->file);
- activ[2] = g_strdup("");
- activ[3] = g_strdup("");
- gtk_clist_append(clist_set, activ);
+ gtk_list_store_set(store, &iter,
+ SET_ICON, NULL,
+ SET_FILENAME, toolbar_ret_descr_from_val(A_SEPARATOR),
+ SET_TEXT, (const gchar *) "",
+ SET_EVENT, toolbar_ret_descr_from_val(A_SEPARATOR),
+ SET_ICON_TEXT, (const gchar *) SEPARATOR_PIXMAP,
+ SET_ICON_IS_TEXT, TRUE,
+ -1);
}
-
- g_free(activ[0]);
- g_free(activ[1]);
- g_free(activ[2]);
- g_free(activ[3]);
}
- gtk_clist_thaw(clist_set);
- gtk_clist_columns_autosize(clist_set);
- gtk_clist_set_row_height(clist_set, CELL_SPACING);
- gtk_clist_select_row(clist_set, 0, 0);
+ /* select first */
+ gtk_tree_model_get_iter_first(GTK_TREE_MODEL(store), &iter);
+ gtk_tree_selection_select_iter(gtk_tree_view_get_selection
+ (list_view_set),
+ &iter);
}
-static void prefs_toolbar_populate(void)
+static void prefs_toolbar_populate(ToolbarPage *prefs_toolbar)
{
gint i;
GSList *cur;
GList *syl_actions = NULL;
- GtkCList *clist_icons = GTK_CLIST(toolbar.clist_icons);
- GdkPixmap *xpm;
- GdkBitmap *xpmmask;
- gchar *avail[2];
+ GtkTreeView *list_view_icons = GTK_TREE_VIEW
+ (prefs_toolbar->list_view_icons);
+ GtkListStore *store = GTK_LIST_STORE(gtk_tree_view_get_model
+ (list_view_icons));
gchar *act;
+ GtkTreeIter iter;
- gtk_clist_clear(clist_icons);
- gtk_clist_freeze(clist_icons);
+ gtk_list_store_clear(store);
/* set available icons */
- avail[0] = g_strdup(SEPARATOR_PIXMAP);
- avail[1] = g_strdup(SEPARATOR);
- gtk_clist_append(clist_icons, avail);
- g_free(avail[0]);
- g_free(avail[1]);
-
- toolbar.combo_action_list = toolbar_get_action_items(toolbar.source);
- gtk_combo_set_popdown_strings(GTK_COMBO(toolbar.combo_action), toolbar.combo_action_list);
- gtk_combo_set_value_in_list(GTK_COMBO(toolbar.combo_action), 0, FALSE);
- gtk_entry_set_text(GTK_ENTRY(toolbar.combo_entry), toolbar.combo_action_list->data);
- //g_list_free(combo_action_list);
+ gtk_list_store_append(store, &iter);
+ gtk_list_store_set(store, &iter,
+ SET_ICON, NULL,
+ SET_ICON_TEXT, SEPARATOR_PIXMAP,
+ SET_ICON_IS_TEXT, TRUE,
+ SET_FILENAME, toolbar_ret_descr_from_val(A_SEPARATOR),
+ -1);
+
+ prefs_toolbar->combo_action_list = toolbar_get_action_items(prefs_toolbar->source);
+ gtk_combo_set_popdown_strings(GTK_COMBO(prefs_toolbar->combo_action),
+ prefs_toolbar->combo_action_list);
+ gtk_combo_set_value_in_list(GTK_COMBO(prefs_toolbar->combo_action), 0, FALSE);
+ gtk_entry_set_text(GTK_ENTRY(prefs_toolbar->combo_entry), prefs_toolbar->combo_action_list->data);
/* get currently defined sylpheed actions */
if (prefs_common.actions_list != NULL) {
syl_actions = g_list_append(syl_actions, act);
}
- gtk_combo_set_popdown_strings(GTK_COMBO(toolbar.combo_syl_action), syl_actions);
- gtk_combo_set_value_in_list(GTK_COMBO(toolbar.combo_syl_action), 0, FALSE);
- gtk_entry_set_text(GTK_ENTRY(toolbar.combo_syl_entry), syl_actions->data);
- prefs_toolbar_selection_changed(GTK_LIST(toolbar.combo_syl_list), NULL);
+ gtk_combo_set_popdown_strings(GTK_COMBO(prefs_toolbar->combo_syl_action), syl_actions);
+ gtk_combo_set_value_in_list(GTK_COMBO(prefs_toolbar->combo_syl_action), 0, FALSE);
+ gtk_entry_set_text(GTK_ENTRY(prefs_toolbar->combo_syl_entry), syl_actions->data);
+ prefs_toolbar_selection_changed(GTK_LIST(prefs_toolbar->combo_syl_list), prefs_toolbar);
g_list_free(syl_actions);
}
- for (i = 0; i < N_STOCK_PIXMAPS; i++) {
- avail[0] = g_strdup("");
- avail[1] = g_strdup(stock_pixmap_get_name((StockPixmap)i));
+ for (i = 0; i < STOCK_PIXMAP_SYLPHEED_LOGO; i++) {
+ GdkPixbuf *pixbuf;
- stock_pixmap_gdk(toolbar.clist_icons, i,
- &xpm, &xpmmask);
- gtk_clist_append(clist_icons, avail);
- gtk_clist_set_pixmap(clist_icons,
- i + 1, 0, xpm, xpmmask);
+ stock_pixbuf_gdk(prefs_toolbar->window, i, &pixbuf);
- g_free(avail[0]);
- g_free(avail[1]);
+ gtk_list_store_append(store, &iter);
+ gtk_list_store_set(store, &iter,
+ SET_ICON, pixbuf,
+ SET_FILENAME, stock_pixmap_get_name((StockPixmap) i),
+ SET_ICON_TEXT, NULL,
+ SET_ICON_IS_TEXT, FALSE,
+ -1);
}
- gtk_clist_thaw(clist_icons);
- gtk_clist_columns_autosize(clist_icons);
- gtk_clist_set_row_height(clist_icons, CELL_SPACING);
- gtk_clist_select_row(clist_icons, 0, 0);
+ gtk_tree_model_get_iter_first(GTK_TREE_MODEL(store), &iter);
+ gtk_tree_selection_select_iter(gtk_tree_view_get_selection
+ (list_view_icons),
+ &iter);
- prefs_toolbar_set_displayed();
+ prefs_toolbar_set_displayed(prefs_toolbar);
- toolbar_clear_list(toolbar.source);
+ toolbar_clear_list(prefs_toolbar->source);
}
-static gboolean is_duplicate(gchar *chosen_action)
+static gboolean is_duplicate(ToolbarPage *prefs_toolbar, gchar *chosen_action)
{
- GtkCList *clist = GTK_CLIST(toolbar.clist_set);
+ GtkTreeView *list_view_set = GTK_TREE_VIEW
+ (prefs_toolbar->list_view_set);
+ GtkTreeModel *model_set = gtk_tree_view_get_model(list_view_set);
gchar *entry;
- gint row = 0;
gchar *syl_act = toolbar_ret_descr_from_val(A_SYL_ACTIONS);
+ GtkTreeIter iter;
+ gboolean result;
g_return_val_if_fail(chosen_action != NULL, TRUE);
- if (clist->rows == 0)
+
+ if (!gtk_tree_model_iter_n_children(model_set, NULL))
return FALSE;
/* allow duplicate entries (A_SYL_ACTIONS) */
- if (g_strcasecmp(syl_act, chosen_action) == 0)
+ if (g_utf8_collate(syl_act, chosen_action) == 0)
return FALSE;
- do {
- gtk_clist_get_text(clist, row, 3, &entry);
- if ( g_strcasecmp(chosen_action, entry) == 0)
- return TRUE;
- row++;
- } while ((gtk_clist_get_text(clist, row, 3, &entry)) && (row <= clist->rows));
-
- return FALSE;
-}
-
-static void prefs_toolbar_save(void)
-{
- gint row = 0;
- GtkCList *clist = GTK_CLIST(toolbar.clist_set);
- gchar *entry = NULL;
-
- toolbar_clear_list(toolbar.source);
-
- if (clist->rows == 0) {
- toolbar_set_default(toolbar.source);
- }
- else {
- do {
- ToolbarItem *t_item = g_new0(ToolbarItem, 1);
-
- gtk_clist_get_text(clist, row, 1, &entry);
- t_item->file = g_strdup(entry);
-
- gtk_clist_get_text(clist, row, 2, &entry);
- t_item->text = g_strdup(entry);
-
- gtk_clist_get_text(clist, row, 3, &entry);
- t_item->index = toolbar_ret_val_from_descr(entry);
-
- /* TODO: save A_SYL_ACTIONS only if they are still active */
- toolbar_set_list_item(t_item, toolbar.source);
-
- g_free(t_item->file);
- g_free(t_item->text);
- g_free(t_item);
- row++;
-
- } while(gtk_clist_get_text(clist, row, 3, &entry));
- }
-
- toolbar_save_config_file(toolbar.source);
-}
-
-static void prefs_toolbar_ok(GtkButton *button, gpointer data)
-{
- prefs_toolbar_save();
- prefs_toolbar_close();
-}
+ if (!gtk_tree_model_get_iter_first(model_set, &iter))
+ return FALSE;
-static void prefs_toolbar_cancel(GtkButton *button, gpointer data)
-{
- prefs_toolbar_close();
+ result = FALSE;
+ do {
+ gtk_tree_model_get(model_set, &iter,
+ SET_EVENT, &entry,
+ -1);
+ if (g_utf8_collate(chosen_action, entry) == 0)
+ result = TRUE;
+ g_free(entry);
+ } while (!result && gtk_tree_model_iter_next(model_set, &iter));
+
+ return result;
}
-static void prefs_toolbar_default(GtkButton *button, gpointer data)
+static void prefs_toolbar_default(GtkButton *button, ToolbarPage *prefs_toolbar)
{
- toolbar_clear_list(toolbar.source);
- toolbar_set_default(toolbar.source);
- prefs_toolbar_set_displayed();
+ toolbar_clear_list(prefs_toolbar->source);
+ toolbar_set_default(prefs_toolbar->source);
+ prefs_toolbar_set_displayed(prefs_toolbar);
}
-static void get_action_name(gchar *entry, gchar **menu)
+/*!
+ *\return String that should be freed by caller.
+ */
+static void get_action_name(const gchar *entry, gchar **menu)
{
gchar *act, *act_p;
}
}
-static void prefs_toolbar_register(GtkButton *button, gpointer data)
+static void prefs_toolbar_register(GtkButton *button, ToolbarPage *prefs_toolbar)
{
- GtkCList *clist_set = GTK_CLIST(toolbar.clist_set);
- GtkCList *clist_icons = GTK_CLIST(toolbar.clist_icons);
+ GtkTreeView *list_view_set = GTK_TREE_VIEW(prefs_toolbar->list_view_set);
+ GtkTreeView *list_view_icons = GTK_TREE_VIEW(prefs_toolbar->list_view_icons);
+ GtkTreeModel *model_icons = gtk_tree_view_get_model(list_view_icons);
gchar *syl_act = toolbar_ret_descr_from_val(A_SYL_ACTIONS);
- gint row_icons = 0;
- gint row_set = 0;
- GdkPixmap *xpm;
- GdkBitmap *xpmmask;
- gchar *item[4] = {NULL, NULL, NULL, NULL};
-
- if (clist_icons->rows == 0) return;
-
- if (clist_icons->selection) {
- if (clist_icons->selection->data)
- row_icons = GPOINTER_TO_INT(clist_icons->selection->data);
- } else
- return;
+ GtkListStore *store_set;
+ GtkTreeIter iter;
+ gchar *fname;
+
+ /* move selection in icon list view to set list view */
- gtk_clist_get_text(clist_icons, row_icons, 1, &item[1]);
- item[3] = g_strdup(gtk_entry_get_text(GTK_ENTRY(toolbar.combo_entry)));
+ if (!gtk_tree_model_iter_n_children(model_icons, NULL))
+ return;
- /* SEPARATOR or other ? */
- if (g_strcasecmp(item[1], SEPARATOR) == 0) {
- item[0] = g_strdup(SEPARATOR_PIXMAP);
- item[2] = g_strdup("");
- item[3] = g_strdup("");
-
- row_set = gtk_clist_append(GTK_CLIST(toolbar.clist_set), item);
+ if (!gtk_tree_selection_get_selected
+ (gtk_tree_view_get_selection(list_view_icons),
+ NULL, &iter))
+ return;
+
+ gtk_tree_model_get(model_icons, &iter,
+ SET_FILENAME, &fname,
+ -1);
+
+ store_set = GTK_LIST_STORE(gtk_tree_view_get_model(list_view_set));
- g_free(item[0]);
+ /* SEPARATOR or other ? */
+ if (g_utf8_collate(fname, toolbar_ret_descr_from_val(A_SEPARATOR)) == 0) {
+ gtk_list_store_append(store_set, &iter);
+ gtk_list_store_set(store_set, &iter,
+ SET_ICON, NULL,
+ SET_FILENAME, NULL,
+ SET_TEXT, NULL,
+ SET_EVENT, toolbar_ret_descr_from_val(A_SEPARATOR),
+ SET_ICON_TEXT, (const gchar *) SEPARATOR_PIXMAP,
+ SET_ICON_IS_TEXT, TRUE,
+ -1);
} else {
+ GdkPixbuf *pixbuf;
+ gchar *event, *text;
+
+ event = g_strdup(gtk_entry_get_text
+ (GTK_ENTRY(prefs_toolbar->combo_entry)));
- if (is_duplicate(item[3])) {
+ if (is_duplicate(prefs_toolbar, event)) {
alertpanel_error(ERROR_MSG);
- g_free(item[3]);
+ g_free(event);
+ g_free(fname);
return;
}
- stock_pixmap_gdk(toolbar.clist_set, stock_pixmap_get_icon(item[1]),
- &xpm, &xpmmask);
-
- if (g_strcasecmp(item[3], syl_act) == 0) {
-
- gchar *entry = gtk_entry_get_text(GTK_ENTRY(toolbar.combo_syl_entry));
- get_action_name(entry, &item[2]);
- }
- else {
- item[2] = g_strdup(gtk_entry_get_text(GTK_ENTRY(toolbar.entry_icon_text)));
- }
-
- row_set = gtk_clist_append(GTK_CLIST(toolbar.clist_set), item);
- gtk_clist_set_pixmap(clist_set, row_set, 0, xpm, xpmmask);
+ stock_pixbuf_gdk(prefs_toolbar->window,
+ stock_pixmap_get_icon(fname),
+ &pixbuf);
+
+ if (g_utf8_collate(event, syl_act) == 0) {
+ const gchar *entry = gtk_entry_get_text(GTK_ENTRY(prefs_toolbar->combo_syl_entry));
+ get_action_name(entry, &text);
+ } else
+ text = gtk_editable_get_chars
+ (GTK_EDITABLE(prefs_toolbar->entry_icon_text), 0, -1);
+
+ gtk_list_store_append(store_set, &iter);
+ gtk_list_store_set(store_set, &iter,
+ SET_ICON, pixbuf,
+ SET_FILENAME, fname,
+ SET_TEXT, text,
+ SET_EVENT, event,
+ SET_ICON_TEXT, NULL,
+ SET_ICON_IS_TEXT, FALSE,
+ -1);
+ g_free(text);
+ g_free(event);
}
- gtk_clist_moveto(clist_set, row_set, 0, row_set/clist_set->rows, 0);
- gtk_clist_select_row(clist_set, row_set, 0);
-
- g_free(item[2]);
- g_free(item[3]);
+ g_free(fname);
+
+ gtk_tree_selection_select_iter(gtk_tree_view_get_selection
+ (list_view_set),
+ &iter);
}
-static void prefs_toolbar_substitute(GtkButton *button, gpointer data)
+static void prefs_toolbar_substitute(GtkButton *button, ToolbarPage *prefs_toolbar)
{
- GtkCList *clist_set = GTK_CLIST(toolbar.clist_set);
- GtkCList *clist_icons = GTK_CLIST(toolbar.clist_icons);
+ GtkTreeView *list_view_set = GTK_TREE_VIEW(prefs_toolbar->list_view_set);
+ GtkTreeView *list_view_icons = GTK_TREE_VIEW(prefs_toolbar->list_view_icons);
+ GtkTreeModel *model_icons = gtk_tree_view_get_model(list_view_icons);
+ GtkListStore *store_set = GTK_LIST_STORE(gtk_tree_view_get_model(list_view_set));
gchar *syl_act = toolbar_ret_descr_from_val(A_SYL_ACTIONS);
- gint row_icons = 0;
- gint row_set = 0;
- GdkPixmap *xpm;
- GdkBitmap *xpmmask;
- gchar *item[4] = {NULL, NULL, NULL, NULL};
- gchar *ac_set;
-
- /* no rows or nothing selected */
- if ((clist_set->rows == 0) || (clist_set->selection == 0)) return;
-
- if (clist_icons->selection) {
- if (clist_icons->selection->data)
- row_icons = GPOINTER_TO_INT(clist_icons->selection->data);
- } else
+ GtkTreeSelection *sel_icons;
+ GtkTreeSelection *sel_set;
+ GtkTreeIter iter_icons;
+ GtkTreeIter iter_set;
+ gchar *icon_fname;
+
+ /* replace selection in set list with the one in icon list */
+
+ if (!gtk_tree_model_iter_n_children(GTK_TREE_MODEL(store_set), NULL))
return;
-
- if (clist_set->selection) {
- if (clist_set->selection->data)
- row_set = GPOINTER_TO_INT(clist_set->selection->data);
- } else
+
+ sel_icons = gtk_tree_view_get_selection(list_view_icons);
+ if (!gtk_tree_selection_get_selected(sel_icons, NULL, &iter_icons))
+ return;
+
+ sel_set = gtk_tree_view_get_selection(list_view_set);
+ if (!gtk_tree_selection_get_selected(sel_set, NULL, &iter_set))
return;
-
- gtk_clist_get_text(clist_icons, row_icons, 1, &item[1]);
- gtk_clist_get_text(clist_set, row_set, 3, &ac_set);
- item[3] = g_strdup(gtk_entry_get_text(GTK_ENTRY(toolbar.combo_entry)));
- if (g_strcasecmp(item[1], SEPARATOR) == 0) {
- item[0] = g_strdup(SEPARATOR_PIXMAP);
- item[2] = g_strdup("");
- item[3] = g_strdup("");
+ gtk_tree_model_get(model_icons, &iter_icons,
+ SET_FILENAME, &icon_fname,
+ -1);
+
+ if (g_utf8_collate(icon_fname, toolbar_ret_descr_from_val(A_SEPARATOR)) == 0) {
+ gtk_list_store_set(store_set, &iter_set,
+ SET_ICON, NULL,
+ SET_TEXT, NULL,
+ SET_EVENT, toolbar_ret_descr_from_val(A_SEPARATOR),
+ SET_FILENAME, icon_fname,
+ SET_ICON_TEXT, (const gchar *) SEPARATOR_PIXMAP,
+ SET_ICON_IS_TEXT, TRUE,
+ -1);
+ } else {
+ GdkPixbuf *pixbuf;
+ gchar *icon_event, *set_event, *text;
- gtk_clist_remove(clist_set, row_set);
- row_set = gtk_clist_insert(clist_set, row_set, item);
+ icon_event = gtk_editable_get_chars
+ (GTK_EDITABLE(prefs_toolbar->combo_entry),
+ 0, -1);
- g_free(item[0]);
- } else {
+ gtk_tree_model_get(GTK_TREE_MODEL(store_set), &iter_set,
+ SET_EVENT, &set_event,
+ -1);
- if ((is_duplicate(item[3])) && (g_strcasecmp(item[3], ac_set) != 0)){
+ if (is_duplicate(prefs_toolbar, icon_event)
+ && g_utf8_collate(icon_event, set_event) != 0){
alertpanel_error(ERROR_MSG);
- g_free(item[3]);
+ g_free(set_event);
+ g_free(icon_event);
+ g_free(icon_fname);
return;
}
- stock_pixmap_gdk(toolbar.clist_set, stock_pixmap_get_icon(item[1]),
- &xpm, &xpmmask);
-
- if (g_strcasecmp(item[3], syl_act) == 0) {
+ stock_pixbuf_gdk(prefs_toolbar->window,
+ stock_pixmap_get_icon(icon_fname),
+ &pixbuf);
- gchar *entry = gtk_entry_get_text(GTK_ENTRY(toolbar.combo_syl_entry));
- get_action_name(entry, &item[2]);
+ if (g_utf8_collate(icon_event, syl_act) == 0) {
+ const gchar *entry = gtk_entry_get_text(GTK_ENTRY(prefs_toolbar->combo_syl_entry));
+ get_action_name(entry, &text);
} else {
- item[2] = g_strdup(gtk_entry_get_text(GTK_ENTRY(toolbar.entry_icon_text)));
+ text = gtk_editable_get_chars(GTK_EDITABLE(prefs_toolbar->entry_icon_text),
+ 0, -1);
}
- gtk_clist_remove(clist_set, row_set);
- row_set = gtk_clist_insert(clist_set, row_set, item);
- gtk_clist_set_pixmap(clist_set, row_set, 0, xpm, xpmmask);
+ /* change the row */
+ gtk_list_store_set(store_set, &iter_set,
+ SET_ICON, pixbuf,
+ SET_FILENAME, icon_fname,
+ SET_TEXT, text,
+ SET_EVENT, icon_event,
+ SET_ICON_TEXT, NULL,
+ SET_ICON_IS_TEXT, FALSE,
+ -1);
+
+ g_free(icon_event);
+ g_free(set_event);
+ g_free(text);
}
- gtk_clist_moveto(clist_set, row_set, 0, row_set/clist_set->rows, 0);
- gtk_clist_select_row(clist_set, row_set, 0);
-
- g_free(item[2]);
- g_free(item[3]);
+ g_free(icon_fname);
}
-static void prefs_toolbar_delete(GtkButton *button, gpointer data)
+static void prefs_toolbar_delete(GtkButton *button, ToolbarPage *prefs_toolbar)
{
- GtkCList *clist_set = GTK_CLIST(toolbar.clist_set);
- gint row_set = 0;
-
- if (clist_set->rows == 0) return;
- if (clist_set->selection) {
- if (clist_set->selection->data)
- row_set = GPOINTER_TO_INT(clist_set->selection->data);
- } else
+ GtkTreeView *list_view_set = GTK_TREE_VIEW(prefs_toolbar->list_view_set);
+ GtkListStore *store_set = GTK_LIST_STORE(gtk_tree_view_get_model
+ (list_view_set));
+ GtkTreeIter iter_set;
+
+ if (!gtk_tree_model_iter_n_children(GTK_TREE_MODEL(store_set), NULL))
return;
- if (clist_set->row_list != NULL) {
-
- row_set = GPOINTER_TO_INT(clist_set->selection->data);
- gtk_clist_remove(clist_set, row_set);
- gtk_clist_columns_autosize(clist_set);
-
- if (clist_set->rows > 0)
- gtk_clist_select_row(clist_set,(row_set == 0) ? 0:row_set - 1, 0);
- }
-}
-
-static void prefs_toolbar_up(GtkButton *button, gpointer data)
-{
- GtkCList *clist = GTK_CLIST(toolbar.clist_set);
- gint row = 0;
-
- if (!clist->selection) return;
- if (clist->selection->data)
- row = GPOINTER_TO_INT(clist->selection->data);
-
- if (row >= 0) {
- gtk_clist_row_move(clist, row, row - 1);
- if(gtk_clist_row_is_visible(clist, row - 1) != GTK_VISIBILITY_FULL) {
- gtk_clist_moveto(clist, row - 1, 0, 0, 0);
- }
- }
-}
-
-static void prefs_toolbar_down(GtkButton *button, gpointer data)
-{
- GtkCList *clist = GTK_CLIST(toolbar.clist_set);
- gint row = 0;
-
- if (!clist->selection) return;
- if (clist->selection->data)
- row = GPOINTER_TO_INT(clist->selection->data);
+ if (!gtk_tree_selection_get_selected(gtk_tree_view_get_selection
+ (list_view_set),
+ NULL,
+ &iter_set))
+ return;
+
+ gtk_list_store_remove(store_set, &iter_set);
- if (row >= 0 && row < clist->rows - 1) {
- gtk_clist_row_move(clist, row, row + 1);
- if(gtk_clist_row_is_visible(clist, row + 1) != GTK_VISIBILITY_FULL) {
- gtk_clist_moveto(clist, row + 1, 0, 1, 0);
- }
- }
+ /* XXX: may need to select a list item */
}
-static void prefs_toolbar_select_row_set(GtkCList *clist, gint row, gint column,
- GdkEvent *event, gpointer user_data)
+static void prefs_toolbar_up(GtkButton *button, ToolbarPage *prefs_toolbar)
{
- GtkCList *clist_ico = GTK_CLIST(toolbar.clist_icons);
- gchar *syl_act = toolbar_ret_descr_from_val(A_SYL_ACTIONS);
- gint row_set = 0;
- gint row_ico = 0;
- gint item_num = 0;
- gchar *file, *icon_text, *descr, *entry;
- GList *cur;
-
- if (clist->selection->data)
- row_set = GPOINTER_TO_INT(clist->selection->data);
-
- gtk_clist_get_text(clist, row_set, 1, &file);
- gtk_clist_get_text(clist, row_set, 2, &icon_text);
- gtk_clist_get_text(clist, row_set, 3, &descr);
+ GtkTreePath *prev, *sel;
+ GtkTreeIter isel;
+ GtkListStore *store = NULL;
+ GtkTreeIter iprev;
+
+ if (!gtk_tree_selection_get_selected
+ (gtk_tree_view_get_selection
+ (GTK_TREE_VIEW(prefs_toolbar->list_view_set)),
+ (GtkTreeModel **)(GtkListStore *) store,
+ &isel))
+ return;
- if (g_strcasecmp(descr, syl_act) != 0)
- gtk_entry_set_text(GTK_ENTRY(toolbar.entry_icon_text), icon_text);
+ sel = gtk_tree_model_get_path(GTK_TREE_MODEL(store), &isel);
+ if (!sel)
+ return;
- /* scan combo list for selected description an set combo item accordingly */
- for (cur = toolbar.combo_action_list; cur != NULL; cur = cur->next) {
- gchar *item_str = (gchar*)cur->data;
- if (g_strcasecmp(item_str, descr) == 0) {
- gtk_list_select_item(GTK_LIST(toolbar.combo_list), item_num);
- break;
- }
- else
- item_num++;
+ /* no move if we're at row 0... */
+ prev = gtk_tree_path_copy(sel);
+ if (!gtk_tree_path_prev(prev)) {
+ gtk_tree_path_free(prev);
+ gtk_tree_path_free(sel);
+ return;
}
- do {
- gtk_clist_get_text(clist_ico, row_ico, 1, &entry);
- row_ico++;
- } while(g_strcasecmp(entry, file) != 0);
-
- gtk_clist_select_row(clist_ico, row_ico - 1, 0);
- gtk_clist_moveto(clist_ico, row_ico - 1, 0, row_ico/clist_ico->rows, 0);
+ gtk_tree_model_get_iter(GTK_TREE_MODEL(store),
+ &iprev, prev);
+ gtk_tree_path_free(sel);
+ gtk_tree_path_free(prev);
+
+ gtk_list_store_swap(store, &iprev, &isel);
}
-static void prefs_toolbar_select_row_icons(GtkCList *clist, gint row, gint column,
- GdkEvent *event, gpointer user_data)
+static void prefs_toolbar_down(GtkButton *button, ToolbarPage *prefs_toolbar)
{
- GtkCList *clist_icons = GTK_CLIST(toolbar.clist_icons);
- gchar *text;
+ GtkListStore *store = NULL;
+ GtkTreeIter next, sel;
- gtk_clist_get_text(clist_icons, row, 1, &text);
+ if (!gtk_tree_selection_get_selected
+ (gtk_tree_view_get_selection
+ (GTK_TREE_VIEW(prefs_toolbar->list_view_set)),
+ (GtkTreeModel **)(GtkListStore *) store,
+ &sel))
+ return;
- if (!text) return;
+ next = sel;
+ if (!gtk_tree_model_iter_next(GTK_TREE_MODEL(store), &next))
+ return;
- if (g_strcasecmp(SEPARATOR, text) == 0) {
- gtk_widget_set_sensitive(toolbar.combo_action, FALSE);
- gtk_widget_set_sensitive(toolbar.entry_icon_text, FALSE);
- gtk_widget_set_sensitive(toolbar.combo_syl_action, FALSE);
- } else {
- gtk_widget_set_sensitive(toolbar.combo_action, TRUE);
- gtk_widget_set_sensitive(toolbar.entry_icon_text, TRUE);
- gtk_widget_set_sensitive(toolbar.combo_syl_action, TRUE);
- }
+ gtk_list_store_swap(store, &next, &sel);
}
static void prefs_toolbar_selection_changed(GtkList *list,
- gpointer user_data)
+ ToolbarPage *prefs_toolbar)
{
-
- gchar *cur_entry = g_strdup(gtk_entry_get_text(GTK_ENTRY(toolbar.combo_entry)));
+ gchar *cur_entry = g_strdup(gtk_entry_get_text(GTK_ENTRY(prefs_toolbar->combo_entry)));
gchar *actions_entry = toolbar_ret_descr_from_val(A_SYL_ACTIONS);
- gtk_widget_set_sensitive(toolbar.combo_syl_action, TRUE);
+ gtk_widget_set_sensitive(prefs_toolbar->combo_syl_action, TRUE);
- if (g_strcasecmp(cur_entry, actions_entry) == 0) {
- gtk_widget_hide(toolbar.entry_icon_text);
- gtk_widget_show(toolbar.combo_syl_action);
- gtk_label_set_text(GTK_LABEL(toolbar.label_icon_text), _("Sylpheed Action"));
+ if (g_utf8_collate(cur_entry, actions_entry) == 0) {
+ gtk_widget_hide(prefs_toolbar->entry_icon_text);
+ gtk_widget_show(prefs_toolbar->combo_syl_action);
+ gtk_label_set_text(GTK_LABEL(prefs_toolbar->label_icon_text), _("Sylpheed Action"));
if (prefs_common.actions_list == NULL) {
- gtk_widget_set_sensitive(toolbar.combo_syl_action, FALSE);
+ gtk_widget_set_sensitive(prefs_toolbar->combo_syl_action, FALSE);
}
} else {
- gtk_widget_hide(toolbar.combo_syl_action);
- gtk_widget_show(toolbar.entry_icon_text);
- gtk_label_set_text(GTK_LABEL(toolbar.label_icon_text), _("Toolbar text"));
+ gtk_widget_hide(prefs_toolbar->combo_syl_action);
+ gtk_widget_show(prefs_toolbar->entry_icon_text);
+ gtk_label_set_text(GTK_LABEL(prefs_toolbar->label_icon_text), _("Toolbar text"));
}
- gtk_misc_set_alignment(GTK_MISC(toolbar.label_icon_text), 1, 0.5);
- gtk_widget_show(toolbar.label_icon_text);
+ gtk_misc_set_alignment(GTK_MISC(prefs_toolbar->label_icon_text), 1, 0.5);
+ gtk_widget_show(prefs_toolbar->label_icon_text);
g_free(cur_entry);
}
-static gint prefs_toolbar_key_pressed(GtkWidget *widget,
- GdkEventKey *event,
- gpointer data)
-{
- if (event && event->keyval == GDK_Escape) {
- prefs_toolbar_close();
- return TRUE;
- }
- return FALSE;
-}
-
-static void prefs_toolbar_create(void)
+static void prefs_toolbar_create(ToolbarPage *prefs_toolbar)
{
- GtkWidget *window;
GtkWidget *main_vbox;
GtkWidget *top_hbox;
GtkWidget *compose_frame;
GtkWidget *reg_btn;
GtkWidget *subst_btn;
GtkWidget *del_btn;
+ GtkWidget *default_btn;
GtkWidget *vbox_frame;
GtkWidget *table;
- GtkWidget *scrolledwindow_clist_icon;
- GtkWidget *clist_icons;
+ GtkWidget *scrolledwindow_list_view_icons;
+ GtkWidget *list_view_icons;
GtkWidget *label_icon_text;
GtkWidget *entry_icon_text;
GtkWidget *label_action_sel;
GtkWidget *combo_syl_list;
GtkWidget *frame_toolbar_items;
GtkWidget *hbox_bottom;
- GtkWidget *scrolledwindow_clist_set;
- GtkWidget *clist_set;
+ GtkWidget *scrolledwindow_list_view_set;
+ GtkWidget *list_view_set;
GtkWidget *btn_vbox;
GtkWidget *up_btn;
GtkWidget *down_btn;
-
- GtkWidget *confirm_area;
- GtkWidget *ok_btn;
- GtkWidget *cancel_btn;
- GtkWidget *default_btn;
-
- gchar *titles[N_DISPLAYED_ITEMS_COLS];
debug_print("Creating custom toolbar window...\n");
- window = gtk_window_new(GTK_WINDOW_DIALOG);
- gtk_widget_set_usize(window, 450, -1);
- gtk_container_set_border_width(GTK_CONTAINER(window), 8);
- gtk_window_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER);
-
- gtk_window_set_modal(GTK_WINDOW(window), TRUE);
- gtk_window_set_policy(GTK_WINDOW(window), FALSE, TRUE, TRUE);
- gtk_signal_connect(GTK_OBJECT(window), "delete_event",
- GTK_SIGNAL_FUNC(prefs_toolbar_cancel),
- NULL);
- gtk_signal_connect(GTK_OBJECT(window), "key_press_event",
- GTK_SIGNAL_FUNC(prefs_toolbar_key_pressed),
- NULL);
- MANAGE_WINDOW_SIGNALS_CONNECT(window);
- gtk_widget_realize(window);
-
main_vbox = gtk_vbox_new(FALSE, 0);
gtk_widget_show(main_vbox);
- gtk_container_add(GTK_CONTAINER(window), main_vbox);
top_hbox = gtk_hbox_new(FALSE, 0);
gtk_box_pack_start(GTK_BOX(main_vbox), top_hbox, TRUE, TRUE, 0);
- compose_frame = gtk_frame_new(_("Available toolbar items"));
+ compose_frame = gtk_frame_new(_("Available toolbar icons"));
gtk_box_pack_start(GTK_BOX(top_hbox), compose_frame, TRUE, TRUE, 0);
gtk_container_set_border_width(GTK_CONTAINER(compose_frame), 5);
gtk_container_add(GTK_CONTAINER(compose_frame), vbox_frame);
/* available icons */
- scrolledwindow_clist_icon = gtk_scrolled_window_new(NULL, NULL);
- gtk_container_set_border_width(GTK_CONTAINER(scrolledwindow_clist_icon), 5);
- gtk_container_add(GTK_CONTAINER(vbox_frame), scrolledwindow_clist_icon);
- gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow_clist_icon),
- GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
-
- clist_icons = gtk_clist_new(2);
- gtk_container_add(GTK_CONTAINER(scrolledwindow_clist_icon), clist_icons);
- gtk_container_set_border_width(GTK_CONTAINER(clist_icons), 1);
- gtk_clist_set_column_width(GTK_CLIST(clist_icons), 0, 35);
- gtk_clist_set_column_width(GTK_CLIST(clist_icons), 1, 200);
- gtk_clist_column_titles_hide(GTK_CLIST(clist_icons));
- gtk_widget_set_usize(clist_icons, 225, 108);
+ scrolledwindow_list_view_icons = gtk_scrolled_window_new(NULL, NULL);
+ gtk_container_set_border_width(GTK_CONTAINER(scrolledwindow_list_view_icons), 5);
+ gtk_container_add(GTK_CONTAINER(vbox_frame), scrolledwindow_list_view_icons);
+ gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow_list_view_icons),
+ GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
+
+ list_view_icons = create_icon_list_view(prefs_toolbar);
+ gtk_widget_show(list_view_icons);
+ gtk_container_add(GTK_CONTAINER(scrolledwindow_list_view_icons), list_view_icons);
+ gtk_container_set_border_width(GTK_CONTAINER(list_view_icons), 1);
+ gtk_widget_set_size_request(list_view_icons, 225, 108);
table = gtk_table_new (2, 3, FALSE);
gtk_container_add (GTK_CONTAINER (vbox_frame), table);
arrow = gtk_arrow_new(GTK_ARROW_DOWN, GTK_SHADOW_OUT);
gtk_box_pack_start(GTK_BOX(reg_hbox), arrow, FALSE, FALSE, 0);
- gtk_widget_set_usize(arrow, -1, 16);
+ gtk_widget_set_size_request(arrow, -1, 16);
btn_hbox = gtk_hbox_new(TRUE, 4);
gtk_box_pack_start(GTK_BOX(reg_hbox), btn_hbox, FALSE, FALSE, 0);
- reg_btn = gtk_button_new_with_label(_("Register"));
+ reg_btn = gtk_button_new_from_stock(GTK_STOCK_ADD);
gtk_box_pack_start(GTK_BOX(btn_hbox), reg_btn, FALSE, TRUE, 0);
- gtk_signal_connect(GTK_OBJECT(reg_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_register),
- NULL);
+ g_signal_connect(G_OBJECT(reg_btn), "clicked",
+ G_CALLBACK(prefs_toolbar_register),
+ prefs_toolbar);
- subst_btn = gtk_button_new_with_label(_(" Substitute "));
+ subst_btn = gtk_button_new_with_label(_(" Replace "));
gtk_box_pack_start(GTK_BOX(btn_hbox), subst_btn, FALSE, TRUE, 0);
- gtk_signal_connect(GTK_OBJECT(subst_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_substitute),
- NULL);
+ g_signal_connect(G_OBJECT(subst_btn), "clicked",
+ G_CALLBACK(prefs_toolbar_substitute),
+ prefs_toolbar);
- del_btn = gtk_button_new_with_label(_("Delete"));
+ del_btn = gtk_button_new_from_stock(GTK_STOCK_DELETE);
gtk_box_pack_start(GTK_BOX(btn_hbox), del_btn, FALSE, TRUE, 0);
- gtk_signal_connect(GTK_OBJECT(del_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_delete),
- NULL);
+ g_signal_connect(G_OBJECT(del_btn), "clicked",
+ G_CALLBACK(prefs_toolbar_delete),
+ prefs_toolbar);
+
+ default_btn = gtk_button_new_with_label(_(" Default "));
+ gtk_box_pack_end(GTK_BOX(reg_hbox), default_btn, FALSE, TRUE, 0);
+ g_signal_connect(G_OBJECT(default_btn), "clicked",
+ G_CALLBACK(prefs_toolbar_default),
+ prefs_toolbar);
/* currently active toolbar items */
frame_toolbar_items = gtk_frame_new(_("Displayed toolbar items"));
hbox_bottom = gtk_hbox_new(FALSE, 0);
gtk_container_add(GTK_CONTAINER(frame_toolbar_items), hbox_bottom);
- scrolledwindow_clist_set = gtk_scrolled_window_new(NULL, NULL);
- gtk_box_pack_start(GTK_BOX(hbox_bottom), scrolledwindow_clist_set, TRUE, TRUE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(scrolledwindow_clist_set), 1);
- gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow_clist_icon),
+ scrolledwindow_list_view_set = gtk_scrolled_window_new(NULL, NULL);
+ gtk_box_pack_start(GTK_BOX(hbox_bottom), scrolledwindow_list_view_set, TRUE, TRUE, 0);
+ gtk_container_set_border_width(GTK_CONTAINER(scrolledwindow_list_view_set), 1);
+ gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow_list_view_icons),
GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
- titles[COL_ICON] = _("Icon");
- titles[COL_FILENAME] = _("File name");
- titles[COL_TEXT] = _("Icon text");
- titles[COL_EVENT] = _("Mapped event");
-
- clist_set = gtk_clist_new_with_titles(N_DISPLAYED_ITEMS_COLS, titles);
- gtk_widget_show(clist_set);
- gtk_container_add(GTK_CONTAINER(scrolledwindow_clist_set), clist_set);
- gtk_clist_set_column_width(GTK_CLIST(clist_set), COL_ICON , 80);
- gtk_clist_set_column_width(GTK_CLIST(clist_set), COL_FILENAME, 80);
- gtk_clist_set_column_width(GTK_CLIST(clist_set), COL_TEXT , 80);
- gtk_clist_set_column_width(GTK_CLIST(clist_set), COL_EVENT , 80);
- gtk_clist_column_titles_show(GTK_CLIST(clist_set));
- gtk_widget_set_usize(clist_set, 225, 120);
+ list_view_set = create_set_list_view(prefs_toolbar);
+ gtk_widget_show(list_view_set);
+ gtk_container_add(GTK_CONTAINER(scrolledwindow_list_view_set), list_view_set);
+ gtk_widget_set_size_request(list_view_set, 225, 120);
btn_vbox = gtk_vbox_new(FALSE, 8);
gtk_widget_show(btn_vbox);
gtk_box_pack_start(GTK_BOX(hbox_bottom), btn_vbox, FALSE, FALSE, 5);
- up_btn = gtk_button_new_with_label(_("Up"));
+ up_btn = gtk_button_new_from_stock(GTK_STOCK_GO_UP);
gtk_widget_show(up_btn);
gtk_box_pack_start(GTK_BOX(btn_vbox), up_btn, FALSE, FALSE, 2);
- down_btn = gtk_button_new_with_label(_("Down"));
+ down_btn = gtk_button_new_from_stock(GTK_STOCK_GO_DOWN);
gtk_widget_show(down_btn);
gtk_box_pack_start(GTK_BOX(btn_vbox), down_btn, FALSE, FALSE, 0);
- gtkut_button_set_create(&confirm_area, &ok_btn, _("OK"),
- &cancel_btn, _("Cancel"), &default_btn, _("Set default"));
- gtk_box_pack_end(GTK_BOX(main_vbox), confirm_area, FALSE, FALSE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(confirm_area), 5);
- gtk_widget_grab_default(ok_btn);
-
- gtk_signal_connect(GTK_OBJECT(ok_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_ok), NULL);
- gtk_signal_connect(GTK_OBJECT(cancel_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_cancel), NULL);
- gtk_signal_connect(GTK_OBJECT(default_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_default), NULL);
- gtk_signal_connect(GTK_OBJECT(clist_set), "select_row",
- GTK_SIGNAL_FUNC(prefs_toolbar_select_row_set),
- NULL);
- gtk_signal_connect(GTK_OBJECT(clist_icons), "select_row",
- GTK_SIGNAL_FUNC(prefs_toolbar_select_row_icons),
- NULL);
- gtk_signal_connect(GTK_OBJECT(combo_list), "selection-changed",
- GTK_SIGNAL_FUNC(prefs_toolbar_selection_changed),
- NULL);
- gtk_signal_connect(GTK_OBJECT(up_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_up), NULL);
- gtk_signal_connect(GTK_OBJECT(down_btn), "clicked",
- GTK_SIGNAL_FUNC(prefs_toolbar_down), NULL);
-
- toolbar.window = window;
- toolbar.clist_icons = clist_icons;
- toolbar.clist_set = clist_set;
- toolbar.combo_action = combo_action;
- toolbar.combo_entry = combo_entry;
- toolbar.combo_list = combo_list;
- toolbar.entry_icon_text = entry_icon_text;
- toolbar.combo_syl_action = combo_syl_action;
- toolbar.combo_syl_list = combo_syl_list;
- toolbar.combo_syl_entry = combo_syl_entry;
-
- toolbar.label_icon_text = label_icon_text;
- toolbar.label_action_sel = label_action_sel;
-
- gtk_widget_show_all(window);
+ g_signal_connect(G_OBJECT(combo_list), "selection-changed",
+ G_CALLBACK(prefs_toolbar_selection_changed),
+ prefs_toolbar);
+ g_signal_connect(G_OBJECT(up_btn), "clicked",
+ G_CALLBACK(prefs_toolbar_up), prefs_toolbar);
+ g_signal_connect(G_OBJECT(down_btn), "clicked",
+ G_CALLBACK(prefs_toolbar_down), prefs_toolbar);
+
+ gtk_widget_show_all(main_vbox);
+
+ prefs_toolbar->list_view_icons = list_view_icons;
+ prefs_toolbar->list_view_set = list_view_set;
+ prefs_toolbar->combo_action = combo_action;
+ prefs_toolbar->combo_entry = combo_entry;
+ prefs_toolbar->combo_list = combo_list;
+ prefs_toolbar->entry_icon_text = entry_icon_text;
+ prefs_toolbar->combo_syl_action = combo_syl_action;
+ prefs_toolbar->combo_syl_list = combo_syl_list;
+ prefs_toolbar->combo_syl_entry = combo_syl_entry;
+
+ prefs_toolbar->label_icon_text = label_icon_text;
+ prefs_toolbar->label_action_sel = label_action_sel;
+
+ prefs_toolbar->page.widget = main_vbox;
+}
+
+ToolbarPage *prefs_toolbar_mainwindow;
+ToolbarPage *prefs_toolbar_composewindow;
+ToolbarPage *prefs_toolbar_messageview;
+
+void prefs_toolbar_init(void)
+{
+ ToolbarPage *page;
+ static gchar *mainpath[3], *messagepath[3], *composepath[3];
+
+ mainpath[0] = _("Customize Toolbars");
+ mainpath[1] = _("Main Window");
+ mainpath[2] = NULL;
+
+ page = g_new0(ToolbarPage, 1);
+ page->page.path = mainpath;
+ page->page.create_widget = prefs_toolbar_create_widget;
+ page->page.destroy_widget = prefs_toolbar_destroy_widget;
+ page->page.save_page = prefs_toolbar_save;
+ page->source = TOOLBAR_MAIN;
+ page->page.weight = 50.0;
+ prefs_gtk_register_page((PrefsPage *) page);
+ prefs_toolbar_mainwindow = page;
+
+ messagepath[0] = _("Customize Toolbars");
+ messagepath[1] = _("Message Window");
+ messagepath[2] = NULL;
+
+ page = g_new0(ToolbarPage, 1);
+ page->page.path = messagepath;
+ page->page.create_widget = prefs_toolbar_create_widget;
+ page->page.destroy_widget = prefs_toolbar_destroy_widget;
+ page->page.save_page = prefs_toolbar_save;
+ page->source = TOOLBAR_MSGVIEW;
+ page->page.weight = 45.0;
+ prefs_gtk_register_page((PrefsPage *) page);
+ prefs_toolbar_messageview = page;
+
+ composepath[0] = _("Customize Toolbars");
+ composepath[1] = _("Compose Window");
+ composepath[2] = NULL;
+
+ page = g_new0(ToolbarPage, 1);
+ page->page.path = composepath;
+ page->page.create_widget = prefs_toolbar_create_widget;
+ page->page.destroy_widget = prefs_toolbar_destroy_widget;
+ page->page.save_page = prefs_toolbar_save;
+ page->source = TOOLBAR_COMPOSE;
+ page->page.weight = 40.0;
+ prefs_gtk_register_page((PrefsPage *) page);
+ prefs_toolbar_composewindow = page;
+}
+
+void prefs_toolbar_done(void)
+{
+ prefs_gtk_unregister_page((PrefsPage *) prefs_toolbar_mainwindow);
+ g_free(prefs_toolbar_mainwindow);
+ prefs_gtk_unregister_page((PrefsPage *) prefs_toolbar_composewindow);
+ g_free(prefs_toolbar_composewindow);
+ prefs_gtk_unregister_page((PrefsPage *) prefs_toolbar_messageview);
+ g_free(prefs_toolbar_messageview);
+}
+
+static void set_visible_if_not_text(GtkTreeViewColumn *col,
+ GtkCellRenderer *renderer,
+ GtkTreeModel *model,
+ GtkTreeIter *iter,
+ gpointer user_data)
+{
+ gboolean is_text;
+ GdkPixbuf *pixbuf;
+
+ gtk_tree_model_get(model, iter, SET_ICON_IS_TEXT, &is_text, -1);
+ if (is_text) {
+ g_object_set(renderer, "visible", FALSE, NULL);
+ } else {
+ pixbuf = NULL;
+ gtk_tree_model_get(model, iter,
+ SET_ICON, &pixbuf,
+ -1);
+ /* note getting a pixbuf from a tree model increases
+ * its refcount ... */
+ g_object_unref(pixbuf);
+
+ g_object_set(renderer, "visible", TRUE, NULL);
+ g_object_set(renderer, "pixbuf", pixbuf, NULL);
+ }
+}
+
+static GtkWidget *create_icon_list_view(ToolbarPage *prefs_toolbar)
+{
+ GtkTreeView *list_view;
+ GtkListStore *store;
+ GtkCellRenderer *renderer;
+ GtkTreeViewColumn *column;
+ GtkTreeSelection *selector;
+
+ /* XXX: for icon list we don't need SET_TEXT, and SET_EVENT */
+ store = gtk_list_store_new(N_SET_COLUMNS,
+ GDK_TYPE_PIXBUF,
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_BOOLEAN,
+ -1);
+ list_view = GTK_TREE_VIEW(gtk_tree_view_new_with_model(GTK_TREE_MODEL(store)));
+ g_object_unref(G_OBJECT(store));
+
+ column = gtk_tree_view_column_new();
+ renderer = gtk_cell_renderer_pixbuf_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+
+ /* tell pixbuf renderer it is only visible if
+ * the icon is not represented by text */
+ gtk_tree_view_column_set_cell_data_func(column, renderer,
+ set_visible_if_not_text,
+ NULL, NULL);
+
+ renderer = gtk_cell_renderer_text_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+
+ /* tell the text renderer it is only visible if the icon
+ * is represented by an image */
+ gtk_tree_view_column_set_attributes(column, renderer,
+ "visible", SET_ICON_IS_TEXT,
+ "text", SET_ICON_TEXT,
+ NULL);
+
+ gtk_tree_view_append_column(list_view, column);
+
+ column = gtk_tree_view_column_new();
+ renderer = gtk_cell_renderer_text_new();
+ gtk_tree_view_column_pack_start(column, renderer, TRUE);
+ gtk_tree_view_column_set_attributes(column, renderer,
+ "text", SET_FILENAME,
+ NULL);
+
+ gtk_tree_view_append_column(list_view, column);
+
+ /* various other tree view attributes */
+ gtk_tree_view_set_rules_hint(list_view, prefs_common.enable_rules_hint);
+ gtk_tree_view_set_headers_visible(list_view, FALSE);
+
+ selector = gtk_tree_view_get_selection(list_view);
+ gtk_tree_selection_set_mode(selector, GTK_SELECTION_BROWSE);
+ gtk_tree_selection_set_select_function
+ (selector, (GtkTreeSelectionFunc) icon_list_selected,
+ prefs_toolbar, NULL);
+
+ return GTK_WIDGET(list_view);
+}
+
+static GtkWidget *create_set_list_view(ToolbarPage *prefs_toolbar)
+{
+ GtkTreeView *list_view;
+ GtkListStore *store;
+ GtkCellRenderer *renderer;
+ GtkTreeViewColumn *column;
+ GtkTreeSelection *selector;
+
+ store = gtk_list_store_new(N_SET_COLUMNS,
+ GDK_TYPE_PIXBUF,
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_STRING,
+ G_TYPE_BOOLEAN,
+ -1);
+ list_view = GTK_TREE_VIEW(gtk_tree_view_new_with_model(GTK_TREE_MODEL(store)));
+ g_object_unref(G_OBJECT(store));
+
+ column = gtk_tree_view_column_new();
+ gtk_tree_view_column_set_title(column, _("Icon"));
+ renderer = gtk_cell_renderer_pixbuf_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+
+ /* tell pixbuf renderer it is only visible if
+ * the icon is not represented by text */
+ gtk_tree_view_column_set_cell_data_func(column, renderer,
+ set_visible_if_not_text,
+ NULL, NULL);
+
+ renderer = gtk_cell_renderer_text_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+
+ /* tell the text renderer it is only visible if the icon
+ * is represented by an image */
+ gtk_tree_view_column_set_attributes(column, renderer,
+ "visible", SET_ICON_IS_TEXT,
+ "text", SET_ICON_TEXT,
+ NULL);
+
+ gtk_tree_view_append_column(list_view, column);
+
+ column = gtk_tree_view_column_new();
+ gtk_tree_view_column_set_title(column, _("File name"));
+ renderer = gtk_cell_renderer_text_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+ gtk_tree_view_column_set_attributes(column, renderer,
+ "text", SET_FILENAME,
+ NULL);
+
+ gtk_tree_view_append_column(list_view, column);
+
+ column = gtk_tree_view_column_new();
+ gtk_tree_view_column_set_title(column, _("Icon text"));
+ renderer = gtk_cell_renderer_text_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+ gtk_tree_view_column_set_attributes(column, renderer,
+ "text", SET_TEXT,
+ NULL);
+ gtk_tree_view_append_column(list_view, column);
+
+ column = gtk_tree_view_column_new();
+ gtk_tree_view_column_set_title(column, _("Mapped event"));
+ renderer = gtk_cell_renderer_text_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+ gtk_tree_view_column_set_attributes(column, renderer,
+ "text", SET_EVENT,
+ NULL);
+ gtk_tree_view_append_column(list_view, column);
+
+ /* various other tree view attributes */
+ gtk_tree_view_set_rules_hint(list_view, prefs_common.enable_rules_hint);
+
+ selector = gtk_tree_view_get_selection(list_view);
+ gtk_tree_selection_set_mode(selector, GTK_SELECTION_BROWSE);
+ gtk_tree_selection_set_select_function
+ (selector, (GtkTreeSelectionFunc) set_list_selected,
+ prefs_toolbar, NULL);
+
+ return GTK_WIDGET(list_view);
+
+}
+
+static gboolean icon_list_selected(GtkTreeSelection *selector,
+ GtkTreeModel *model,
+ GtkTreePath *path,
+ gboolean currently_selected,
+ ToolbarPage *prefs_toolbar)
+{
+ GtkTreeIter iter;
+ gchar *text;
+
+ if (currently_selected ||!gtk_tree_model_get_iter(model, &iter, path))
+ return TRUE;
+
+ text = NULL;
+ gtk_tree_model_get(model, &iter,
+ SET_FILENAME, &text,
+ -1);
+ if (!text)
+ return TRUE;
+
+ if (g_utf8_collate(toolbar_ret_descr_from_val(A_SEPARATOR), text) == 0) {
+ gtk_widget_set_sensitive(prefs_toolbar->combo_action, FALSE);
+ gtk_widget_set_sensitive(prefs_toolbar->entry_icon_text, FALSE);
+ gtk_widget_set_sensitive(prefs_toolbar->combo_syl_action, FALSE);
+ } else {
+ gtk_widget_set_sensitive(prefs_toolbar->combo_action, TRUE);
+ gtk_widget_set_sensitive(prefs_toolbar->entry_icon_text, TRUE);
+ gtk_widget_set_sensitive(prefs_toolbar->combo_syl_action, TRUE);
+ }
+
+ g_free(text);
+
+ return TRUE;
+}
+
+static gboolean set_list_selected(GtkTreeSelection *selector,
+ GtkTreeModel *model,
+ GtkTreePath *path,
+ gboolean currently_selected,
+ ToolbarPage *prefs_toolbar)
+{
+ GtkTreeIter iter;
+ GtkTreeView *list_ico = GTK_TREE_VIEW(prefs_toolbar->list_view_icons);
+ gchar *syl_act = toolbar_ret_descr_from_val(A_SYL_ACTIONS);
+ gchar *file, *icon_text, *descr;
+ GList *cur;
+ gint item_num;
+ GtkTreeModel *model_ico;
+
+ if (currently_selected ||!gtk_tree_model_get_iter(model, &iter, path))
+ return TRUE;
+
+ gtk_tree_model_get(model, &iter,
+ SET_FILENAME, &file,
+ SET_TEXT, &icon_text,
+ SET_EVENT, &descr,
+ -1);
+
+ if (g_utf8_collate(descr, syl_act))
+ gtk_entry_set_text(GTK_ENTRY(prefs_toolbar->entry_icon_text),
+ icon_text);
+
+ /* scan combo list for selected description an set combo item accordingly */
+ for (cur = prefs_toolbar->combo_action_list, item_num = 0; cur != NULL;
+ cur = cur->next) {
+ gchar *item_str = (gchar*)cur->data;
+ if (g_utf8_collate(item_str, descr) == 0) {
+ gtk_list_select_item(GTK_LIST(prefs_toolbar->combo_list), item_num);
+ break;
+ }
+ else
+ item_num++;
+ }
+
+ model_ico = gtk_tree_view_get_model(list_ico);
+ if (gtk_tree_model_get_iter_first(model_ico, &iter)) {
+ gchar *entry;
+ gboolean found = FALSE;
+
+ /* find in icon list, scroll to item */
+ do {
+ entry = NULL;
+ gtk_tree_model_get(model_ico, &iter,
+ SET_FILENAME, &entry,
+ -1);
+ found = entry && !g_utf8_collate(entry, file);
+ g_free(entry);
+ if (found)
+ break;
+ } while(gtk_tree_model_iter_next(model_ico, &iter));
+
+ if (found) {
+ GtkTreePath *path;
+
+ gtk_tree_selection_select_iter
+ (gtk_tree_view_get_selection(list_ico), &iter);
+ path = gtk_tree_model_get_path(model_ico, &iter);
+ gtk_tree_view_set_cursor(list_ico, path, NULL, FALSE);
+ gtk_tree_path_free(path);
+ }
+ }
+
+ g_free(file);
+ g_free(icon_text);
+ g_free(descr);
+
+ return TRUE;
}