# HG changeset patch
# User Sean Egan <seanegan@gmail.com>
# Date 1130141194 0
# Node ID b9b7a010b043c946e7f69f26abfc463c92d0d889
# Parent  f48e2acaa5d21ea03c7238fdcb70443296468cb9
[gaim-migrate @ 14087]
I need to sleep. This isn't finished. Hopefully someone will finish it before
I wake up.

Moved Preferences > Buddy List to Buddies menu.

committer: Tailor Script <tailor@pidgin.im>

diff -r f48e2acaa5d2 -r b9b7a010b043 src/gtkblist.c
--- a/src/gtkblist.c	Mon Oct 24 07:46:21 2005 +0000
+++ b/src/gtkblist.c	Mon Oct 24 08:06:34 2005 +0000
@@ -101,7 +101,7 @@
 
 static GtkWidget *protomenu = NULL;
 
-GSList *gaim_gtk_blist_sort_methods = NULL;
+static GList *gaim_gtk_blist_sort_methods = NULL;
 static struct gaim_gtk_blist_sort_method *current_sort_method = NULL;
 static GtkTreeIter sort_method_none(GaimBlistNode *node, GaimBuddyList *blist, GtkTreeIter groupiter, GtkTreeIter *cur);
 
@@ -1310,6 +1310,12 @@
 	return handled;
 }
 
+static void gaim_gtk_blist_buddy_details_cb(gpointer data, guint action, GtkWidget *item)
+{
+	gaim_prefs_set_bool("/gaim/gtk/blist/show_buddy_icons",
+			    gtk_check_menu_item_get_active(GTK_CHECK_MENU_ITEM(item)));
+}
+
 static void gaim_gtk_blist_show_empty_groups_cb(gpointer data, guint action, GtkWidget *item)
 {
 	gaim_prefs_set_bool("/gaim/gtk/blist/show_empty_groups",
@@ -2328,10 +2334,13 @@
 	{ "/Buddies/sep1", NULL, NULL, 0, "<Separator>" },
 	{ N_("/Buddies/Show _Offline Buddies"), NULL, gaim_gtk_blist_edit_mode_cb, 1, "<CheckItem>"},
 	{ N_("/Buddies/Show _Empty Groups"), NULL, gaim_gtk_blist_show_empty_groups_cb, 1, "<CheckItem>"},
+	{ N_("/Buddies/Show Buddy _Details"), NULL, gaim_gtk_blist_buddy_details_cb, 1, "<CheckItem>"},
+	{ N_("/Buddies/Sorting"), NULL, NULL, 0, "<Branch>" },
+	{ "/Buddies/sep2", NULL, NULL, 0, "<Separator>" },
 	{ N_("/Buddies/_Add Buddy..."), "<CTL>B", gaim_gtk_blist_add_buddy_cb, 0, "<StockItem>", GTK_STOCK_ADD },
 	{ N_("/Buddies/Add C_hat..."), NULL, gaim_gtk_blist_add_chat_cb, 0, "<StockItem>", GTK_STOCK_ADD },
 	{ N_("/Buddies/Add _Group..."), NULL, gaim_blist_request_add_group, 0, "<StockItem>", GTK_STOCK_ADD },
-	{ "/Buddies/sep2", NULL, NULL, 0, "<Separator>" },
+	{ "/Buddies/sep3", NULL, NULL, 0, "<Separator>" },
 	{ N_("/Buddies/_Quit"), "<CTL>Q", gaim_core_quit, 0, "<StockItem>", GTK_STOCK_QUIT },
 
 	/* Tools */
@@ -3316,12 +3325,15 @@
 			gaim_prefs_get_bool("/gaim/gtk/blist/show_empty_groups"));
 	gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(gtk_item_factory_get_item (gtkblist->ift, N_("/Tools/Mute Sounds"))),
 			gaim_prefs_get_bool("/gaim/gtk/sound/mute"));
