# HG changeset patch
# User Sean Egan <seanegan@gmail.com>
# Date 1135119474 0
# Node ID 301e9f0841d70c63d7d2cdb96aa8a24993995189
# Parent  f75c0d35e0325628da72a4952bcdfbaca976a893
[gaim-migrate @ 14911]
Brutally murdered the per-account statusboxes; but didn't come up with any
replacement

committer: Tailor Script <tailor@pidgin.im>

diff -r f75c0d35e032 -r 301e9f0841d7 src/gtkblist.c
--- a/src/gtkblist.c	Tue Dec 20 21:58:15 2005 +0000
+++ b/src/gtkblist.c	Tue Dec 20 22:57:54 2005 +0000
@@ -3437,45 +3437,6 @@
 	return result;
 }
 
-static void account_enabled(GaimAccount *account, GaimGtkBuddyList *gtkblist)
-{
-	GtkWidget *box;
-	
-	if (!gtkblist)
-		return;
-	
-	box = gtk_gaim_status_box_new_with_account(account);
-	gtkblist->statusboxes = g_list_append(gtkblist->statusboxes, box);
-	gtk_box_pack_start(GTK_BOX(gtkblist->statusboxbox), box, FALSE, TRUE, 0);
-	gtk_widget_show(box);
-
-	update_menu_bar(gtkblist);
-}
-
-static void account_disabled(GaimAccount *account, GaimGtkBuddyList *gtkblist)
-{
-	GList *iter;
-
-	if (!gtkblist)
-		return;
-
-	for (iter = gtkblist->statusboxes; iter; iter = iter->next)
-	{
-		GtkWidget *box = iter->data;
-		GaimAccount *ac = NULL;
-
-		g_object_get(G_OBJECT(box), "account", &ac, NULL);
-		if (ac == account)
-		{
-			gtkblist->statusboxes = g_list_remove_link(gtkblist->statusboxes, iter);
-			gtk_widget_destroy(box);
-			break;
-		}
-	}
-
-	update_menu_bar(gtkblist);
-}
-
 static void account_modified(GaimAccount *account, GaimGtkBuddyList *gtkblist)
 {
 	if (!gtkblist)
@@ -3515,7 +3476,6 @@
 	GtkTreeViewColumn *column;
 	GtkWidget *menu;
 	GtkWidget *sw;
-	GtkWidget *vpane;
 	GtkAccelGroup *accel_group;
 	GtkTreeSelection *selection;
 	GtkTargetEntry dte[] = {{"GAIM_BLIST_NODE", GTK_TARGET_SAME_APP, DRAG_ROW},
@@ -3571,15 +3531,6 @@
 
 	accountmenu = gtk_item_factory_get_widget(gtkblist->ift, N_("/Accounts"));
 
-	/****************************** GtkVPaned ************************************/
-	vpane = gtk_vpaned_new();
-	gtk_widget_show(vpane);
-	gtk_box_pack_start(GTK_BOX(gtkblist->vbox), vpane, TRUE, TRUE, 0);
-	gtk_paned_set_position(GTK_PANED(vpane),
-	                       gaim_prefs_get_int("/gaim/gtk/blist/pane"));
-	g_signal_connect(G_OBJECT(vpane), "notify::position",
-	                 G_CALLBACK(pane_position_cb), NULL);
-
 	/****************************** GtkTreeView **********************************/
 	sw = gtk_scrolled_window_new(NULL,NULL);
 	gtk_widget_show(sw);
@@ -3664,39 +3615,15 @@
 	gtk_tree_view_set_search_column(GTK_TREE_VIEW(gtkblist->treeview), NAME_COLUMN);
 	gtk_tree_view_set_search_equal_func(GTK_TREE_VIEW(gtkblist->treeview), _search_func, NULL, NULL);
 
-	gtk_paned_pack1(GTK_PANED(vpane), sw, TRUE, FALSE);
+	gtk_box_pack_start(GTK_BOX(gtkblist->vbox), sw, TRUE, TRUE, 0);
 	gtk_container_add(GTK_CONTAINER(sw), gtkblist->treeview);
 	gaim_gtk_blist_update_columns();
 
-	/* TODO: functionize this */
-	{
-		GList *accounts, *l;
-		GtkWidget *sw2 = gtk_scrolled_window_new(NULL, NULL);
-
-		/* Set up some per account status boxes */
-		gtkblist->statusboxbox = gtk_vbox_new(FALSE, 0);
-		gtkblist->statusboxes = NULL;
-
-		for (l = accounts = gaim_accounts_get_all_active(); l; l = l->next) {
-			GtkWidget *statusbox = gtk_gaim_status_box_new_with_account(l->data);
-			gtkblist->statusboxes = g_list_append(gtkblist->statusboxes, statusbox);
-			gtk_box_pack_start(GTK_BOX(gtkblist->statusboxbox), statusbox, FALSE, TRUE, 0);
-			gtk_widget_show(statusbox);
-		}
-		g_list_free(accounts);
-
-		gtk_widget_show(gtkblist->statusboxbox);
-		gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(sw2), gtkblist->statusboxbox);
-		gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(sw2), GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
-		gtk_widget_show(sw2);
-		gtk_paned_pack2(GTK_PANED(vpane), sw2, FALSE, TRUE);
-
-		gtkblist->statusbox = gtk_gaim_status_box_new();
-
-		gtk_widget_show(gtkblist->statusbox);
-		gtk_box_pack_start(GTK_BOX(gtkblist->vbox), gtkblist->statusbox, FALSE, TRUE, 0);
-
-	}
+	gtkblist->statusbox = gtk_gaim_status_box_new();
+	
+	gtk_widget_show(gtkblist->statusbox);
+	gtk_box_pack_start(GTK_BOX(gtkblist->vbox), gtkblist->statusbox, FALSE, TRUE, 0);
+	
 
 	/* set the Show Offline Buddies option. must be done
 	 * after the treeview or faceprint gets mad. -Robot101
@@ -3752,11 +3679,11 @@
 
 	/* Setup some gaim signal handlers. */
 	gaim_signal_connect(gaim_accounts_get_handle(), "account-enabled",
-			gtkblist, GAIM_CALLBACK(account_enabled), gtkblist);
+			gtkblist, GAIM_CALLBACK(account_modified), gtkblist);
 	gaim_signal_connect(gaim_accounts_get_handle(), "account-disabled",
-			gtkblist, GAIM_CALLBACK(account_disabled), gtkblist);
+			gtkblist, GAIM_CALLBACK(account_modified), gtkblist);
 	gaim_signal_connect(gaim_accounts_get_handle(), "account-removed",
-			gtkblist, GAIM_CALLBACK(account_disabled), gtkblist);
+			gtkblist, GAIM_CALLBACK(account_modified), gtkblist);
 
 	gaim_signal_connect(gaim_gtk_account_get_handle(), "account-modified",
 			gtkblist, GAIM_CALLBACK(account_modified), gtkblist);
