Mercurial > pidgin
changeset 3819:8997bc63417c
[gaim-migrate @ 3966]
add group dialog gtk2ized.
committer: Tailor Script <tailor@pidgin.im>
author | Sean Egan <seanegan@gmail.com> |
---|---|
date | Tue, 29 Oct 2002 08:55:23 +0000 |
parents | fed3d1b2a472 |
children | 1e9221073b1a |
files | src/dialogs.c |
diffstat | 1 files changed, 52 insertions(+), 69 deletions(-) [+] |
line wrap: on
line diff
--- a/src/dialogs.c Tue Oct 29 08:37:39 2002 +0000 +++ b/src/dialogs.c Tue Oct 29 08:55:23 2002 +0000 @@ -58,7 +58,6 @@ #include "pixmaps/save.xpm" #include "pixmaps/ok.xpm" #include "pixmaps/add.xpm" -#include "pixmaps/warn.xpm" #include "pixmaps/close.xpm" #include "pixmaps/gnome_add.xpm" #include "pixmaps/gnome_remove.xpm" @@ -896,17 +895,19 @@ destroy_dialog(NULL, a->window); } -void do_add_group(GtkWidget *w, struct addbuddy *a) +void do_add_group(GtkWidget *w, int resp, struct addbuddy *a) { const char *grp; - - grp = gtk_entry_get_text(GTK_ENTRY(a->entry)); - - if (!a->gc) - a->gc = connections->data; - - add_group(a->gc, grp); - do_export(a->gc); + + if (resp == GTK_RESPONSE_OK) { + grp = gtk_entry_get_text(GTK_ENTRY(a->entry)); + + if (!a->gc) + a->gc = connections->data; + + add_group(a->gc, grp); + do_export(a->gc); + } destroy_dialog(NULL, a->window); } @@ -941,71 +942,53 @@ void show_add_group(struct gaim_connection *gc) { - GtkWidget *cancel; - GtkWidget *add; + + GtkWidget *hbox, *vbox; GtkWidget *label; - GtkWidget *bbox; - GtkWidget *vbox; - GtkWidget *topbox; - GtkWidget *frame; + char *filename = g_build_filename(DATADIR, "pixmaps", "gaim", "dialogs", "gaim_question.png", NULL); + GtkWidget *img = gtk_image_new_from_file(filename); struct addbuddy *a = g_new0(struct addbuddy, 1); a->gc = gc; - GAIM_DIALOG(a->window); - gtk_window_set_wmclass(GTK_WINDOW(a->window), "add_group", "Gaim"); - gtk_window_set_policy(GTK_WINDOW(a->window), FALSE, FALSE, TRUE); - gtk_widget_realize(a->window); - dialogwindows = g_list_prepend(dialogwindows, a->window); - - bbox = gtk_hbox_new(TRUE, 10); - topbox = gtk_hbox_new(FALSE, 5); - vbox = gtk_vbox_new(FALSE, 5); - + a->window = gtk_dialog_new_with_buttons("", blist, GTK_DIALOG_MODAL, + GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, GTK_STOCK_ADD, GTK_RESPONSE_OK, NULL); + gtk_dialog_set_default_response (GTK_DIALOG(a->window), GTK_RESPONSE_OK); + gtk_container_set_border_width (GTK_CONTAINER(a->window), 6); + gtk_window_set_resizable(GTK_WINDOW(a->window), FALSE); + gtk_dialog_set_has_separator(GTK_DIALOG(a->window), FALSE); + gtk_box_set_spacing(GTK_BOX(GTK_DIALOG(a->window)->vbox), 12); + gtk_container_set_border_width (GTK_CONTAINER(GTK_DIALOG(a->window)->vbox), 6); + + hbox = gtk_hbox_new(FALSE, 12); + gtk_container_add(GTK_CONTAINER(GTK_DIALOG(a->window)->vbox), hbox); + gtk_box_pack_start(GTK_BOX(hbox), img, FALSE, FALSE, 0); + gtk_misc_set_alignment(GTK_MISC(img), 0, 0); + + vbox = gtk_vbox_new(FALSE, 0); + gtk_container_add(GTK_CONTAINER(hbox), vbox); + + label = gtk_label_new(_("Please enter the name of the group to be added.\n")); + gtk_label_set_line_wrap(GTK_LABEL(label), TRUE); + gtk_misc_set_alignment(GTK_MISC(label), 0, 0); + gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0); + + hbox = gtk_hbox_new(FALSE, 6); + gtk_container_add(GTK_CONTAINER(vbox), hbox); + + label = gtk_label_new(NULL); + gtk_label_set_markup_with_mnemonic(GTK_LABEL(label), _("_Group:")); + gtk_box_pack_start(GTK_BOX(hbox), label, FALSE, FALSE, 0); + a->entry = gtk_entry_new(); - /* Put the buttons in the box */ - - add = picture_button(a->window, _("Add"), add_xpm); - - cancel = picture_button(a->window, _("Cancel"), cancel_xpm); - - gtk_box_pack_start(GTK_BOX(bbox), add, FALSE, FALSE, 5); - gtk_box_pack_end(GTK_BOX(bbox), cancel, FALSE, FALSE, 5); - - frame = gtk_frame_new(NULL); - gtk_frame_set_label(GTK_FRAME(frame), _("Add Group")); - - label = gtk_label_new(_("Group")); - gtk_widget_show(label); - gtk_box_pack_start(GTK_BOX(topbox), label, FALSE, FALSE, 5); - gtk_box_pack_start(GTK_BOX(topbox), a->entry, FALSE, FALSE, 5); - - /* And the boxes in the box */ - gtk_box_pack_start(GTK_BOX(vbox), topbox, TRUE, TRUE, 5); - gtk_box_pack_start(GTK_BOX(vbox), bbox, TRUE, TRUE, 5); - - /* Handle closes right */ - gtk_signal_connect(GTK_OBJECT(a->window), "destroy", GTK_SIGNAL_FUNC(destroy_dialog), a->window); - gtk_signal_connect(GTK_OBJECT(a->window), "destroy", GTK_SIGNAL_FUNC(free_dialog), a); - gtk_signal_connect(GTK_OBJECT(cancel), "clicked", GTK_SIGNAL_FUNC(destroy_dialog), a->window); - gtk_signal_connect(GTK_OBJECT(add), "clicked", GTK_SIGNAL_FUNC(do_add_group), a); - gtk_signal_connect(GTK_OBJECT(a->entry), "activate", GTK_SIGNAL_FUNC(do_add_group), a); - /* Finish up */ - gtk_widget_show(add); - gtk_widget_show(cancel); - gtk_widget_show(a->entry); - gtk_widget_show(topbox); - gtk_widget_show(bbox); - gtk_widget_show(vbox); - gtk_widget_show(frame); - gtk_window_set_title(GTK_WINDOW(a->window), _("Gaim - Add Group")); - gtk_window_set_focus(GTK_WINDOW(a->window), a->entry); - gtk_container_add(GTK_CONTAINER(frame), vbox); - gtk_container_add(GTK_CONTAINER(a->window), frame); - gtk_container_set_border_width(GTK_CONTAINER(a->window), 5); - gtk_widget_realize(a->window); - - gtk_widget_show(a->window); + gtk_entry_set_activates_default (GTK_ENTRY(a->entry), TRUE); + gtk_box_pack_start(GTK_BOX(hbox), a->entry, FALSE, FALSE, 0); + gtk_label_set_mnemonic_widget(GTK_LABEL(label), GTK_WIDGET(a->entry)); + + g_signal_connect(G_OBJECT(a->window), "response", G_CALLBACK(do_add_group), a); + + gtk_widget_show_all(a->window); + gtk_widget_grab_focus(GTK_WIDGET(a->entry)); } static void addbuddy_select_account(GtkObject *w, struct gaim_connection *gc)