+	gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(gtk_item_factory_get_item (gtkblist->ift, N_("/Buddies/Show Buddy Details"))),
+                	gaim_prefs_get_bool("/gaim/gtk/blist/show_buddy_icons"));
 	if(!strcmp(gaim_prefs_get_string("/gaim/gtk/sound/method"), "none"))
 		gtk_widget_set_sensitive(gtk_item_factory_get_widget(gtkblist->ift, N_("/Tools/Mute Sounds")), FALSE);
 
 	/* Update some dynamic things */
 	update_menu_bar(gtkblist);
 	gaim_gtk_blist_update_plugin_actions();
+	gaim_gtk_blist_update_sort_methods();
 
 	/* OK... let's show this bad boy. */
 	if (gaim_prefs_get_bool("/gaim/gtk/blist/list_visible")) {
@@ -4631,32 +4643,39 @@
  * Buddy List sorting functions                                      *
  *********************************************************************/
 
+GList *gaim_gtk_blist_get_sort_methods()
+{
+	return gaim_gtk_blist_sort_methods;
+}
+
 void gaim_gtk_blist_sort_method_reg(const char *id, const char *name, gaim_gtk_blist_sort_function func)
 {
 	struct gaim_gtk_blist_sort_method *method = g_new0(struct gaim_gtk_blist_sort_method, 1);
 	method->id = g_strdup(id);
 	method->name = g_strdup(name);
 	method->func = func;
-	gaim_gtk_blist_sort_methods = g_slist_append(gaim_gtk_blist_sort_methods, method);
+	gaim_gtk_blist_sort_methods = g_list_append(gaim_gtk_blist_sort_methods, method);
+	gaim_gtk_blist_update_sort_methods();
 }
 
 void gaim_gtk_blist_sort_method_unreg(const char *id){
-	GSList *l = gaim_gtk_blist_sort_methods;
+	GList *l = gaim_gtk_blist_sort_methods;
 
 	while(l) {
 		struct gaim_gtk_blist_sort_method *method = l->data;
 		if(!strcmp(method->id, id)) {
-			gaim_gtk_blist_sort_methods = g_slist_delete_link(gaim_gtk_blist_sort_methods, l);
+			gaim_gtk_blist_sort_methods = g_list_delete_link(gaim_gtk_blist_sort_methods, l);
 			g_free(method->id);
 			g_free(method->name);
 			g_free(method);
 			break;
 		}
 	}
+	gaim_gtk_blist_update_sort_methods();
 }
 
 void gaim_gtk_blist_sort_method_set(const char *id){
-	GSList *l = gaim_gtk_blist_sort_methods;
+	GList *l = gaim_gtk_blist_sort_methods;
 
 	if(!id)
 		id = "none";
@@ -5116,3 +5135,49 @@
 		
 	}
 }
+
+void sortmethod_act(GtkCheckMenuItem *checkmenuitem, char *id)
+{
+	if (gtk_check_menu_item_get_active(checkmenuitem))
+		gaim_gtk_blist_sort_method_set(id);
+}
+
+void
+gaim_gtk_blist_update_sort_methods(void)
+{
+	GtkWidget *menuitem = NULL, *activeitem = NULL;
+	GaimGtkBlistSortMethod *method = NULL;
+	GList *l;
+	GSList *sl = NULL;
+	GtkWidget *sortmenu;
+	char *m = gaim_prefs_get_string("/gaim/gtk/blist/sort_type");
+
+	if (gtkblist == NULL)
+		return;
+
+	sortmenu = gtk_item_factory_get_widget(gtkblist->ift, N_("/Buddies/Sorting"));
+
+	if (sortmenu == NULL)
+		return;
+
+	/* Clear the old menu */
+	for (l = gtk_container_get_children(GTK_CONTAINER(sortmenu)); l; l = l->next) {
+		menuitem = l->data;
+		gtk_widget_destroy(GTK_WIDGET(menuitem));
+	}
+	
+	for (l = gaim_gtk_blist_sort_methods; l; l = l->next) {
+		method = (GaimGtkBlistSortMethod *) l->data;
+		menuitem = gtk_radio_menu_item_new_with_label(sl, _(method->name));
+		if (!strcmp(m, method->id))
+			activeitem = menuitem;
+		sl = gtk_radio_menu_item_get_group(GTK_RADIO_MENU_ITEM(menuitem));
+		gtk_menu_shell_append(GTK_MENU_SHELL(sortmenu), menuitem);
+		g_signal_connect(G_OBJECT(menuitem), "toggled",
+				 G_CALLBACK(sortmethod_act), method->id);
+		gtk_widget_show(menuitem);		
+	}
+	if (activeitem)
+		gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(activeitem), TRUE);
+
+}
diff -r f48e2acaa5d2 -r b9b7a010b043 src/gtkblist.h
--- a/src/gtkblist.h	Mon Oct 24 07:46:21 2005 +0000
+++ b/src/gtkblist.h	Mon Oct 24 08:06:34 2005 +0000
@@ -195,7 +195,12 @@
 
 typedef GtkTreeIter (*gaim_gtk_blist_sort_function)(GaimBlistNode *new, GaimBuddyList *blist, GtkTreeIter group, GtkTreeIter *cur);
 
