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 {
|
12779
|
55 GTK_GAIM_STATUS_BOX_TYPE_SEPARATOR,
|
|
56 GTK_GAIM_STATUS_BOX_TYPE_PRIMITIVE,
|
|
57 GTK_GAIM_STATUS_BOX_TYPE_POPULAR,
|
11739
|
58 GTK_GAIM_STATUS_BOX_TYPE_CUSTOM,
|
|
59 GTK_GAIM_STATUS_BOX_TYPE_SAVED,
|
|
60 GTK_GAIM_STATUS_BOX_NUM_TYPES
|
|
61 } GtkGaimStatusBoxItemType;
|
|
62
|
10643
|
63 typedef struct _GtkGaimStatusBox GtkGaimStatusBox;
|
|
64 typedef struct _GtkGaimStatusBoxClass GtkGaimStatusBoxClass;
|
|
65
|
|
66 struct _GtkGaimStatusBox
|
|
67 {
|
|
68 GtkComboBox parent_instance;
|
|
69
|
11739
|
70 /**
|
|
71 * This GtkListStore contains only one row--the currently selected status.
|
|
72 */
|
10643
|
73 GtkListStore *store;
|
11739
|
74
|
|
75 /**
|
|
76 * This is the dropdown GtkListStore that contains the available statuses,
|
|
77 * plus some recently used statuses, plus the "Custom..." and "Saved..."
|
|
78 * options.
|
|
79 */
|
10643
|
80 GtkListStore *dropdown_store;
|
|
81
|
11499
|
82 GaimAccount *account;
|
|
83
|
10643
|
84 GtkWidget *vbox, *sw;
|
|
85 GtkWidget *imhtml;
|
|
86 gboolean imhtml_visible;
|
|
87
|
|
88 GtkWidget *cell_view;
|
|
89 GtkCellRenderer *icon_rend;
|
|
90 GtkCellRenderer *text_rend;
|
|
91
|
|
92 GdkPixbuf *error_pixbuf;
|
|
93 int connecting_index;
|
|
94 GdkPixbuf *connecting_pixbufs[4];
|
|
95 int typing_index;
|
|
96 GdkPixbuf *typing_pixbufs[4];
|
|
97
|
|
98 gboolean connecting;
|
13123
|
99 guint typing;
|
10643
|
100
|
|
101 GtkTreeIter iter;
|
|
102 char *error;
|
11960
|
103
|
|
104 gulong status_changed_signal;
|
12619
|
105
|
13121
|
106 /*
|
|
107 * These widgets are made for renderin'
|
|
108 * That's just what they'll do
|
|
109 * One of these days these widgets
|
|
110 * Are gonna render all over you
|
|
111 */
|
12262
|
112 GtkWidget *hbox;
|
|
113 GtkWidget *toggle_button;
|
|
114 GtkWidget *vsep;
|
|
115 GtkWidget *arrow;
|
10643
|
116 };
|
|
117
|
|
118 struct _GtkGaimStatusBoxClass
|
|
119 {
|
|
120 GtkComboBoxClass parent_class;
|
|
121
|
|
122 /* signals */
|
|
123 void (* changed) (GtkComboBox *combo_box);
|
|
124
|
|
125 /* Padding for future expansion */
|
|
126 void (*_gtk_reserved0) (void);
|
|
127 void (*_gtk_reserved1) (void);
|
|
128 void (*_gtk_reserved2) (void);
|
|
129 void (*_gtk_reserved3) (void);
|
|
130 };
|
|
131
|
|
132
|
|
133 GType gtk_gaim_status_box_get_type (void) G_GNUC_CONST;
|
|
134 GtkWidget *gtk_gaim_status_box_new (void);
|
11499
|
135 GtkWidget *gtk_gaim_status_box_new_with_account (GaimAccount *);
|
10643
|
136
|
|
137 void
|
12778
|
138 gtk_gaim_status_box_add(GtkGaimStatusBox *status_box, GtkGaimStatusBoxItemType type, GdkPixbuf *pixbuf, const char *text, const char *sec_text, gpointer data);
|
10643
|
139
|
|
140 void
|
11738
|
141 gtk_gaim_status_box_add_separator(GtkGaimStatusBox *status_box);
|
|
142
|
|
143 void
|
10643
|
144 gtk_gaim_status_box_set_connecting(GtkGaimStatusBox *status_box, gboolean connecting);
|
|
145
|
|
146 void
|
|
147 gtk_gaim_status_box_pulse_connecting(GtkGaimStatusBox *status_box);
|
|
148
|
11638
|
149 char *gtk_gaim_status_box_get_message(GtkGaimStatusBox *status_box);
|
10649
|
150
|
10643
|
151 G_END_DECLS
|
|
152
|
|
153 #endif /* __GTK_GAIM_GTK_STATUS_COMBO_BOX_H__ */
|