changeset 3753:764ecb5f984b

[gaim-migrate @ 3892] I never committed this last night. committer: Tailor Script <tailor@pidgin.im>
author Sean Egan <seanegan@gmail.com>
date Sat, 19 Oct 2002 22:11:10 +0000 (2002-10-19)
parents b32474e522fa
children 599194293ee5
files src/dialogs.c src/prpl.c
diffstat 2 files changed, 25 insertions(+), 79 deletions(-) [+]
line wrap: on
line diff
--- a/src/dialogs.c	Sat Oct 19 05:22:30 2002 +0000
+++ b/src/dialogs.c	Sat Oct 19 22:11:10 2002 +0000
@@ -463,7 +463,7 @@
 	gtk_widget_show(w->window);
 }
 
-void do_remove_buddy(GtkWidget *w, struct buddy *b)
+void do_remove_buddy(struct buddy *b)
 {
 	struct group *g = find_group_by_buddy(b->gc, b->name);
 	struct gaim_connection *gc = b->gc;
@@ -486,84 +486,14 @@
 
 void show_confirm_del(struct gaim_connection *gc, gchar *name)
 {
-	struct confirm_del *b = g_new0(struct confirm_del, 1);
-	struct buddy *bd;
-	GtkWidget *hbox;
-	GtkWidget *vbox;
-	GtkWidget *fbox;
-	GtkSizeGroup *sg = gtk_size_group_new(GTK_SIZE_GROUP_BOTH);
-	gchar tmp[2048];
-	char labeltext[1024 * 2];
-	char *filename;
-	GtkWidget *image;
-
-	GAIM_DIALOG(b->window);
-	dialogwindows = g_list_prepend(dialogwindows, b->window);
-
-	g_snprintf(tmp, sizeof(tmp), _("Gaim - Remove %s?"), name);
-	gtk_container_set_border_width(GTK_CONTAINER(b->window), 6);
-	gtk_window_set_title(GTK_WINDOW(b->window), tmp);
-	gtk_window_set_wmclass(GTK_WINDOW(b->window), "confirm_del", "Gaim");
-	gtk_window_set_policy(GTK_WINDOW(b->window), FALSE, FALSE, TRUE);
-	gtk_signal_connect(GTK_OBJECT(b->window), "delete_event",
-			   GTK_SIGNAL_FUNC(destroy_dialog), b->window);
-
-	gtk_widget_realize(b->window);
-
-	vbox = gtk_vbox_new(FALSE, 0);
-	gtk_box_set_spacing(GTK_BOX(vbox), 12);
-	gtk_container_set_border_width(GTK_CONTAINER(vbox), 6);
-	gtk_container_add(GTK_CONTAINER(b->window), vbox);
-	gtk_widget_show(vbox);
-
-	fbox = gtk_hbox_new(FALSE, 0);
-	gtk_box_set_spacing(GTK_BOX(fbox), 6);
-	gtk_container_set_border_width(GTK_CONTAINER(fbox), 5);
-	gtk_widget_show(fbox);
-
-	filename = g_build_filename (DATADIR, "pixmaps", "gaim", "dialogs", "gaim_question.png", NULL);
-	debug_printf("Loading: %s\n", filename);
-	image = gtk_image_new_from_file(filename);
-	gtk_misc_set_alignment(GTK_MISC(image), 0, 0);
-	gtk_box_pack_start(GTK_BOX(fbox), image, FALSE, FALSE, 0);
-	gtk_widget_show(image);
-	g_free(filename);
-
-	g_snprintf(labeltext, sizeof(labeltext), "<span weight=\"bold\" size=\"larger\">Remove Buddy</span>\n\nYou are about to remove '%s' from\nyour buddylist.  Do you want to continue?", name);
-	b->label = gtk_label_new(NULL);
-	gtk_label_set_markup(GTK_LABEL(b->label), labeltext);
-	gtk_label_set_line_wrap(GTK_LABEL(b->label), TRUE);
-	gtk_label_set_justify(GTK_LABEL(b->label), GTK_JUSTIFY_LEFT);
-	gtk_misc_set_alignment(GTK_MISC(b->label), 0, 0);
-	gtk_box_pack_start(GTK_BOX(fbox), b->label, FALSE, FALSE, 0);
-	gtk_widget_show(b->label);
-	gtk_box_pack_start(GTK_BOX(vbox), fbox, TRUE, FALSE, 0);
-
-	hbox = gtk_hbox_new(FALSE, 0);
-	gtk_box_set_spacing(GTK_BOX(hbox), 6);
-	gtk_container_set_border_width(GTK_CONTAINER(hbox), 0);
-	gtk_box_pack_start(GTK_BOX(vbox), hbox, TRUE, FALSE, 0);
-	gtk_widget_show(hbox);
-
-	b->ok = gtk_button_new_with_label("Remove Buddy");
-	gtk_widget_show(b->ok);
-	gtk_size_group_add_widget(sg, b->ok);
-	gtk_box_pack_end(GTK_BOX(hbox), b->ok, FALSE, FALSE, 5);
-
-	bd = find_buddy(gc, name);
-
-	if (bd)
-		gtk_signal_connect(GTK_OBJECT(b->ok), "clicked", GTK_SIGNAL_FUNC(do_remove_buddy), bd);
-	
-	gtk_signal_connect(GTK_OBJECT(b->ok), "clicked", GTK_SIGNAL_FUNC(destroy_dialog), b->window);
-
-	b->cancel = gtk_button_new_from_stock (GTK_STOCK_CANCEL);
-	gtk_widget_show(b->cancel);
-	gtk_size_group_add_widget(sg, b->cancel);
-	gtk_box_pack_end(GTK_BOX(hbox), b->cancel, FALSE, FALSE, 5);
-	gtk_signal_connect(GTK_OBJECT(b->cancel), "clicked", GTK_SIGNAL_FUNC(destroy_dialog), b->window);
-	
-	gtk_widget_show(b->window);	
+	struct buddy *bd = find_buddy(gc, name);
+	char *text;
+	if (!bd)
+		return;
+
+	text = g_strdup_printf("You are about to remove %s from your buddy list.  Do you want to continue?", name);
+	do_ask_dialog("Remove Buddy", text, bd, "Remove Buddy", do_remove_buddy, "Cancel", NULL);
+	g_free(text);
 }
 
 
--- a/src/prpl.c	Sat Oct 19 05:22:30 2002 +0000
+++ b/src/prpl.c	Sat Oct 19 22:11:10 2002 +0000
@@ -165,6 +165,10 @@
 	gtk_widget_destroy(GTK_WIDGET(d));
 }
 
