10643
|
1 /*
|
|
2 * @file gtkstatusbox.c GTK+ Status Selection Widget
|
|
3 * @ingroup gtkui
|
|
4 *
|
|
5 * gaim
|
|
6 *
|
|
7 * Gaim is the legal property of its developers, whose names are too numerous
|
|
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
|
|
26
|
|
27 #ifndef __GTK_GAIM_STATUS_BOX_H__
|
|
28 #define __GTK_GAIM_STATUS_BOX_H__
|
|
29
|
|
30 #include <gtk/gtk.h>
|
|
31 #include "gtkimhtml.h"
|
11499
|
32 #include "account.h"
|
11677
|
33 #include "savedstatuses.h"
|
11739
|
34 #include "status.h"
|
10643
|
35 #include <gtk/gtktreemodel.h>
|
|
36 #include <gtk/gtktreeview.h>
|
|
37
|
|
38 G_BEGIN_DECLS
|
|
39
|
|
40 #define GTK_GAIM_TYPE_STATUS_BOX (gtk_gaim_status_box_get_type ())
|
|
41 #define GTK_GAIM_STATUS_BOX(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_GAIM_TYPE_STATUS_BOX, GtkGaimStatusBox))
|
|
42 #define GTK_GAIM_STATUS_BOX_CLASS(vtable) (G_TYPE_CHECK_CLASS_CAST ((vtable), GTK_GAIM_TYPE_STATUS_BOX, GtkGaimStatusBoxClass))
|
|
43 #define GTK_GAIM_IS_STATUS_BOX(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_GAIM_TYPE_STATUS_BOX))
|
|
44 #define GTK_GAIM_IS_STATUS_BOX_CLASS(vtable) (G_TYPE_CHECK_CLASS_TYPE ((vtable), GTK_GAIM_TYPE_STATUS_BOX))
|
|
45 #define GTK_GAIM_STATUS_BOX_GET_CLASS(inst) (G_TYPE_INSTANCE_GET_CLASS ((inst), GTK_GAIM_TYPE_STATUS_BOX, GtkGaimStatusBoxClass))
|
|
46
|
11739
|
47 /**
|
|
48 * This is a hidden field in the GtkStatusBox that identifies the
|
|
49 * item in the list store. The item could be a normal
|
|
50 * GaimStatusPrimitive, or it could be something special like the
|
|
51 * "Custom..." item, or "Saved..." or a GtkSeparator.
|
|
52 */
|
|
53 typedef enum
|
|
54 {
|
|
55 /*
|
|
56 * The first 0 through GAIM_STATUS_NUM_PRIMITIVES
|
|
57 * correspond to GaimStatusPrimitives.
|
|
58 */
|
|
59 GTK_GAIM_STATUS_BOX_TYPE_SEPARATOR = GAIM_STATUS_NUM_PRIMITIVES,
|
|
60 GTK_GAIM_STATUS_BOX_TYPE_CUSTOM,
|
|
61 GTK_GAIM_STATUS_BOX_TYPE_SAVED,
|
|
62 GTK_GAIM_STATUS_BOX_NUM_TYPES
|
|
63 } GtkGaimStatusBoxItemType;
|
|
64
|
10643
|
65 typedef struct _GtkGaimStatusBox GtkGaimStatusBox;
|
|
66 typedef struct _GtkGaimStatusBoxClass GtkGaimStatusBoxClass;
|
|
67
|
|
68 struct _GtkGaimStatusBox
|
|
69 {
|
|
70 GtkComboBox parent_instance;
|
|
71
|
11739
|
72 /**
|
|
73 * This GtkListStore contains only one row--the currently selected status.
|
|
74 */
|
10643
|
75 GtkListStore *store;
|
11739
|
76
|
|
77 /**
|
|
78 * This is the dropdown GtkListStore that contains the available statuses,
|
|
79 * plus some recently used statuses, plus the "Custom..." and "Saved..."
|
|
80 * options.
|
|
81 */
|
10643
|
82 GtkListStore *dropdown_store;
|
|
83
|
11499
|
84 GaimAccount *account;
|
|
85
|
10643
|
86 GtkWidget *vbox, *sw;
|
|
87 GtkWidget *imhtml;
|
|
88 gboolean imhtml_visible;
|
|
89
|
|
90 GtkWidget *cell_view;
|
|
91 GtkCellRenderer *icon_rend;
|
|
92 GtkCellRenderer *text_rend;
|
|
93
|
|
94 GdkPixbuf *error_pixbuf;
|
|
95 int connecting_index;
|
|
96 GdkPixbuf *connecting_pixbufs[4];
|
|
97 int typing_index;
|
|
98 GdkPixbuf *typing_pixbufs[4];
|
|
99
|
|
100 gboolean connecting;
|
|
101 gboolean typing;
|
|
102
|
|
103
|
|
104 GtkTreeIter iter;
|
|
105 GdkPixbuf *pixbuf;
|
|
106 char *title;
|
|
107 char *desc;
|
|
108 char *error;
|
11960
|
109
|
|
110 gulong status_changed_signal;
|
12619
|
111
|
12262
|
112 /* Widgets for renderin' */
|
|
113 GtkWidget *hbox;
|
|
114 GtkWidget *toggle_button;
|
|
115 GtkWidget *vsep;
|
|
116 GtkWidget *arrow;
|
10643
|
117 };
|
|
118
|
|
119 struct _GtkGaimStatusBoxClass
|
|
120 {
|
|
121 GtkComboBoxClass parent_class;
|
|
122
|
|
123 /* signals */
|
|
124 void (* changed) (GtkComboBox *combo_box);
|
|
125
|
|
126 /* Padding for future expansion */
|
|
127 void (*_gtk_reserved0) (void);
|
|
128 void (*_gtk_reserved1) (void);
|
|
129 void (*_gtk_reserved2) (void);
|
|
130 void (*_gtk_reserved3) (void);
|
|
131 };
|
|
132
|
|
133
|
|
134 GType gtk_gaim_status_box_get_type (void) G_GNUC_CONST;
|
|
135 GtkWidget *gtk_gaim_status_box_new (void);
|
11499
|
136 GtkWidget *gtk_gaim_status_box_new_with_account (GaimAccount *);
|
10643
|
137
|
|
138 void
|
11739
|
139 gtk_gaim_status_box_add(GtkGaimStatusBox *status_box, GtkGaimStatusBoxItemType type, GdkPixbuf *pixbuf, const char *text, const char *sec_text);
|
10643
|
140
|
|
141 void
|
11738
|
142 gtk_gaim_status_box_add_separator(GtkGaimStatusBox *status_box);
|
|
143
|
|
144 void
|
10643
|
145 gtk_gaim_status_box_set_error(GtkGaimStatusBox *status_box, const gchar *error);
|
|
146
|
|
147 void
|
|
148 gtk_gaim_status_box_set_connecting(GtkGaimStatusBox *status_box, gboolean connecting);
|
|
149
|
|
150 void
|
|
151 gtk_gaim_status_box_pulse_connecting(GtkGaimStatusBox *status_box);
|
|
152
|
11739
|
153 GtkGaimStatusBoxItemType gtk_gaim_status_box_get_active_type(GtkGaimStatusBox *status_box);
|
10649
|
154
|
11638
|
155 char *gtk_gaim_status_box_get_message(GtkGaimStatusBox *status_box);
|
10649
|
156
|
10643
|
157 G_END_DECLS
|
|
158
|
|
159 #endif /* __GTK_GAIM_GTK_STATUS_COMBO_BOX_H__ */
|