gaim/gaim

White McSpacen

2005-04-24, Mark Doliner
449548d1e3c7
Parents a838a103eec8
Children a88c0df88ef8
White McSpacen
--- a/src/gtkstatusbox.c Sun Apr 24 14:13:16 2005 -0400
+++ b/src/gtkstatusbox.c Sun Apr 24 15:52:29 2005 -0400
@@ -57,53 +57,53 @@
GType
gtk_gaim_status_box_get_type (void)
{
- static GType status_box_type = 0;
+ static GType status_box_type = 0;
- if (!status_box_type)
- {
- static const GTypeInfo status_box_info =
- {
- sizeof (GtkGaimStatusBoxClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) gtk_gaim_status_box_class_init,
- NULL, /* class_finalize */
- NULL, /* class_data */
- sizeof (GtkGaimStatusBox),
- 0,
- (GInstanceInitFunc) gtk_gaim_status_box_init
- };
+ if (!status_box_type)
+ {
+ static const GTypeInfo status_box_info =
+ {
+ sizeof (GtkGaimStatusBoxClass),
+ NULL, /* base_init */
+ NULL, /* base_finalize */
+ (GClassInitFunc) gtk_gaim_status_box_class_init,
+ NULL, /* class_finalize */
+ NULL, /* class_data */
+ sizeof (GtkGaimStatusBox),
+ 0,
+ (GInstanceInitFunc) gtk_gaim_status_box_init
+ };
- status_box_type = g_type_register_static (GTK_TYPE_COMBO_BOX,
- "GtkGaimStatusBox",
- &status_box_info,
- 0);
- }
+ status_box_type = g_type_register_static(GTK_TYPE_COMBO_BOX,
+ "GtkGaimStatusBox",
+ &status_box_info,
+ 0);
+ }
- return status_box_type;
+ return status_box_type;
}
static void
gtk_gaim_status_box_class_init (GtkGaimStatusBoxClass *klass)
{
- GObjectClass *object_class;
- GtkWidgetClass *widget_class;
- GtkComboBoxClass *parent_class = (GtkComboBoxClass*)klass;
- GtkContainerClass *container_class = (GtkContainerClass*)klass;
-
- parent_class->changed = gtk_gaim_status_box_changed;
- widget_class = (GtkWidgetClass*)klass;
- combo_box_size_request = widget_class->size_request;
- widget_class->size_request = gtk_gaim_status_box_size_request;
- combo_box_size_allocate = widget_class->size_allocate;
- widget_class->size_allocate = gtk_gaim_status_box_size_allocate;
- combo_box_expose_event = widget_class->expose_event;
- widget_class->expose_event = gtk_gaim_status_box_expose_event;
+ GObjectClass *object_class;
+ GtkWidgetClass *widget_class;
+ GtkComboBoxClass *parent_class = (GtkComboBoxClass*)klass;
+ GtkContainerClass *container_class = (GtkContainerClass*)klass;
- combo_box_forall = container_class->forall;
- container_class->forall = gtk_gaim_status_box_forall;
+ parent_class->changed = gtk_gaim_status_box_changed;
+ widget_class = (GtkWidgetClass*)klass;
+ combo_box_size_request = widget_class->size_request;
+ widget_class->size_request = gtk_gaim_status_box_size_request;
+ combo_box_size_allocate = widget_class->size_allocate;
+ widget_class->size_allocate = gtk_gaim_status_box_size_allocate;
+ combo_box_expose_event = widget_class->expose_event;
+ widget_class->expose_event = gtk_gaim_status_box_expose_event;
- object_class = (GObjectClass *)klass;
+ combo_box_forall = container_class->forall;
+ container_class->forall = gtk_gaim_status_box_forall;
+
+ object_class = (GObjectClass *)klass;
}
static void
@@ -126,25 +126,21 @@
if (status_box->error) {
text = g_strdup_printf("%s\n<span size=\"smaller\" weight=\"bold\" color=\"red\">%s</span>",
- title, status_box->error);
+ title, status_box->error);
} else if (status_box->typing) {
- text = g_strdup_printf("%s\n<span size=\"smaller\" color=\"%s\">%s</span>",
- title,
- aa_color,
- _("Typing"));
+ text = g_strdup_printf("%s\n<span size=\"smaller\" color=\"%s\">%s</span>",
+ title, aa_color, _("Typing"));
} else if (status_box->connecting) {
- text = g_strdup_printf("%s\n<span size=\"smaller\" color=\"%s\">%s</span>",
- title,
- aa_color,
- _("Connecting"));
- } else if (status_box->desc) {
- text = g_strdup_printf("%s\n<span size=\"smaller\" color=\"%s\">%s</span>",
- title, aa_color, status_box->desc);
+ text = g_strdup_printf("%s\n<span size=\"smaller\" color=\"%s\">%s</span>",
+ title, aa_color, _("Connecting"));
+ } else if (status_box->desc) {
+ text = g_strdup_printf("%s\n<span size=\"smaller\" color=\"%s\">%s</span>",
+ title, aa_color, status_box->desc);
} else {
text = g_strdup_printf("%s", title);
}
-
- if (status_box->error)
+
+ if (status_box->error)
pixbuf = status_box->error_pixbuf;
else if (status_box->typing)
pixbuf = status_box->typing_pixbufs[status_box->typing_index];
@@ -155,9 +151,9 @@
gtk_list_store_set(status_box->store, &(status_box->iter),
ICON_COLUMN, pixbuf,
- TEXT_COLUMN, text,
+ TEXT_COLUMN, text,
TITLE_COLUMN, title,
- DESC_COLUMN, status_box->desc,
+ DESC_COLUMN, status_box->desc,
TYPE_COLUMN, NULL, -1);
path = gtk_tree_path_new_from_string("0");
gtk_cell_view_set_displayed_row(GTK_CELL_VIEW(status_box->cell_view), path);
@@ -179,13 +175,13 @@
status_box->error_pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_OFFLINE,
icon_size, "GtkGaimStatusBox");
status_box->connecting_index = 0;
- status_box->connecting_pixbufs[0] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT0,
+ status_box->connecting_pixbufs[0] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT0,
icon_size, "GtkGaimStatusBox");
- status_box->connecting_pixbufs[1] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT1,
+ status_box->connecting_pixbufs[1] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT1,
icon_size, "GtkGaimStatusBox");
- status_box->connecting_pixbufs[2] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT2,
+ status_box->connecting_pixbufs[2] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT2,
icon_size, "GtkGaimStatusBox");
- status_box->connecting_pixbufs[3] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT3,
+ status_box->connecting_pixbufs[3] = gtk_widget_render_icon (GTK_WIDGET(status_box), GAIM_STOCK_STATUS_CONNECT3,
icon_size, "GtkGaimStatusBox");
status_box->typing_index = 0;
@@ -200,10 +196,10 @@
status_box->connecting = FALSE;
status_box->typing = FALSE;
status_box->title = NULL;
- status_box->pixbuf = NULL;
+ status_box->pixbuf = NULL;
status_box->cell_view = gtk_cell_view_new();
gtk_widget_show (status_box->cell_view);
-
+
status_box->store = gtk_list_store_new(NUM_COLUMNS, GDK_TYPE_PIXBUF, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING);
status_box->dropdown_store = gtk_list_store_new(NUM_COLUMNS, GDK_TYPE_PIXBUF, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING);
gtk_combo_box_set_model(GTK_COMBO_BOX(status_box), GTK_TREE_MODEL(status_box->dropdown_store));
@@ -213,12 +209,12 @@
gtk_gaim_status_box_refresh(status_box);
gtk_cell_view_set_displayed_row(GTK_CELL_VIEW(status_box->cell_view), gtk_tree_path_new_from_string("0"));
gtk_container_add(GTK_CONTAINER(status_box), status_box->cell_view);
-
+
status_box->icon_rend = gtk_cell_renderer_pixbuf_new();
status_box->text_rend = gtk_cell_renderer_text_new();
gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(status_box), icon_rend, FALSE);
- gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(status_box), text_rend, TRUE);
+ gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(status_box), text_rend, TRUE);
gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(status_box), icon_rend, "pixbuf", ICON_COLUMN, NULL);
gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(status_box), text_rend, "markup", TEXT_COLUMN, NULL);
@@ -257,34 +253,35 @@
static void
-gtk_gaim_status_box_size_request (GtkWidget *widget,
- GtkRequisition *requisition)
+gtk_gaim_status_box_size_request(GtkWidget *widget,
+ GtkRequisition *requisition)
{
GtkRequisition box_req;
combo_box_size_request(widget, requisition);
-
+
gtk_widget_size_request(GTK_GAIM_STATUS_BOX(widget)->vbox, &box_req);
if (box_req.height > 1)
requisition->height = requisition->height + box_req.height + 6;
-
+
requisition->width = 1;
}
static void
-gtk_gaim_status_box_size_allocate (GtkWidget *widget,
- GtkAllocation *allocation)
+gtk_gaim_status_box_size_allocate(GtkWidget *widget,
+ GtkAllocation *allocation)
{
GtkRequisition req = {0,0};
GtkAllocation parent_alc = *allocation, box_alc = *allocation ;
combo_box_size_request(widget, &req);
-
+
/* EVIL XXX */
- box_alc.height = 80;//MAX(1,box_alc.height - req.height - 6);
-
+ box_alc.height = 80;
+ /* box_alc.height = MAX(1,box_alc.height - req.height - 6); */
+
box_alc.y = box_alc.y + req.height + 6;
gtk_widget_size_allocate((GTK_GAIM_STATUS_BOX(widget))->vbox, &box_alc);
-
+
parent_alc.height = MAX(1,req.height);
combo_box_size_allocate(widget, &parent_alc);
widget->allocation = *allocation;
@@ -292,32 +289,31 @@
static gboolean
-gtk_gaim_status_box_expose_event (GtkWidget *widget,
- GdkEventExpose *event)
+gtk_gaim_status_box_expose_event(GtkWidget *widget,
+ GdkEventExpose *event)
{
+ GtkGaimStatusBox *status_box = GTK_GAIM_STATUS_BOX(widget);
+ combo_box_expose_event(widget, event);
- GtkGaimStatusBox *status_box = GTK_GAIM_STATUS_BOX (widget);
- combo_box_expose_event(widget, event);
-
- gtk_container_propagate_expose (GTK_CONTAINER (widget),
- status_box->vbox, event);
- return FALSE;
+ gtk_container_propagate_expose(GTK_CONTAINER(widget),
+ status_box->vbox, event);
+ return FALSE;
}
static void
-gtk_gaim_status_box_forall (GtkContainer *container,
- gboolean include_internals,
- GtkCallback callback,
- gpointer callback_data)
+gtk_gaim_status_box_forall(GtkContainer *container,
+ gboolean include_internals,
+ GtkCallback callback,
+ gpointer callback_data)
{
- GtkGaimStatusBox *status_box = GTK_GAIM_STATUS_BOX (container);
+ GtkGaimStatusBox *status_box = GTK_GAIM_STATUS_BOX (container);
- if (include_internals)
- {
- (* callback) (status_box->vbox, callback_data);
- }
+ if (include_internals)
+ {
+ (* callback) (status_box->vbox, callback_data);
+ }
- combo_box_forall(container, include_internals, callback, callback_data);
+ combo_box_forall(container, include_internals, callback, callback_data);
}
GtkWidget *
@@ -332,25 +328,25 @@
{
GtkTreeIter iter;
char *t;
-
+
if (sec_text) {
char aa_color[8];
GtkStyle *style = gtk_widget_get_style(GTK_WIDGET(status_box));
snprintf(aa_color, sizeof(aa_color), "#%02x%02x%02x",
style->text_aa[GTK_STATE_NORMAL].red >> 8,
style->text_aa[GTK_STATE_NORMAL].green >> 8,
- style->text_aa[GTK_STATE_NORMAL].blue >> 8);
+ style->text_aa[GTK_STATE_NORMAL].blue >> 8);
t = g_strdup_printf("%s\n<span color=\"%s\">%s</span>", text, aa_color, sec_text);
} else {
t = g_strdup(text);
}
-
+
gtk_list_store_append(status_box->dropdown_store, &iter);
gtk_list_store_set(status_box->dropdown_store, &iter,
ICON_COLUMN, pixbuf,
- TEXT_COLUMN, t,
+ TEXT_COLUMN, t,
TITLE_COLUMN, text,
- DESC_COLUMN, sec_text,
+ DESC_COLUMN, sec_text,
TYPE_COLUMN, edit, -1);
}
@@ -377,7 +373,7 @@
return;
if (status_box->connecting_index == 3)
status_box->connecting_index = 0;
- else
+ else
status_box->connecting_index++;
gtk_gaim_status_box_refresh(status_box);
}
@@ -387,7 +383,7 @@
{
if (status_box->typing_index == 3)
status_box->typing_index = 0;
- else
+ else
status_box->typing_index++;
gtk_gaim_status_box_refresh(status_box);
}
@@ -403,7 +399,7 @@
for (l = gaim_accounts_get_all(); l != NULL; l = l->next) {
GaimAccount *account = (GaimAccount*)l->data;
GaimStatusType *status_type;
-
+
if (!gaim_account_get_enabled(account, GAIM_GTK_UI))
continue;
@@ -411,7 +407,7 @@
if (status_type == NULL)
continue;
- gaim_account_set_status(account, status_type_id, TRUE,
+ gaim_account_set_status(account, status_type_id, TRUE,
"message",gtk_imhtml_get_markup(GTK_IMHTML(box->imhtml)), NULL);
}
g_source_remove(box->typing);
@@ -434,18 +430,18 @@
gtk_combo_box_get_active_iter(GTK_COMBO_BOX(status_box), &iter);
gtk_tree_model_get(GTK_TREE_MODEL(status_box->dropdown_store), &iter, TITLE_COLUMN, &text,
- DESC_COLUMN, &sec_text, ICON_COLUMN, &pixbuf,
+ DESC_COLUMN, &sec_text, ICON_COLUMN, &pixbuf,
TYPE_COLUMN, &status_type_id, -1);
if (status_box->title)
g_free(status_box->title);
status_box->title = g_strdup(text);
if (status_box->desc && sec_text)
- g_free(status_box->desc);
+ g_free(status_box->desc);
status_box->desc = g_strdup(sec_text);
if (status_box->pixbuf)
g_object_unref(status_box->pixbuf);
status_box->pixbuf = pixbuf;
-
+
if (!strcmp(status_type_id, "away")) {
gtk_widget_show_all(status_box->vbox);
status_box->typing = g_timeout_add(3000, (GSourceFunc)remove_typing_cb, status_box);
@@ -480,7 +476,7 @@
if (box->typing) {
gtk_gaim_status_box_pulse_typing(box);
g_source_remove(box->typing);
- }
+ }
box->typing = g_timeout_add(3000, (GSourceFunc)remove_typing_cb, box);
gtk_gaim_status_box_refresh(box);
}
@@ -490,7 +486,7 @@
GtkTreeIter iter;
char *type;
gtk_combo_box_get_active_iter(GTK_COMBO_BOX(status_box), &iter);
- gtk_tree_model_get(GTK_TREE_MODEL(status_box->dropdown_store), &iter,
+ gtk_tree_model_get(GTK_TREE_MODEL(status_box->dropdown_store), &iter,
TYPE_COLUMN, &type, -1);
return type;
}