Mercurial > pidgin
annotate finch/gntrequest.c @ 16182:36d9409dab58
Point to the devel@pidgin.im list instead of gaim-devel.
author | Richard Laager <rlaager@wiktel.com> |
---|---|
date | Mon, 16 Apr 2007 00:49:52 +0000 |
parents | 87019c619be0 |
children | 0f0832c13fcb |
rev | line source |
---|---|
15817 | 1 /** |
2 * @file gntrequest.c GNT Request API | |
3 * @ingroup gntui | |
4 * | |
15870
66dff3dfdea6
Re-sed the copyright notices so they don't all talk about Purple.
Richard Laager <rlaager@wiktel.com>
parents:
15843
diff
changeset
|
5 * finch |
15817 | 6 * |
15870
66dff3dfdea6
Re-sed the copyright notices so they don't all talk about Purple.
Richard Laager <rlaager@wiktel.com>
parents:
15843
diff
changeset
|
7 * Finch is the legal property of its developers, whose names are too numerous |
15817 | 8 * to list here. Please refer to the COPYRIGHT file distributed with this |
9 * source distribution. | |
10 * | |
11 * This program is free software; you can redistribute it and/or modify | |
12 * it under the terms of the GNU General Public License as published by | |
13 * the Free Software Foundation; either version 2 of the License, or | |
14 * (at your option) any later version. | |
15 * | |
16 * This program is distributed in the hope that it will be useful, | |
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 * GNU General Public License for more details. | |
20 * | |
21 * You should have received a copy of the GNU General Public License | |
22 * along with this program; if not, write to the Free Software | |
23 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
24 */ | |
25 #include <gnt.h> | |
26 #include <gntbox.h> | |
27 #include <gntbutton.h> | |
28 #include <gntcheckbox.h> | |
29 #include <gntcombobox.h> | |
30 #include <gntentry.h> | |
15927
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
31 #include <gntfilesel.h> |
15817 | 32 #include <gntlabel.h> |
33 #include <gntline.h> | |
34 #include <gnttree.h> | |
35 | |
15822 | 36 #include "finch.h" |
15817 | 37 #include "gntrequest.h" |
16164
87019c619be0
Include header files, not source files. Bah.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15936
diff
changeset
|
38 #include "util.h" |
15817 | 39 |
40 typedef struct | |
41 { | |
42 void *user_data; | |
15927
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
43 GntWidget *dialog; |
15817 | 44 GCallback *cbs; |
15822 | 45 } PurpleGntFileRequest; |
15817 | 46 |
47 static GntWidget * | |
48 setup_request_window(const char *title, const char *primary, | |
15822 | 49 const char *secondary, PurpleRequestType type) |
15817 | 50 { |
51 GntWidget *window; | |
52 | |
53 window = gnt_vbox_new(FALSE); | |
54 gnt_box_set_toplevel(GNT_BOX(window), TRUE); | |
55 gnt_box_set_title(GNT_BOX(window), title); | |
56 gnt_box_set_alignment(GNT_BOX(window), GNT_ALIGN_MID); | |
57 | |
58 if (primary) | |
59 gnt_box_add_widget(GNT_BOX(window), | |
60 gnt_label_new_with_format(primary, GNT_TEXT_FLAG_BOLD)); | |
61 if (secondary) | |
62 gnt_box_add_widget(GNT_BOX(window), gnt_label_new(secondary)); | |
63 | |
15822 | 64 g_signal_connect_swapped(G_OBJECT(window), "destroy", G_CALLBACK(purple_request_close), |
15817 | 65 GINT_TO_POINTER(type)); |
66 | |
67 return window; | |
68 } | |
69 | |
70 static GntWidget * | |
71 setup_button_box(gpointer userdata, gpointer cb, gpointer data, ...) | |
72 { | |
73 GntWidget *box, *button; | |
74 va_list list; | |
75 const char *text; | |
76 gpointer callback; | |
77 | |
78 box = gnt_hbox_new(FALSE); | |
79 | |
80 va_start(list, data); | |
81 | |
82 while ((text = va_arg(list, const char *))) | |
83 { | |
84 callback = va_arg(list, gpointer); | |
85 button = gnt_button_new(text); | |
86 gnt_box_add_widget(GNT_BOX(box), button); | |
87 g_object_set_data(G_OBJECT(button), "activate-callback", callback); | |
88 g_object_set_data(G_OBJECT(button), "activate-userdata", userdata); | |
89 g_signal_connect(G_OBJECT(button), "activate", G_CALLBACK(cb), data); | |
90 } | |
91 | |
92 va_end(list); | |
93 return box; | |
94 } | |
95 | |
96 static void | |
97 notify_input_cb(GntWidget *button, GntWidget *entry) | |
98 { | |
15822 | 99 PurpleRequestInputCb callback = g_object_get_data(G_OBJECT(button), "activate-callback"); |
15817 | 100 gpointer data = g_object_get_data(G_OBJECT(button), "activate-userdata"); |
101 const char *text = gnt_entry_get_text(GNT_ENTRY(entry)); | |
102 | |
103 if (callback) | |
104 callback(data, text); | |
105 | |
106 while (button->parent) | |
107 button = button->parent; | |
108 | |
15822 | 109 purple_request_close(PURPLE_REQUEST_INPUT, button); |
15817 | 110 } |
111 | |
112 static void * | |
113 finch_request_input(const char *title, const char *primary, | |
114 const char *secondary, const char *default_value, | |
115 gboolean multiline, gboolean masked, gchar *hint, | |
116 const char *ok_text, GCallback ok_cb, | |
117 const char *cancel_text, GCallback cancel_cb, | |
118 void *user_data) | |
119 { | |
120 GntWidget *window, *box, *entry; | |
121 | |
15822 | 122 window = setup_request_window(title, primary, secondary, PURPLE_REQUEST_INPUT); |
15817 | 123 |
124 entry = gnt_entry_new(default_value); | |
125 if (masked) | |
126 gnt_entry_set_masked(GNT_ENTRY(entry), TRUE); | |
127 gnt_box_add_widget(GNT_BOX(window), entry); | |
128 | |
129 box = setup_button_box(user_data, notify_input_cb, entry, | |
130 ok_text, ok_cb, cancel_text, cancel_cb, NULL); | |
131 gnt_box_add_widget(GNT_BOX(window), box); | |
132 | |
133 gnt_widget_show(window); | |
134 | |
135 return window; | |
136 } | |
137 | |
138 static void | |
15822 | 139 finch_close_request(PurpleRequestType type, gpointer ui_handle) |
15817 | 140 { |
141 GntWidget *widget = GNT_WIDGET(ui_handle); | |
142 while (widget->parent) | |
143 widget = widget->parent; | |
144 gnt_widget_destroy(widget); | |
145 } | |
146 | |
147 static void | |
148 request_choice_cb(GntWidget *button, GntComboBox *combo) | |
149 { | |
15822 | 150 PurpleRequestChoiceCb callback = g_object_get_data(G_OBJECT(button), "activate-callback"); |
15817 | 151 gpointer data = g_object_get_data(G_OBJECT(button), "activate-userdata"); |
152 int choice = GPOINTER_TO_INT(gnt_combo_box_get_selected_data(GNT_COMBO_BOX(combo))) - 1; | |
153 | |
154 if (callback) | |
155 callback(data, choice); | |
156 | |
157 while (button->parent) | |
158 button = button->parent; | |
159 | |
15822 | 160 purple_request_close(PURPLE_REQUEST_INPUT, button); |
15817 | 161 } |
162 | |
163 static void * | |
164 finch_request_choice(const char *title, const char *primary, | |
165 const char *secondary, unsigned int default_value, | |
166 const char *ok_text, GCallback ok_cb, | |
167 const char *cancel_text, GCallback cancel_cb, | |
168 void *user_data, va_list choices) | |
169 { | |
170 GntWidget *window, *combo, *box; | |
171 const char *text; | |
172 int val; | |
173 | |
15822 | 174 window = setup_request_window(title, primary, secondary, PURPLE_REQUEST_CHOICE); |
15817 | 175 |
176 combo = gnt_combo_box_new(); | |
177 gnt_box_add_widget(GNT_BOX(window), combo); | |
178 while ((text = va_arg(choices, const char *))) | |
179 { | |
180 val = va_arg(choices, int); | |
181 gnt_combo_box_add_data(GNT_COMBO_BOX(combo), GINT_TO_POINTER(val + 1), text); | |
182 } | |
183 gnt_combo_box_set_selected(GNT_COMBO_BOX(combo), GINT_TO_POINTER(default_value + 1)); | |
184 | |
185 box = setup_button_box(user_data, request_choice_cb, combo, | |
186 ok_text, ok_cb, cancel_text, cancel_cb, NULL); | |
187 gnt_box_add_widget(GNT_BOX(window), box); | |
188 | |
189 gnt_widget_show(window); | |
190 | |
191 return window; | |
192 } | |
193 | |
194 static void | |
195 request_action_cb(GntWidget *button, GntWidget *window) | |
196 { | |
15822 | 197 PurpleRequestActionCb callback = g_object_get_data(G_OBJECT(button), "activate-callback"); |
15817 | 198 gpointer data = g_object_get_data(G_OBJECT(button), "activate-userdata"); |
199 int id = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(button), "activate-id")); | |
200 | |
201 if (callback) | |
202 callback(data, id); | |
203 | |
15822 | 204 purple_request_close(PURPLE_REQUEST_ACTION, window); |
15817 | 205 } |
206 | |
207 static void* | |
208 finch_request_action(const char *title, const char *primary, | |
209 const char *secondary, unsigned int default_value, | |
210 void *user_data, size_t actioncount, | |
211 va_list actions) | |
212 { | |
213 GntWidget *window, *box, *button; | |
214 int i; | |
215 | |
15822 | 216 window = setup_request_window(title, primary, secondary, PURPLE_REQUEST_ACTION); |
15817 | 217 |
218 box = gnt_hbox_new(FALSE); | |
219 gnt_box_add_widget(GNT_BOX(window), box); | |
220 for (i = 0; i < actioncount; i++) | |
221 { | |
222 const char *text = va_arg(actions, const char *); | |
15822 | 223 PurpleRequestActionCb callback = va_arg(actions, PurpleRequestActionCb); |
15817 | 224 |
225 button = gnt_button_new(text); | |
226 gnt_box_add_widget(GNT_BOX(box), button); | |
227 | |
228 g_object_set_data(G_OBJECT(button), "activate-callback", callback); | |
229 g_object_set_data(G_OBJECT(button), "activate-userdata", user_data); | |
230 g_object_set_data(G_OBJECT(button), "activate-id", GINT_TO_POINTER(i)); | |
231 g_signal_connect(G_OBJECT(button), "activate", G_CALLBACK(request_action_cb), window); | |
232 } | |
233 | |
234 gnt_widget_show(window); | |
235 | |
236 return window; | |
237 } | |
238 | |
239 static void | |
15822 | 240 request_fields_cb(GntWidget *button, PurpleRequestFields *fields) |
15817 | 241 { |
15822 | 242 PurpleRequestFieldsCb callback = g_object_get_data(G_OBJECT(button), "activate-callback"); |
15817 | 243 gpointer data = g_object_get_data(G_OBJECT(button), "activate-userdata"); |
244 GList *list; | |
245 | |
15822 | 246 /* Update the data of the fields. GtkPurple does this differently. Instead of |
15817 | 247 * updating the fields at the end like here, it updates the appropriate field |
248 * instantly whenever a change is made. That allows it to make sure the | |
249 * 'required' fields are entered before the user can hit OK. It's not the case | |
250 * here, althought it can be done. I am not honouring the 'required' fields | |
251 * for the moment. */ | |
15822 | 252 for (list = purple_request_fields_get_groups(fields); list; list = list->next) |
15817 | 253 { |
15822 | 254 PurpleRequestFieldGroup *group = list->data; |
255 GList *fields = purple_request_field_group_get_fields(group); | |
15817 | 256 |
257 for (; fields ; fields = fields->next) | |
258 { | |
15822 | 259 PurpleRequestField *field = fields->data; |
260 PurpleRequestFieldType type = purple_request_field_get_type(field); | |
261 if (type == PURPLE_REQUEST_FIELD_BOOLEAN) | |
15817 | 262 { |
263 GntWidget *check = field->ui_data; | |
264 gboolean value = gnt_check_box_get_checked(GNT_CHECK_BOX(check)); | |
15822 | 265 purple_request_field_bool_set_value(field, value); |
15817 | 266 } |
15822 | 267 else if (type == PURPLE_REQUEST_FIELD_STRING) |
15817 | 268 { |
269 GntWidget *entry = field->ui_data; | |
270 const char *text = gnt_entry_get_text(GNT_ENTRY(entry)); | |
15822 | 271 purple_request_field_string_set_value(field, (text && *text) ? text : NULL); |
15817 | 272 } |
15822 | 273 else if (type == PURPLE_REQUEST_FIELD_INTEGER) |
15817 | 274 { |
275 GntWidget *entry = field->ui_data; | |
276 const char *text = gnt_entry_get_text(GNT_ENTRY(entry)); | |
277 int value = (text && *text) ? atoi(text) : 0; | |
15822 | 278 purple_request_field_int_set_value(field, value); |
15817 | 279 } |
15822 | 280 else if (type == PURPLE_REQUEST_FIELD_CHOICE) |
15817 | 281 { |
282 GntWidget *combo = field->ui_data; | |
283 int id; | |
284 id = GPOINTER_TO_INT(gnt_combo_box_get_selected_data(GNT_COMBO_BOX(combo))); | |
15822 | 285 purple_request_field_choice_set_value(field, id); |
15817 | 286 } |
15822 | 287 else if (type == PURPLE_REQUEST_FIELD_LIST) |
15817 | 288 { |
289 GList *list = NULL; | |
15822 | 290 if (purple_request_field_list_get_multi_select(field)) |
15817 | 291 { |
292 const GList *iter; | |
293 GntWidget *tree = field->ui_data; | |
294 | |
15822 | 295 iter = purple_request_field_list_get_items(field); |
15817 | 296 for (; iter; iter = iter->next) |
297 { | |
298 const char *text = iter->data; | |
15822 | 299 gpointer key = purple_request_field_list_get_data(field, text); |
15817 | 300 if (gnt_tree_get_choice(GNT_TREE(tree), key)) |
301 list = g_list_prepend(list, key); | |
302 } | |
303 } | |
304 else | |
305 { | |
306 GntWidget *combo = field->ui_data; | |
307 gpointer data = gnt_combo_box_get_selected_data(GNT_COMBO_BOX(combo)); | |
308 list = g_list_append(list, data); | |
309 } | |
310 | |
15822 | 311 purple_request_field_list_set_selected(field, list); |
15817 | 312 g_list_free(list); |
313 } | |
15822 | 314 else if (type == PURPLE_REQUEST_FIELD_ACCOUNT) |
15817 | 315 { |
316 GntWidget *combo = field->ui_data; | |
15822 | 317 PurpleAccount *acc = gnt_combo_box_get_selected_data(GNT_COMBO_BOX(combo)); |
318 purple_request_field_account_set_value(field, acc); | |
15817 | 319 } |
320 } | |
321 } | |
322 | |
323 if (callback) | |
324 callback(data, fields); | |
325 | |
326 while (button->parent) | |
327 button = button->parent; | |
328 | |
15822 | 329 purple_request_close(PURPLE_REQUEST_FIELDS, button); |
15817 | 330 } |
331 | |
332 static void * | |
333 finch_request_fields(const char *title, const char *primary, | |
15822 | 334 const char *secondary, PurpleRequestFields *allfields, |
15817 | 335 const char *ok, GCallback ok_cb, |
336 const char *cancel, GCallback cancel_cb, | |
337 void *userdata) | |
338 { | |
339 GntWidget *window, *box; | |
340 GList *grlist; | |
341 | |
15822 | 342 window = setup_request_window(title, primary, secondary, PURPLE_REQUEST_FIELDS); |
15817 | 343 |
344 /* This is how it's going to work: the request-groups are going to be | |
345 * stacked vertically one after the other. A GntLine will be separating | |
346 * the groups. */ | |
347 box = gnt_vbox_new(FALSE); | |
348 gnt_box_set_pad(GNT_BOX(box), 0); | |
349 gnt_box_set_fill(GNT_BOX(box), TRUE); | |
15822 | 350 for (grlist = purple_request_fields_get_groups(allfields); grlist; grlist = grlist->next) |
15817 | 351 { |
15822 | 352 PurpleRequestFieldGroup *group = grlist->data; |
353 GList *fields = purple_request_field_group_get_fields(group); | |
15817 | 354 GntWidget *hbox; |
15822 | 355 const char *title = purple_request_field_group_get_title(group); |
15817 | 356 |
357 if (title) | |
358 gnt_box_add_widget(GNT_BOX(box), | |
359 gnt_label_new_with_format(title, GNT_TEXT_FLAG_BOLD)); | |
360 | |
361 for (; fields ; fields = fields->next) | |
362 { | |
363 /* XXX: Break each of the fields into a separate function? */ | |
15822 | 364 PurpleRequestField *field = fields->data; |
365 PurpleRequestFieldType type = purple_request_field_get_type(field); | |
366 const char *label = purple_request_field_get_label(field); | |
15817 | 367 |
368 hbox = gnt_hbox_new(TRUE); /* hrm */ | |
369 gnt_box_add_widget(GNT_BOX(box), hbox); | |
370 | |
15822 | 371 if (type != PURPLE_REQUEST_FIELD_BOOLEAN && label) |
15817 | 372 { |
373 GntWidget *l = gnt_label_new(label); | |
374 gnt_widget_set_size(l, 0, 1); | |
375 gnt_box_add_widget(GNT_BOX(hbox), l); | |
376 } | |
377 | |
15822 | 378 if (type == PURPLE_REQUEST_FIELD_BOOLEAN) |
15817 | 379 { |
380 GntWidget *check = gnt_check_box_new(label); | |
381 gnt_check_box_set_checked(GNT_CHECK_BOX(check), | |
15822 | 382 purple_request_field_bool_get_default_value(field)); |
15817 | 383 gnt_box_add_widget(GNT_BOX(hbox), check); |
384 field->ui_data = check; | |
385 } | |
15822 | 386 else if (type == PURPLE_REQUEST_FIELD_STRING) |
15817 | 387 { |
15829 | 388 const char *hint = purple_request_field_get_type_hint(field); |
15817 | 389 GntWidget *entry = gnt_entry_new( |
15822 | 390 purple_request_field_string_get_default_value(field)); |
15817 | 391 gnt_entry_set_masked(GNT_ENTRY(entry), |
15822 | 392 purple_request_field_string_is_masked(field)); |
15829 | 393 if (purple_str_has_prefix(hint, "screenname")) { |
394 PurpleBlistNode *node = purple_blist_get_root(); | |
395 gboolean offline = purple_str_has_suffix(hint, "all"); | |
396 for (; node; node = purple_blist_node_next(node, offline)) { | |
397 if (!PURPLE_BLIST_NODE_IS_BUDDY(node)) | |
15826
f59cfcce68a8
Add auto-complete support in request-entries that have 'screenname' hint set. This can be useful in, for example, 'send im' dialog etc.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
398 continue; |
15829 | 399 gnt_entry_add_suggest(GNT_ENTRY(entry), purple_buddy_get_name((PurpleBuddy*)node)); |
15826
f59cfcce68a8
Add auto-complete support in request-entries that have 'screenname' hint set. This can be useful in, for example, 'send im' dialog etc.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
400 } |
f59cfcce68a8
Add auto-complete support in request-entries that have 'screenname' hint set. This can be useful in, for example, 'send im' dialog etc.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
401 gnt_entry_set_always_suggest(GNT_ENTRY(entry), TRUE); |
15843
e74c2488448b
Group autocomplete for buddy adding
Richard Nelson <wabz@pidgin.im>
parents:
15829
diff
changeset
|
402 } else if (hint && !strcmp(hint, "group")) { |
e74c2488448b
Group autocomplete for buddy adding
Richard Nelson <wabz@pidgin.im>
parents:
15829
diff
changeset
|
403 PurpleBlistNode *node; |
e74c2488448b
Group autocomplete for buddy adding
Richard Nelson <wabz@pidgin.im>
parents:
15829
diff
changeset
|
404 for (node = purple_blist_get_root(); node; node = node->next) { |
e74c2488448b
Group autocomplete for buddy adding
Richard Nelson <wabz@pidgin.im>
parents:
15829
diff
changeset
|
405 if (PURPLE_BLIST_NODE_IS_GROUP(node)) |
e74c2488448b
Group autocomplete for buddy adding
Richard Nelson <wabz@pidgin.im>
parents:
15829
diff
changeset
|
406 gnt_entry_add_suggest(GNT_ENTRY(entry), ((PurpleGroup *)node)->name); |
e74c2488448b
Group autocomplete for buddy adding
Richard Nelson <wabz@pidgin.im>
parents:
15829
diff
changeset
|
407 } |
15826
f59cfcce68a8
Add auto-complete support in request-entries that have 'screenname' hint set. This can be useful in, for example, 'send im' dialog etc.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
408 } |
15817 | 409 gnt_box_add_widget(GNT_BOX(hbox), entry); |
410 field->ui_data = entry; | |
411 } | |
15822 | 412 else if (type == PURPLE_REQUEST_FIELD_INTEGER) |
15817 | 413 { |
414 char str[256]; | |
15822 | 415 int val = purple_request_field_int_get_default_value(field); |
15817 | 416 GntWidget *entry; |
417 | |
418 snprintf(str, sizeof(str), "%d", val); | |
419 entry = gnt_entry_new(str); | |
420 gnt_entry_set_flag(GNT_ENTRY(entry), GNT_ENTRY_FLAG_INT); | |
421 gnt_box_add_widget(GNT_BOX(hbox), entry); | |
422 field->ui_data = entry; | |
423 } | |
15822 | 424 else if (type == PURPLE_REQUEST_FIELD_CHOICE) |
15817 | 425 { |
426 int id; | |
427 const GList *list; | |
428 GntWidget *combo = gnt_combo_box_new(); | |
429 gnt_box_add_widget(GNT_BOX(hbox), combo); | |
430 field->ui_data = combo; | |
431 | |
15822 | 432 list = purple_request_field_choice_get_labels(field); |
15817 | 433 for (id = 1; list; list = list->next, id++) |
434 { | |
435 gnt_combo_box_add_data(GNT_COMBO_BOX(combo), | |
436 GINT_TO_POINTER(id), list->data); | |
437 } | |
438 gnt_combo_box_set_selected(GNT_COMBO_BOX(combo), | |
15822 | 439 GINT_TO_POINTER(purple_request_field_choice_get_default_value(field))); |
15817 | 440 } |
15822 | 441 else if (type == PURPLE_REQUEST_FIELD_LIST) |
15817 | 442 { |
443 const GList *list; | |
15822 | 444 gboolean multi = purple_request_field_list_get_multi_select(field); |
15817 | 445 if (multi) |
446 { | |
447 GntWidget *tree = gnt_tree_new(); | |
448 gnt_box_add_widget(GNT_BOX(hbox), tree); | |
449 field->ui_data = tree; | |
450 | |
15822 | 451 list = purple_request_field_list_get_items(field); |
15817 | 452 for (; list; list = list->next) |
453 { | |
454 const char *text = list->data; | |
15822 | 455 gpointer key = purple_request_field_list_get_data(field, text); |
15817 | 456 gnt_tree_add_choice(GNT_TREE(tree), key, |
457 gnt_tree_create_row(GNT_TREE(tree), text), NULL, NULL); | |
15822 | 458 if (purple_request_field_list_is_selected(field, text)) |
15817 | 459 gnt_tree_set_choice(GNT_TREE(tree), key, TRUE); |
460 } | |
461 } | |
462 else | |
463 { | |
464 GntWidget *combo = gnt_combo_box_new(); | |
465 gnt_box_set_alignment(GNT_BOX(hbox), GNT_ALIGN_MID); | |
466 gnt_box_add_widget(GNT_BOX(hbox), combo); | |
467 field->ui_data = combo; | |
468 | |
15822 | 469 list = purple_request_field_list_get_items(field); |
15817 | 470 for (; list; list = list->next) |
471 { | |
472 const char *text = list->data; | |
15822 | 473 gpointer key = purple_request_field_list_get_data(field, text); |
15817 | 474 gnt_combo_box_add_data(GNT_COMBO_BOX(combo), key, text); |
15822 | 475 if (purple_request_field_list_is_selected(field, text)) |
15817 | 476 gnt_combo_box_set_selected(GNT_COMBO_BOX(combo), key); |
477 } | |
478 } | |
479 } | |
15822 | 480 else if (type == PURPLE_REQUEST_FIELD_ACCOUNT) |
15817 | 481 { |
482 gboolean all; | |
15822 | 483 PurpleAccount *def; |
15817 | 484 GList *list; |
485 GntWidget *combo = gnt_combo_box_new(); | |
486 gnt_box_set_alignment(GNT_BOX(hbox), GNT_ALIGN_MID); | |
487 gnt_box_add_widget(GNT_BOX(hbox), combo); | |
488 field->ui_data = combo; | |
489 | |
15822 | 490 all = purple_request_field_account_get_show_all(field); |
491 def = purple_request_field_account_get_default_value(field); | |
15817 | 492 |
493 if (all) | |
15822 | 494 list = purple_accounts_get_all(); |
15817 | 495 else |
15822 | 496 list = purple_connections_get_all(); |
15817 | 497 |
498 for (; list; list = list->next) | |
499 { | |
15822 | 500 PurpleAccount *account; |
15817 | 501 char *text; |
502 | |
503 if (all) | |
504 account = list->data; | |
505 else | |
15822 | 506 account = purple_connection_get_account(list->data); |
15817 | 507 |
508 text = g_strdup_printf("%s (%s)", | |
15822 | 509 purple_account_get_username(account), |
510 purple_account_get_protocol_name(account)); | |
15817 | 511 gnt_combo_box_add_data(GNT_COMBO_BOX(combo), account, text); |
512 g_free(text); | |
513 if (account == def) | |
514 gnt_combo_box_set_selected(GNT_COMBO_BOX(combo), account); | |
515 } | |
516 gnt_widget_set_size(combo, 20, 3); /* ew */ | |
517 } | |
518 else | |
519 { | |
520 gnt_box_add_widget(GNT_BOX(hbox), | |
521 gnt_label_new_with_format(_("Not implemented yet."), | |
522 GNT_TEXT_FLAG_BOLD)); | |
523 } | |
524 } | |
525 if (grlist->next) | |
526 gnt_box_add_widget(GNT_BOX(box), gnt_hline_new()); | |
527 } | |
528 gnt_box_add_widget(GNT_BOX(window), box); | |
529 | |
530 box = setup_button_box(userdata, request_fields_cb, allfields, | |
531 ok, ok_cb, cancel, cancel_cb, NULL); | |
532 gnt_box_add_widget(GNT_BOX(window), box); | |
533 | |
534 gnt_widget_show(window); | |
535 | |
536 return window; | |
537 } | |
538 | |
539 static void | |
540 file_cancel_cb(GntWidget *wid, gpointer fq) | |
541 { | |
15822 | 542 PurpleGntFileRequest *data = fq; |
15817 | 543 if (data->cbs[1] != NULL) |
15822 | 544 ((PurpleRequestFileCb)data->cbs[1])(data->user_data, NULL); |
15817 | 545 |
15822 | 546 purple_request_close(PURPLE_REQUEST_FILE, data->dialog); |
15817 | 547 } |
548 | |
549 static void | |
550 file_ok_cb(GntWidget *wid, gpointer fq) | |
551 { | |
15822 | 552 PurpleGntFileRequest *data = fq; |
15927
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
553 char *file = gnt_file_sel_get_selected_file(GNT_FILE_SEL(data->dialog)); |
15817 | 554 if (data->cbs[0] != NULL) |
15927
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
555 ((PurpleRequestFileCb)data->cbs[0])(data->user_data, file); |
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
556 g_free(file); |
15817 | 557 |
15822 | 558 purple_request_close(PURPLE_REQUEST_FILE, data->dialog); |
15817 | 559 } |
560 | |
561 static void | |
15822 | 562 file_request_destroy(PurpleGntFileRequest *data) |
15817 | 563 { |
564 g_free(data->cbs); | |
565 g_free(data); | |
566 } | |
567 | |
568 static void * | |
569 finch_request_file(const char *title, const char *filename, | |
570 gboolean savedialog, | |
571 GCallback ok_cb, GCallback cancel_cb, | |
572 void *user_data) | |
573 { | |
15927
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
574 GntWidget *window = gnt_file_sel_new(); |
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
575 GntFileSel *sel = GNT_FILE_SEL(window); |
15822 | 576 PurpleGntFileRequest *data = g_new0(PurpleGntFileRequest, 1); |
15817 | 577 |
578 data->user_data = user_data; | |
579 data->cbs = g_new0(GCallback, 2); | |
580 data->cbs[0] = ok_cb; | |
581 data->cbs[1] = cancel_cb; | |
582 data->dialog = window; | |
583 gnt_box_set_title(GNT_BOX(window), title ? title : (savedialog ? _("Save File...") : _("Open File..."))); | |
15927
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
584 gnt_file_sel_set_current_location(sel, purple_home_dir()); /* XXX: */ |
15936 | 585 if (savedialog) |
586 gnt_file_sel_set_suggested_filename(sel, filename); | |
15927
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
587 g_signal_connect(G_OBJECT(sel->cancel), "activate", |
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
588 G_CALLBACK(file_cancel_cb), data); |
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
589 g_signal_connect(G_OBJECT(sel->select), "activate", |
846a00760176
use file select dialog
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15924
diff
changeset
|
590 G_CALLBACK(file_ok_cb), data); |
15817 | 591 g_signal_connect_swapped(G_OBJECT(window), "destroy", |
592 G_CALLBACK(file_request_destroy), data); | |
593 | |
594 gnt_widget_show(window); | |
595 | |
596 return window; | |
597 } | |
598 | |
15822 | 599 static PurpleRequestUiOps uiops = |
15817 | 600 { |
601 .request_input = finch_request_input, | |
602 .close_request = finch_close_request, | |
603 .request_choice = finch_request_choice, | |
604 .request_action = finch_request_action, | |
605 .request_fields = finch_request_fields, | |
606 .request_file = finch_request_file, | |
607 .request_folder = NULL /* No plans for this */ | |
608 }; | |
609 | |
15822 | 610 PurpleRequestUiOps *finch_request_get_ui_ops() |
15817 | 611 { |
612 return &uiops; | |
613 } | |
614 | |
615 void finch_request_init() | |
616 { | |
617 } | |
618 | |
619 void finch_request_uninit() | |
620 { | |
621 } | |
622 |