+#define STOCK_ITEMIZE(r, l)       if (!strcmp(r,yestext))  \
+                                           yestext = l;    \
+                                   if (!strcmp(r,notext))  \
+                                           notext = l;     
 
 void do_ask_dialog(const char *prim, const char *sec, void *data, char *yestext, void *doit, char *notext, void *dont)
 {
@@ -183,6 +187,18 @@
 	g_free(filename);
 	gtk_misc_set_alignment(GTK_MISC(img), 0, 0);
 
+	/* This is ugly.  GTK Stock items will take a button with a label "gtk-cancel" and turn it into a 
+	 * Cancel button with a Cancel icon and whatnot.  We want to avoid using anything gtk in the prpls
+	 * so we replace "Cancel" with "gtk-cancel" right here. */
+	STOCK_ITEMIZE("Add", GTK_STOCK_ADD);
+	STOCK_ITEMIZE("Apply", GTK_STOCK_APPLY);
+	STOCK_ITEMIZE("Cancel", GTK_STOCK_CANCEL);
+	STOCK_ITEMIZE("Close", GTK_STOCK_CLOSE);
+	STOCK_ITEMIZE("Delete", GTK_STOCK_DELETE);
+	STOCK_ITEMIZE("Remove", GTK_STOCK_REMOVE);
+	STOCK_ITEMIZE("Yes", GTK_STOCK_YES);
+	STOCK_ITEMIZE("No", GTK_STOCK_NO);
+
 	window = gtk_dialog_new_with_buttons("", NULL, GTK_DIALOG_MODAL, notext, GTK_RESPONSE_NO, yestext, GTK_RESPONSE_YES, NULL);
 	gtk_dialog_set_default_response (GTK_DIALOG(window), GTK_RESPONSE_YES);
 	g_signal_connect(G_OBJECT(window), "response", G_CALLBACK(do_ask_callback), doask);