]> Dogcows Code - chaz/homebank/blob - src/ui-widgets.c
import homebank-5.2.6
[chaz/homebank] / src / ui-widgets.c
1 /* HomeBank -- Free, easy, personal accounting for everyone.
2 * Copyright (C) 1995-2019 Maxime DOYEN
3 *
4 * This file is part of HomeBank.
5 *
6 * HomeBank is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * HomeBank is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20
21 #include "homebank.h"
22
23 #include "gtk-chart.h"
24 #include "ui-widgets.h"
25
26 /****************************************************************************/
27 /* Debug macros */
28 /****************************************************************************/
29 #define MYDEBUG 0
30
31 #if MYDEBUG
32 #define DB(x) (x);
33 #else
34 #define DB(x);
35 #endif
36
37 /* our global datas */
38 extern struct HomeBank *GLOBALS;
39
40
41 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
42
43
44 extern HbKvData CYA_FLT_RANGE[];
45
46
47 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
48
49 //TODO: only WEIGHT & SCALE are used for now
50 void
51 gimp_label_set_attributes (GtkLabel *label,
52 ...)
53 {
54 PangoAttribute *attr = NULL;
55 PangoAttrList *attrs;
56 va_list args;
57
58 g_return_if_fail (GTK_IS_LABEL (label));
59
60 attrs = pango_attr_list_new ();
61
62 va_start (args, label);
63
64 do
65 {
66 PangoAttrType attr_type = va_arg (args, PangoAttrType);
67
68 if (attr_type <= 0)
69 attr_type = PANGO_ATTR_INVALID;
70
71 switch (attr_type)
72 {
73 case PANGO_ATTR_LANGUAGE:
74 attr = pango_attr_language_new (va_arg (args, PangoLanguage *));
75 break;
76
77 case PANGO_ATTR_FAMILY:
78 attr = pango_attr_family_new (va_arg (args, const gchar *));
79 break;
80
81 case PANGO_ATTR_STYLE:
82 attr = pango_attr_style_new (va_arg (args, PangoStyle));
83 break;
84
85 case PANGO_ATTR_WEIGHT:
86 attr = pango_attr_weight_new (va_arg (args, PangoWeight));
87 break;
88
89 case PANGO_ATTR_VARIANT:
90 attr = pango_attr_variant_new (va_arg (args, PangoVariant));
91 break;
92
93 case PANGO_ATTR_STRETCH:
94 attr = pango_attr_stretch_new (va_arg (args, PangoStretch));
95 break;
96
97 case PANGO_ATTR_SIZE:
98 attr = pango_attr_size_new (va_arg (args, gint));
99 break;
100
101 case PANGO_ATTR_FONT_DESC:
102 attr = pango_attr_font_desc_new (va_arg (args,
103 const PangoFontDescription *));
104 break;
105
106 case PANGO_ATTR_FOREGROUND:
107 {
108 const PangoColor *color = va_arg (args, const PangoColor *);
109
110 attr = pango_attr_foreground_new (color->red,
111 color->green,
112 color->blue);
113 }
114 break;
115
116 case PANGO_ATTR_BACKGROUND:
117 {
118 const PangoColor *color = va_arg (args, const PangoColor *);
119
120 attr = pango_attr_background_new (color->red,
121 color->green,
122 color->blue);
123 }
124 break;
125
126 case PANGO_ATTR_UNDERLINE:
127 attr = pango_attr_underline_new (va_arg (args, PangoUnderline));
128 break;
129
130 case PANGO_ATTR_STRIKETHROUGH:
131 attr = pango_attr_strikethrough_new (va_arg (args, gboolean));
132 break;
133
134 case PANGO_ATTR_RISE:
135 attr = pango_attr_rise_new (va_arg (args, gint));
136 break;
137
138 case PANGO_ATTR_SCALE:
139 attr = pango_attr_scale_new (va_arg (args, gdouble));
140 break;
141
142 default:
143 //g_warning ("%s: invalid PangoAttribute type %d", G_STRFUNC, attr_type);
144 case PANGO_ATTR_INVALID:
145 attr = NULL;
146 break;
147 }
148
149 if (attr)
150 {
151 attr->start_index = 0;
152 attr->end_index = -1;
153 pango_attr_list_insert (attrs, attr);
154 }
155 }
156 while (attr);
157
158 va_end (args);
159
160 gtk_label_set_attributes (label, attrs);
161 pango_attr_list_unref (attrs);
162 }
163
164
165 void hb_widget_visible(GtkWidget *widget, gboolean visible)
166 {
167 if(!GTK_IS_WIDGET(widget))
168 return;
169
170 if(visible)
171 {
172 gtk_widget_show(widget);
173 }
174 else
175 {
176 gtk_widget_hide(widget);
177 }
178 }
179
180
181 void ui_label_set_integer(GtkLabel *label, gint value)
182 {
183 gchar buf[16];
184
185 g_snprintf(buf, 16, "%d", value);
186 gtk_label_set_text (label, buf);
187 }
188
189
190 void ui_gtk_entry_tag_name_append(GtkEntry *entry, gchar *tagname)
191 {
192 GtkEntryBuffer *buffer;
193 const gchar *text;
194 guint len;
195
196 text = gtk_entry_get_text(entry);
197 if( g_strstr_len(text, -1, tagname) == NULL )
198 {
199 DB( g_print(" gtkentry append tagname '%'\n", tagname) );
200 buffer = gtk_entry_get_buffer(GTK_ENTRY(entry));
201 if(buffer)
202 {
203 len = gtk_entry_buffer_get_length(buffer);
204 DB( g_print("- add ' %s' %p %d\n", tagname, buffer, len) );
205 if(len > 0)
206 gtk_entry_buffer_insert_text(buffer, len, " ", 1);
207 gtk_entry_buffer_insert_text(buffer, len+1, tagname, -1);
208 }
209 }
210
211 }
212
213
214 void ui_gtk_entry_set_text(GtkWidget *widget, gchar *text)
215 {
216 DB( g_print(" set text to '%s'\n", text) );
217
218 if( text != NULL )
219 gtk_entry_set_text(GTK_ENTRY(widget), text);
220 else
221 gtk_entry_set_text(GTK_ENTRY(widget), "");
222 }
223
224 void ui_gtk_entry_replace_text(GtkWidget *widget, gchar **storage)
225 {
226 const gchar *text;
227
228 DB( g_print(" storage is '%p' at '%p'\n", *storage, storage) );
229
230 /* free any previous string */
231 if( *storage != NULL )
232 {
233 g_free(*storage);
234 }
235
236 *storage = NULL;
237 text = gtk_entry_get_text(GTK_ENTRY(widget));
238 *storage = g_strdup(text);
239 }
240
241
242 GtkWidget *make_clicklabel(gchar *id, gchar *str)
243 {
244 GtkWidget *label;
245 gchar buffer[255];
246
247 g_snprintf(buffer, 254, "<a href=\"%s\">%s</a>", id, str);
248 label = gtk_label_new(buffer);
249 gtk_label_set_use_markup (GTK_LABEL (label), TRUE);
250 gtk_label_set_track_visited_links(GTK_LABEL(label), FALSE);
251 gtk_widget_set_halign(label, GTK_ALIGN_START);
252
253 return GTK_WIDGET(label);
254 }
255
256
257 GtkWidget *make_label_group(gchar *str)
258 {
259 GtkWidget *label = gtk_label_new (str);
260
261 gtk_widget_set_valign (label, GTK_ALIGN_CENTER);
262 gtk_widget_set_halign (label, GTK_ALIGN_START);
263 gimp_label_set_attributes(GTK_LABEL(label), PANGO_ATTR_WEIGHT, PANGO_WEIGHT_BOLD, -1);
264 return label;
265 }
266
267
268 GtkWidget *make_label_widget(char *str)
269 {
270 GtkWidget *label = gtk_label_new_with_mnemonic (str);
271
272 gtk_widget_set_valign (label, GTK_ALIGN_CENTER);
273 gtk_widget_set_halign (label, GTK_ALIGN_END);
274 return label;
275 }
276
277
278 GtkWidget *make_label(char *str, gfloat xalign, gfloat yalign)
279 {
280 GtkWidget *label = gtk_label_new_with_mnemonic (str);
281
282 #if GTK_MINOR_VERSION >= 16
283 gtk_label_set_xalign(GTK_LABEL(label), xalign);
284 gtk_label_set_yalign(GTK_LABEL(label), yalign);
285 #else
286 gtk_misc_set_alignment (GTK_MISC (label), xalign, yalign);
287 #endif
288 return label;
289 }
290
291
292 /*
293 **
294 */
295 GtkWidget *make_text(gfloat xalign)
296 {
297 GtkWidget *entry;
298
299 entry = gtk_entry_new ();
300 gtk_editable_set_editable (GTK_EDITABLE(entry), FALSE);
301 g_object_set(entry, "xalign", xalign, NULL);
302 return entry;
303 }
304
305
306 GtkWidget *make_search(void)
307 {
308 GtkWidget *search;
309
310 search = gtk_search_entry_new();
311 gtk_entry_set_placeholder_text(GTK_ENTRY(search), _("Search...") );
312
313 return search;
314 }
315
316
317
318 /*
319 **
320 */
321 GtkWidget *make_string(GtkWidget *label)
322 {
323 GtkWidget *entry;
324
325 entry = gtk_entry_new ();
326
327 if(label)
328 gtk_label_set_mnemonic_widget (GTK_LABEL(label), entry);
329
330 return entry;
331 }
332
333
334 GtkWidget *make_image_button(gchar *icon_name, gchar *tooltip_text)
335 {
336 GtkWidget *button, *image;
337
338 //todo 3.10 use gtk_button_new_from_icon_name
339
340 button = gtk_button_new();
341 image = gtk_image_new_from_icon_name (icon_name, GTK_ICON_SIZE_BUTTON);
342 g_object_set (button, "image", image, NULL);
343 if(tooltip_text != NULL)
344 gtk_widget_set_tooltip_text(button, tooltip_text);
345
346 return button;
347 }
348
349
350
351 /*
352 **
353 */
354 GtkWidget *make_memo_entry(GtkWidget *label)
355 {
356 GtkListStore *store;
357 GtkWidget *entry;
358 GtkEntryCompletion *completion;
359 GList *lmem, *list;
360
361 store = gtk_list_store_new (1, G_TYPE_STRING);
362
363 completion = gtk_entry_completion_new ();
364 gtk_entry_completion_set_model (completion, GTK_TREE_MODEL(store));
365 gtk_entry_completion_set_text_column (completion, 0);
366
367 entry = gtk_entry_new ();
368 gtk_entry_set_completion (GTK_ENTRY (entry), completion);
369
370 g_object_unref(store);
371
372 //populate
373 //gtk_list_store_clear (GTK_LIST_STORE(store));
374
375 lmem = list = g_hash_table_get_keys(GLOBALS->h_memo);
376 while (list != NULL)
377 {
378 GtkTreeIter iter;
379
380 //gtk_list_store_append (GTK_LIST_STORE(store), &iter);
381 //gtk_list_store_set (GTK_LIST_STORE(store), &iter, 0, list->data, -1);
382 gtk_list_store_insert_with_values(GTK_LIST_STORE(store), &iter, -1,
383 0, list->data,
384 -1);
385
386 list = g_list_next(list);
387 }
388
389 g_list_free(lmem);
390
391 if(label)
392 gtk_label_set_mnemonic_widget (GTK_LABEL(label), entry);
393
394 return entry;
395 }
396
397
398 /*
399 **
400 */
401 GtkWidget *make_string_maxlength(GtkWidget *label, guint max_length)
402 {
403 GtkWidget *entry;
404
405 entry = make_string(label);
406 gtk_entry_set_width_chars(GTK_ENTRY(entry), max_length+2);
407 gtk_entry_set_max_length(GTK_ENTRY(entry), max_length);
408
409 return entry;
410 }
411
412
413 static void hb_amount_insert_text_handler (GtkEntry *entry, const gchar *text, gint length, gint *position, gpointer data)
414 {
415 GtkEditable *editable = GTK_EDITABLE(entry);
416 gint i, digits, count=0, dcpos=-1;
417 gchar *clntxt;
418
419 DB( g_print("-----\ninsert_text-handler: instxt:%s pos:%d len:%d\n", text, *position, length) );
420
421 digits = gtk_spin_button_get_digits(GTK_SPIN_BUTTON(entry));
422
423 // most common : only 1 char to be inserted
424 if( length == 1 )
425 {
426 const gchar *curtxt = gtk_entry_get_text(entry);
427
428 for (i=0 ; curtxt[i]!='\0' ; i++)
429 {
430 if(curtxt[i]==',' || curtxt[i]=='.')
431 dcpos = i;
432 }
433 DB( g_print(" dcpos:'%d'\n", dcpos) );
434
435 clntxt = g_new0 (gchar, length+1);
436 for (i=0 ; i < length ; i++)
437 {
438 if( g_ascii_isdigit(text[i]) && ( (*position <= dcpos + digits) || dcpos < 0) )
439 goto doinsert;
440
441 if( text[i]=='-' && *position==0 ) /* minus sign only at position 0 */
442 goto doinsert;
443
444 if( dcpos < 0 && (text[i]=='.' || text[i]==',') ) /* decimal separator if not in previous string */
445 clntxt[count++] = '.';
446
447 continue;
448
449 doinsert:
450 clntxt[count++] = text[i];
451 }
452 }
453 // less common: paste a full text
454 else
455 {
456 clntxt = hb_string_dup_raw_amount_clean(text, digits);
457 count = strlen(clntxt);
458 }
459
460 if (count > 0)
461 {
462 DB( g_print(" insert %d char '%s' at %d\n", count, clntxt, *position) );
463 g_signal_handlers_block_by_func (G_OBJECT (editable), G_CALLBACK (hb_amount_insert_text_handler), data);
464 gtk_editable_insert_text (editable, clntxt, count, position);
465 g_signal_handlers_unblock_by_func (G_OBJECT (editable), G_CALLBACK (hb_amount_insert_text_handler), data);
466 }
467
468 g_free (clntxt);
469
470 g_signal_stop_emission_by_name (G_OBJECT (editable), "insert-text");
471 }
472
473
474 GtkWidget *make_amount(GtkWidget *label)
475 {
476 GtkWidget *spinner;
477 GtkAdjustment *adj;
478
479 //adj = (GtkAdjustment *) gtk_adjustment_new (0.0, -G_MAXDOUBLE, G_MAXDOUBLE, 0.01, 1.0, 0.0);
480 adj = (GtkAdjustment *) gtk_adjustment_new (0.0, -8589934588, 8589934588, 0.01, 1.0, 0.0);
481 spinner = gtk_spin_button_new (adj, 1.0, 2);
482 g_object_set(spinner, "xalign", 1.0, NULL);
483
484 if(label)
485 gtk_label_set_mnemonic_widget (GTK_LABEL(label), spinner);
486
487 g_signal_connect(G_OBJECT(spinner), "insert-text",
488 G_CALLBACK(hb_amount_insert_text_handler),
489 NULL);
490
491 return spinner;
492 }
493
494
495 GtkWidget *make_exchange_rate(GtkWidget *label)
496 {
497 GtkWidget *spinner;
498 GtkAdjustment *adj;
499
500 adj = (GtkAdjustment *) gtk_adjustment_new (0.0, 0.0, 99999, 0.01, 1.0, 0.0);
501 spinner = gtk_spin_button_new (adj, 1.0, 8);
502 //gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE);
503 gtk_spin_button_set_numeric (GTK_SPIN_BUTTON (spinner), TRUE);
504 g_object_set(spinner, "xalign", 1.0, NULL);
505
506 if(label)
507 gtk_label_set_mnemonic_widget (GTK_LABEL(label), spinner);
508
509 return spinner;
510 }
511
512 /*
513 **
514 */
515 GtkWidget *make_numeric(GtkWidget *label, gdouble min, gdouble max)
516 {
517 GtkWidget *spinner;
518 GtkAdjustment *adj;
519
520 adj = (GtkAdjustment *) gtk_adjustment_new (0.0, min, max, 1.0, 10.0, 0.0);
521 spinner = gtk_spin_button_new (adj, 0, 0);
522 //gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE);
523 gtk_spin_button_set_numeric (GTK_SPIN_BUTTON (spinner), TRUE);
524 g_object_set(spinner, "xalign", 1.0, NULL);
525
526 if(label)
527 gtk_label_set_mnemonic_widget (GTK_LABEL(label), spinner);
528
529 return spinner;
530 }
531
532 /*
533 **
534 */
535 GtkWidget *make_scale(GtkWidget *label)
536 {
537 GtkWidget *scale;
538
539 scale = gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, GTK_CHART_MINBARW, GTK_CHART_SPANBARW, 1.0);
540 gtk_scale_set_draw_value(GTK_SCALE(scale), FALSE);
541 gtk_range_set_value(GTK_RANGE(scale), GTK_CHART_BARW);
542
543 if(label)
544 gtk_label_set_mnemonic_widget (GTK_LABEL(label), scale);
545
546 return scale;
547 }
548
549 /*
550 **
551 */
552 GtkWidget *make_long(GtkWidget *label)
553 {
554 GtkWidget *spinner;
555
556 spinner = make_numeric(label, 0.0, G_MAXINT);
557 return spinner;
558 }
559
560
561 GtkWidget *make_year(GtkWidget *label)
562 {
563 GtkWidget *spinner;
564 GtkAdjustment *adj;
565
566 adj = (GtkAdjustment *) gtk_adjustment_new (0.0, 1900, 2200, 1.0, 10.0, 0.0);
567 spinner = gtk_spin_button_new (adj, 0, 0);
568 gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE);
569 gtk_spin_button_set_numeric (GTK_SPIN_BUTTON (spinner), TRUE);
570 g_object_set(spinner, "xalign", 1.0, NULL);
571
572 if(label)
573 gtk_label_set_mnemonic_widget (GTK_LABEL(label), spinner);
574
575 return spinner;
576 }
577
578
579 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
580
581
582 gint hbtk_radio_button_get_active (GtkContainer *container)
583 {
584 GList *lchild, *list;
585 GtkWidget *radio;
586 gint i, retval = 0;
587
588 if(!GTK_IS_CONTAINER(container))
589 return -1;
590
591 lchild = list = gtk_container_get_children (container);
592 for(i=0;list != NULL;i++)
593 {
594 radio = list->data;
595 if(GTK_IS_TOGGLE_BUTTON(radio))
596 {
597 if( gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(radio)) == TRUE )
598 {
599 retval = i;
600 break;
601 }
602 }
603 list = g_list_next(list);
604 }
605 g_list_free(lchild);
606
607 return retval;
608 }
609
610
611 void hbtk_radio_button_set_active (GtkContainer *container, gint active)
612 {
613 GList *lchild, *list;
614 GtkWidget *radio;
615
616 if(!GTK_IS_CONTAINER(container))
617 return;
618
619 lchild = list = gtk_container_get_children (container);
620 radio = g_list_nth_data (list, active);
621 if(radio != NULL && GTK_IS_TOGGLE_BUTTON(radio))
622 {
623 gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(radio), TRUE);
624 }
625 g_list_free(lchild);
626 }
627
628
629 GtkWidget *hbtk_radio_button_get_nth (GtkContainer *container, gint nth)
630 {
631 GList *lchild, *list;
632 GtkWidget *radio;
633
634 if(!GTK_IS_CONTAINER(container))
635 return NULL;
636
637 lchild = list = gtk_container_get_children (container);
638 radio = g_list_nth_data (list, nth);
639 g_list_free(lchild);
640 return radio; //may return NULL
641 }
642
643
644 void hbtk_radio_button_unblock_by_func(GtkContainer *container, GCallback c_handler, gpointer data)
645 {
646 GList *lchild, *list;
647 GtkWidget *radio;
648 gint i;
649
650 if(!GTK_IS_CONTAINER(container))
651 return;
652
653 lchild = list = gtk_container_get_children (container);
654 for(i=0;list != NULL;i++)
655 {
656 radio = list->data;
657 if(GTK_IS_TOGGLE_BUTTON(radio))
658 {
659 g_signal_handlers_unblock_by_func (radio, c_handler, data);
660 }
661 list = g_list_next(list);
662 }
663 g_list_free(lchild);
664 }
665
666
667 void hbtk_radio_button_block_by_func(GtkContainer *container, GCallback c_handler, gpointer data)
668 {
669 GList *lchild, *list;
670 GtkWidget *radio;
671 gint i;
672
673 if(!GTK_IS_CONTAINER(container))
674 return;
675
676 lchild = list = gtk_container_get_children (container);
677 for(i=0;list != NULL;i++)
678 {
679 radio = list->data;
680 if(GTK_IS_TOGGLE_BUTTON(radio))
681 {
682 g_signal_handlers_block_by_func (radio, c_handler, data);
683 }
684 list = g_list_next(list);
685 }
686 g_list_free(lchild);
687 }
688
689
690 void hbtk_radio_button_connect(GtkContainer *container, const gchar *detailed_signal, GCallback c_handler, gpointer data)
691 {
692 GList *lchild, *list;
693 GtkWidget *radio;
694 gint i;
695
696 if(!GTK_IS_CONTAINER(container))
697 return;
698
699 lchild = list = gtk_container_get_children (container);
700 for(i=0;list != NULL;i++)
701 {
702 radio = list->data;
703 if(GTK_IS_TOGGLE_BUTTON(radio))
704 {
705 g_signal_connect (radio, "toggled", c_handler, data);
706 }
707 list = g_list_next(list);
708 }
709 g_list_free(lchild);
710
711 }
712
713
714 GtkWidget *hbtk_radio_button_new (gchar **items, gboolean buttonstyle)
715 {
716 GtkWidget *box, *button, *newbutton;
717 guint i;
718
719 box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
720
721 button = gtk_radio_button_new_with_label (NULL, _(items[0]));
722 gtk_toggle_button_set_mode (GTK_TOGGLE_BUTTON (button), !buttonstyle);
723 gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 0);
724 for (i = 1; items[i] != NULL; i++)
725 {
726 newbutton = gtk_radio_button_new_with_label_from_widget (GTK_RADIO_BUTTON (button), _(items[i]));
727 gtk_toggle_button_set_mode (GTK_TOGGLE_BUTTON (newbutton), !buttonstyle);
728 gtk_box_pack_start (GTK_BOX (box), newbutton, FALSE, FALSE, 0);
729 }
730
731 if(buttonstyle)
732 {
733 gtk_style_context_add_class (gtk_widget_get_style_context (box), GTK_STYLE_CLASS_LINKED);
734 gtk_style_context_add_class (gtk_widget_get_style_context (box), GTK_STYLE_CLASS_RAISED);
735 }
736
737 return box;
738 }
739
740
741 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
742
743
744 static gboolean
745 is_separator (GtkTreeModel *model,
746 GtkTreeIter *iter,
747 gpointer data)
748 {
749 //GtkTreePath *path;
750 gboolean retval;
751 gchar *txt;
752
753 gtk_tree_model_get (model, iter, 0, &txt, -1);
754
755 retval = *txt == 0 ? TRUE : FALSE;
756 //path = gtk_tree_model_get_path (model, iter);
757 //result = gtk_tree_path_get_indices (path)[0] == 4;
758 //gtk_tree_path_free (path);
759
760 //leak
761 g_free(txt);
762
763
764 return retval;
765 }
766
767
768 GtkWidget *make_cycle(GtkWidget *label, gchar **items)
769 {
770 GtkWidget *combobox;
771 guint i;
772
773 combobox = gtk_combo_box_text_new ();
774
775 for (i = 0; items[i] != NULL; i++)
776 {
777 if(*items[i] != 0)
778 gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT(combobox), _(items[i]));
779 else
780 gtk_combo_box_text_append_text (GTK_COMBO_BOX_TEXT(combobox), "");
781 }
782 gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
783 gtk_combo_box_set_row_separator_func (GTK_COMBO_BOX (combobox), is_separator, NULL, NULL);
784
785 if(label)
786 gtk_label_set_mnemonic_widget (GTK_LABEL(label), combobox);
787
788 return combobox;
789 }
790
791
792 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
793
794
795 #define HB_KV_BUFFER_MAX_LEN 8
796 #define HB_KV_ITEMS_MAX_LEN 32
797
798 gchar *hbtk_get_label(HbKvData *kvdata, guint32 key)
799 {
800 gchar *retval = NULL;
801 guint32 i;
802
803 for(i=0;i<HB_KV_ITEMS_MAX_LEN;i++)
804 {
805 HbKvData *tmp = &kvdata[i];
806 if( tmp->name == NULL )
807 break;
808 if( tmp->key == key )
809 {
810 //#1820372
811 retval = (gchar *)_(tmp->name);
812 break;
813 }
814 }
815 return retval;
816 }
817
818
819 static gboolean hbtk_combo_box_is_separator (GtkTreeModel *model, GtkTreeIter *iter, gpointer data)
820 {
821 //GtkTreePath *path;
822 gboolean retval;
823 gchar *txt;
824
825 gtk_tree_model_get (model, iter, 0, &txt, -1);
826 retval = *txt == 0 ? TRUE : FALSE;
827 //leak
828 g_free(txt);
829
830 return retval;
831 }
832
833
834 guint32 hbtk_combo_box_get_active_id (GtkComboBoxText *combobox)
835 {
836 const gchar* buf;
837 guint32 retval;
838
839 buf = gtk_combo_box_get_active_id(GTK_COMBO_BOX(combobox));
840 retval = buf != NULL ? atoi(buf) : 0;
841
842 return retval;
843 }
844
845
846 void hbtk_combo_box_set_active_id (GtkComboBoxText *combobox, guint32 key)
847 {
848 gchar buf[HB_KV_BUFFER_MAX_LEN];
849
850 g_snprintf(buf, HB_KV_BUFFER_MAX_LEN-1, "%d", key);
851 gtk_combo_box_set_active_id(GTK_COMBO_BOX(combobox), buf);
852 }
853
854
855 void hbtk_combo_box_text_append (GtkComboBoxText *combobox, guint32 key, gchar *text)
856 {
857 gchar buf[HB_KV_BUFFER_MAX_LEN];
858
859 g_snprintf(buf, HB_KV_BUFFER_MAX_LEN-1, "%d", key);
860 gtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(combobox), buf, text);
861 }
862
863
864 GtkWidget *hbtk_combo_box_new (GtkWidget *label)
865 {
866 GtkWidget *combobox;
867
868 combobox = gtk_combo_box_text_new();
869
870 if(label)
871 gtk_label_set_mnemonic_widget (GTK_LABEL(label), combobox);
872
873 return combobox;
874 }
875
876
877 GtkWidget *hbtk_combo_box_new_with_data (GtkWidget *label, HbKvData *kvdata)
878 {
879 GtkWidget *combobox = hbtk_combo_box_new(label);
880 HbKvData *tmp;
881 gboolean hassep;
882 guint32 i;
883
884 hassep = FALSE;
885 for(i=0;i<HB_KV_ITEMS_MAX_LEN;i++)
886 {
887 tmp = &kvdata[i];
888 if( tmp->name == NULL )
889 break;
890 if( *tmp->name != 0 )
891 {
892 hbtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(combobox), tmp->key, (gchar *)_(tmp->name));
893 }
894 else
895 {
896 hbtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(combobox), tmp->key, (gchar *)"");
897 hassep = TRUE;
898 }
899 }
900 gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
901
902 if(hassep)
903 gtk_combo_box_set_row_separator_func (GTK_COMBO_BOX (combobox), hbtk_combo_box_is_separator, NULL, NULL);
904
905 return combobox;
906 }
907
908
909 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
910
911 static void
912 set_sensitive (GtkCellLayout *cell_layout,
913 GtkCellRenderer *cell,
914 GtkTreeModel *tree_model,
915 GtkTreeIter *iter,
916 gpointer data)
917 {
918 GtkTreePath *path;
919 gint *indices;
920 gboolean sensitive;
921
922 path = gtk_tree_model_get_path (tree_model, iter);
923 indices = gtk_tree_path_get_indices (path);
924 sensitive = indices[0] != FLT_RANGE_OTHER;
925 gtk_tree_path_free (path);
926
927 g_object_set (cell, "sensitive", sensitive, NULL);
928 }
929
930
931
932 GtkWidget *make_daterange(GtkWidget *label, guint dspmode)
933 {
934 GtkWidget *combobox = hbtk_combo_box_new(label);
935 GList *renderers, *list;
936 HbKvData *tmp, *kvdata = CYA_FLT_RANGE;
937 guint32 i;
938
939 for(i=0;i<HB_KV_ITEMS_MAX_LEN;i++)
940 {
941 tmp = &kvdata[i];
942 if( tmp->name == NULL )
943 break;
944
945 if( (tmp->key == FLT_RANGE_OTHER) )
946 {
947 if( dspmode == DATE_RANGE_CUSTOM_DISABLE )
948 {
949 renderers = gtk_cell_layout_get_cells (GTK_CELL_LAYOUT(combobox));
950 if(g_list_length(renderers) == 1)
951 {
952 list = g_list_first(renderers);
953 gtk_cell_layout_set_cell_data_func (GTK_CELL_LAYOUT (combobox),
954 list->data,
955 set_sensitive,
956 NULL, NULL);
957 }
958 g_list_free(renderers);
959 }
960 else
961 if( dspmode == DATE_RANGE_CUSTOM_HIDE )
962 {
963 //if hide, we do not show it
964 i++;
965 continue;
966 }
967 }
968
969 hbtk_combo_box_text_append(GTK_COMBO_BOX_TEXT(combobox), tmp->key, (*tmp->name != 0) ? (gchar *)_(tmp->name) : (gchar *)"");
970 }
971
972 gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
973 gtk_combo_box_set_row_separator_func (GTK_COMBO_BOX (combobox), hbtk_combo_box_is_separator, NULL, NULL);
974
975 return combobox;
976 }
977
978
979 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
980
981 /*
982 id ofx english french
983 ---------------------------------------------------------------------
984 0 -------- (none) (aucun)
985 1 -------- credit card carte de crédit
986 2 OFX_CHECK Check cheque
987 3 OFX_CASH Cash withdrawal retrait espece
988 4 OFX_XFER Transfer virement
989 5 -------- internal transfer virement compte
990 6 -------- (debit card) (carte de paiement
991 7 OFX_REPEATPMT Repeating payment/standing order Paiement recurrent/Virement auto.
992
993 8 OFX_PAYMENT Electronic payment télépaiement
994 9 OFX_DEP Deposit dépôt
995 10 OFX_FEE FI fee frais bancaires
996
997
998 OFX_DIRECTDEBIT Merchant initiated debit prelevement
999 OFX_OTHER Somer other type of transaction autre
1000
1001 other OFX values:
1002
1003 OFX_CREDIT Generic credit
1004 OFX_DEBIT Generic debit
1005 OFX_INT Interest earned or paid (Note: Depends on signage of amount)
1006 OFX_DIV Dividend
1007 OFX_SRVCHG Service charge
1008 -OFX_DEP Deposit
1009 OFX_ATM ATM debit or credit (Note: Depends on signage of amount)
1010 OFX_POS Point of sale debit or credit (Note: Depends on signage of amount)
1011 -OFX_XFER Transfer
1012 -OFX_CHECK Check
1013 -OFX_PAYMENT Electronic payment
1014 -OFX_CASH Cash withdrawal
1015 OFX_DIRECTDEP Direct deposit
1016 OFX_DIRECTDEBIT Merchant initiated debit
1017 -OFX_REPEATPMT Repeating payment/standing order
1018 OFX_OTHER Somer other type of transaction
1019 */
1020
1021 enum
1022 {
1023 LST_PAYMODE_ICONNAME,
1024 LST_PAYMODE_LABEL,
1025 NUM_LST_PAYMODE
1026 };
1027
1028 char *paymode_iconnames[NUM_PAYMODE_MAX] =
1029 {
1030 "pm-none",
1031 "pm-ccard",
1032 "pm-check",
1033 "pm-cash" ,
1034 "pm-transfer",
1035 "pm-intransfer",
1036 "pm-dcard",
1037 "pm-standingorder",
1038 "pm-epayment",
1039 "pm-deposit",
1040 "pm-fifee",
1041 "pm-directdebit"
1042 };
1043
1044 char *paymode_label_names[NUM_PAYMODE_MAX] =
1045 {
1046 N_("(none)"),
1047 N_("Credit card"),
1048 N_("Check"),
1049 N_("Cash"),
1050 N_("Transfer"),
1051 N_("Internal transfer"),
1052 N_("Debit card"),
1053 N_("Standing order"),
1054 N_("Electronic payment"),
1055 N_("Deposit"),
1056 //TRANSLATORS: Financial institution fee
1057 N_("FI fee"),
1058 N_("Direct Debit")
1059 };
1060
1061 /* nota: used in ui-filter */
1062 gchar *get_paymode_icon_name(gint index)
1063 {
1064 if(index >= NUM_PAYMODE_MAX)
1065 return NULL;
1066
1067 return paymode_iconnames[index];
1068 }
1069
1070
1071 /*
1072 ** Make a paymode combobox widget
1073 */
1074
1075 static void
1076 paymode_set_sensitive (GtkCellLayout *cell_layout,
1077 GtkCellRenderer *cell,
1078 GtkTreeModel *tree_model,
1079 GtkTreeIter *iter,
1080 gpointer data)
1081 {
1082 GtkTreePath *path;
1083 gint *indices;
1084 gboolean sensitive;
1085
1086 path = gtk_tree_model_get_path (tree_model, iter);
1087 indices = gtk_tree_path_get_indices (path);
1088 sensitive = (indices[0] == PAYMODE_INTXFER) ? FALSE : TRUE;
1089 gtk_tree_path_free (path);
1090
1091
1092 g_object_set (cell, "sensitive", sensitive, NULL);
1093 }
1094
1095
1096
1097 static GtkWidget *make_paymode_internal(GtkWidget *label, gboolean intxfer)
1098 {
1099 GtkListStore *store;
1100 GtkTreeIter iter;
1101 GtkWidget *combobox;
1102 GtkCellRenderer *renderer, *r1, *r2;
1103 guint i;
1104
1105 store = gtk_list_store_new (
1106 NUM_LST_PAYMODE,
1107 G_TYPE_STRING,
1108 G_TYPE_STRING
1109 );
1110
1111 combobox = gtk_combo_box_new_with_model(GTK_TREE_MODEL(store));
1112 g_object_unref(store);
1113
1114 renderer = r1 = gtk_cell_renderer_pixbuf_new();
1115 gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(combobox), renderer, FALSE);
1116 gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT(combobox), renderer, "icon-name", LST_PAYMODE_ICONNAME);
1117
1118 renderer = r2 = gtk_cell_renderer_text_new();
1119 gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(combobox), renderer, FALSE);
1120 gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT(combobox), renderer, "text", LST_PAYMODE_LABEL);
1121
1122
1123 if( intxfer == FALSE )
1124 {
1125 gtk_cell_layout_set_cell_data_func (GTK_CELL_LAYOUT (combobox),
1126 r1,
1127 paymode_set_sensitive,
1128 NULL, NULL);
1129 gtk_cell_layout_set_cell_data_func (GTK_CELL_LAYOUT (combobox),
1130 r2,
1131 paymode_set_sensitive,
1132 NULL, NULL);
1133 }
1134
1135 //populate our combobox model
1136 for(i=0;i<NUM_PAYMODE_MAX;i++)
1137 {
1138 gtk_list_store_append(store, &iter);
1139 gtk_list_store_set(store, &iter,
1140 LST_PAYMODE_ICONNAME, paymode_iconnames[i],
1141 LST_PAYMODE_LABEL, _(paymode_label_names[i]),
1142 -1);
1143 }
1144
1145 gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
1146
1147 if(label)
1148 gtk_label_set_mnemonic_widget (GTK_LABEL(label), combobox);
1149
1150 return combobox;
1151 }
1152
1153
1154
1155 GtkWidget *make_paymode(GtkWidget *label)
1156 {
1157 return make_paymode_internal(label, TRUE);
1158 }
1159
1160 GtkWidget *make_paymode_nointxfer(GtkWidget *label)
1161 {
1162 return make_paymode_internal(label, FALSE);
1163 }
1164
1165
1166 /* = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = */
1167
1168 #define NUM_NAINEX_MAX 3
1169
1170 enum
1171 {
1172 LST_NAINEX_ICONNAME,
1173 LST_NAINEX_LABEL,
1174 NUM_LST_NAINEX
1175 };
1176
1177 char *nainex_iconnames[NUM_NAINEX_MAX] =
1178 {
1179 "flt-inactive",
1180 "flt-include",
1181 "flt-exclude",
1182 };
1183
1184 extern gchar *nainex_label_names[];
1185
1186 /*
1187 ** Make a nainex combobox widget
1188 */
1189 GtkWidget *make_nainex(GtkWidget *label)
1190 {
1191 GtkListStore *store;
1192 GtkTreeIter iter;
1193 GtkWidget *combobox;
1194 GtkCellRenderer *renderer;
1195 guint i;
1196
1197 //store
1198 store = gtk_list_store_new (
1199 NUM_LST_NAINEX,
1200 G_TYPE_STRING,
1201 G_TYPE_STRING
1202 );
1203
1204 //combobox
1205 combobox = gtk_combo_box_new_with_model(GTK_TREE_MODEL(store));
1206
1207 //column 1
1208 renderer = gtk_cell_renderer_pixbuf_new();
1209 gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(combobox), renderer, FALSE);
1210 gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT(combobox), renderer, "icon-name", LST_NAINEX_ICONNAME);
1211
1212 renderer = gtk_cell_renderer_text_new();
1213 gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(combobox), renderer, FALSE);
1214 gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT(combobox), renderer, "text", LST_NAINEX_LABEL);
1215
1216 gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
1217
1218 //populate our combobox model
1219 for(i=0;i<NUM_NAINEX_MAX;i++)
1220 {
1221 gtk_list_store_append(store, &iter);
1222 gtk_list_store_set(store, &iter,
1223 LST_NAINEX_ICONNAME, nainex_iconnames[i],
1224 LST_NAINEX_LABEL, _(nainex_label_names[i]),
1225 -1);
1226 }
1227 gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
1228
1229 if(label)
1230 gtk_label_set_mnemonic_widget (GTK_LABEL(label), combobox);
1231
1232 return combobox;
1233 }
1234
This page took 0.088237 seconds and 4 git commands to generate.