-extern GSList *gaim_gtk_blist_sort_methods;
+/**
+ * Gets the current list of sort methods.
+ *
+ * @return A GSlist of sort methods
+ */
+GList *gaim_gtk_blist_get_sort_methods();
 
 struct gaim_gtk_blist_sort_method {
 	char *id;
@@ -203,6 +208,8 @@
 	gaim_gtk_blist_sort_function func;
 };
 
+typedef struct gaim_gtk_blist_sort_method GaimGtkBlistSortMethod;
+
 /**
  * Registers a buddy list sorting method.
  *
@@ -243,6 +250,11 @@
 void gaim_gtk_blist_update_plugin_actions();
 
 /**
+ * Updates the Sorting menu on the GTK+ buddy list window.
+ */
+void gaim_gtk_blist_update_sort_methods();
+
+/**
  * Determines if showing the join chat dialog is a valid action.
  *
  * @return Returns TRUE if there are accounts online capable of
diff -r f48e2acaa5d2 -r b9b7a010b043 src/gtkprefs.c
--- a/src/gtkprefs.c	Mon Oct 24 07:46:21 2005 +0000
+++ b/src/gtkprefs.c	Mon Oct 24 08:06:34 2005 +0000
@@ -772,40 +772,6 @@
 	gaim_prefs_set_string("/gaim/gtk/conversations/bgcolor", "");
 }
 
-static GtkWidget *
-list_page()
-{
-	GtkWidget *ret;
-	GtkWidget *vbox;
-	GList *l= NULL;
-	GSList *sl;
-	ret = gtk_vbox_new(FALSE, GAIM_HIG_BOX_SPACE);
-	gtk_container_set_border_width (GTK_CONTAINER (ret), GAIM_HIG_BORDER);
-
-
-	vbox = gaim_gtk_make_frame (ret, _("Buddy List Sorting"));
-
-	for (sl = gaim_gtk_blist_sort_methods; sl != NULL; sl = sl->next) {
-		struct gaim_gtk_blist_sort_method *method = sl->data;
-
-		l = g_list_append(l, method->name);
-		l = g_list_append(l, method->id);
-	}
-
-	gaim_gtk_prefs_dropdown_from_list(vbox, _("_Sorting:"), GAIM_PREF_STRING,
-			"/gaim/gtk/blist/sort_type", l);
-
-	g_list_free(l);
-
-	vbox = gaim_gtk_make_frame (ret, _("Buddy Display"));
-	gaim_gtk_prefs_checkbox(_("Show more buddy details"),
-			"/gaim/gtk/blist/show_buddy_icons", vbox);
-
-	gtk_widget_show_all(ret);
-
-	return ret;
-}
-
 static void
 conversation_usetabs_cb(const char *name, GaimPrefType type, gpointer value,
                           gpointer data)
@@ -1752,7 +1718,6 @@
 
 static void prefs_notebook_init() {
 	GtkTreeIter p, c, c2;
-	prefs_notebook_add_page(_("Buddy List"), NULL, list_page(), &c, &p, notebook_page++);
 	prefs_notebook_add_page(_("Conversations"), NULL, conv_page(), &c, &p, notebook_page++);
 	prefs_notebook_add_page(_("Smiley Themes"), NULL, theme_page(), &c2, &c, notebook_page++);
 	prefs_notebook_add_page(_("Sounds"), NULL, sound_page(), &c, &p, notebook_page++);