diff -r f75c0d35e032 -r 301e9f0841d7 src/gtkblist.h
--- a/src/gtkblist.h	Tue Dec 20 21:58:15 2005 +0000
+++ b/src/gtkblist.h	Tue Dec 20 22:57:54 2005 +0000
@@ -88,8 +88,6 @@
 
 	GaimBlistNode *selected_node;   /**< The currently selected node */
         GtkWidget *statusbox;            /**< The status selector dropdown */
-	GtkWidget *statusboxbox;       /**< A box to hold per account status boxes */
-	GList *statusboxes;            /**< A list of the per account status boxes */
 	GdkPixbuf *east, *south;                 /**< Drop shadow stuff */
 	GdkWindow *east_shadow, *south_shadow;   /**< Drop shadow stuff */
 
diff -r f75c0d35e032 -r 301e9f0841d7 src/gtkconn.c
--- a/src/gtkconn.c	Tue Dec 20 21:58:15 2005 +0000
+++ b/src/gtkconn.c	Tue Dec 20 22:57:54 2005 +0000
@@ -48,25 +48,6 @@
 static GHashTable *hash = NULL;
 static GSList *accountReconnecting = NULL;
 
-static GtkGaimStatusBox *
-find_status_box_for_account(GaimAccount *account)
-{
-	GaimGtkBuddyList *gtkblist;
-	GList *iter;
-
-	gtkblist = gaim_gtk_blist_get_default_gtk_blist();
-	if (!gtkblist)
-		return NULL;
-
-	for (iter = gtkblist->statusboxes; iter; iter=iter->next)
-	{
-		GtkGaimStatusBox *box = iter->data;
-		if (box->account == account)
-			return box;
-	}
-	return NULL;
-}
-
 static void gaim_gtk_connection_connect_progress(GaimConnection *gc,
 		const char *text, size_t step, size_t step_count)
 {
@@ -77,13 +58,6 @@
 	gtk_gaim_status_box_set_connecting(GTK_GAIM_STATUS_BOX(gtkblist->statusbox),
 					   (gaim_connections_get_connecting() != NULL));
 	gtk_gaim_status_box_pulse_connecting(GTK_GAIM_STATUS_BOX(gtkblist->statusbox));
-
-	if ((box = find_status_box_for_account(gc->account)) != NULL)
-	{
-		gtk_gaim_status_box_set_error(box, NULL);
-		gtk_gaim_status_box_set_connecting(box, TRUE);
-		gtk_gaim_status_box_pulse_connecting(box);
-	}
 }
 
 static void gaim_gtk_connection_connected(GaimConnection *gc)
@@ -97,12 +71,6 @@
 					   (gaim_connections_get_connecting() != NULL));
 	account = gaim_connection_get_account(gc);
 	
-	if ((box = find_status_box_for_account(account)) != NULL)
-	{
-		gtk_gaim_status_box_set_connecting(box, FALSE);
-		gtk_gaim_status_box_set_error(box, NULL);
-	}
-
 	if (hash != NULL)
 		g_hash_table_remove(hash, account);
 	if (accountReconnecting == NULL)
@@ -119,8 +87,6 @@
 		return;
 	gtk_gaim_status_box_set_connecting(GTK_GAIM_STATUS_BOX(gtkblist->statusbox),
 					   (gaim_connections_get_connecting() != NULL));
-	gtk_gaim_status_box_set_connecting(find_status_box_for_account(gc->account),
-									FALSE);
 
 	if (gaim_connections_get_all() != NULL)
 		return;
@@ -189,8 +155,7 @@
 	if (!gc->wants_to_die) {
 		if (gtkblist != NULL)
 			gtk_gaim_status_box_set_error(GTK_GAIM_STATUS_BOX(gtkblist->statusbox), text);
-			gtk_gaim_status_box_set_error(find_status_box_for_account(account), text);
-
+		
 		if (info == NULL) {
 			info = g_new0(GaimAutoRecon, 1);
 			g_hash_table_insert(hash, account, info);