# HG changeset patch # User Will Thompson # Date 1207950611 0 # Node ID efc232f1822bfb509ef9bf9ddafc802120bcc345 # Parent 589803e5ce7b158cea52ffdcf75b502856135019 Improve the layout of the plugin description pane. diff -r 589803e5ce7b -r efc232f1822b pidgin/gtkplugin.c --- a/pidgin/gtkplugin.c Fri Apr 11 02:08:42 2008 +0000 +++ b/pidgin/gtkplugin.c Fri Apr 11 21:50:11 2008 +0000 @@ -42,7 +42,14 @@ static GtkWidget *expander = NULL; static GtkWidget *plugin_dialog = NULL; -static GtkWidget *plugin_details = NULL; + +static GtkLabel *plugin_name = NULL; +static GtkTextBuffer *plugin_desc = NULL; +static GtkLabel *plugin_error = NULL; +static GtkLabel *plugin_author = NULL; +static GtkLabel *plugin_website = NULL; +static GtkLabel *plugin_filename = NULL; + static GtkWidget *pref_button = NULL; static GHashTable *plugin_pref_dialogs = NULL; @@ -301,9 +308,6 @@ static void plugin_toggled_stage_two(PurplePlugin *plug, GtkTreeModel *model, GtkTreeIter *iter, gboolean unload) { - gchar *name = NULL; - gchar *description = NULL; - if (unload) { pidgin_set_cursor(plugin_dialog, GDK_WATCH); @@ -337,30 +341,30 @@ || (plug->info->prefs_info && plug->info->prefs_info->get_plugin_pref_frame))); - name = g_markup_escape_text(_(plug->info->name), -1); - description = g_markup_escape_text(_(plug->info->description), -1); + if (plug->error != NULL) + { + gchar *name = g_markup_escape_text(_(plug->info->name), -1); - if (plug->error != NULL) { gchar *error = g_markup_escape_text(plug->error, -1); - gchar *desc; - gchar *text = g_strdup_printf( - "%s %s\n\n" - "%s\n\n" - "%s", - name, plug->info->version, error, description); - desc = g_strdup_printf("%s %s\n", - plug->info->name, plug->info->version, error); + gchar *text; + + text = g_strdup_printf( + "%s %s\n", + plug->info->name, plug->info->version, error); gtk_list_store_set(GTK_LIST_STORE (model), iter, - 1, desc, + 1, text, -1); - g_free(desc); + g_free(text); + + text = g_strdup_printf( + "%s", + error); + gtk_label_set_markup(plugin_error, text); + g_free(text); + g_free(error); - gtk_label_set_markup(GTK_LABEL(plugin_details), text); - g_free(text); + g_free(name); } - g_free(name); - g_free(description); - gtk_list_store_set(GTK_LIST_STORE (model), iter, 0, purple_plugin_is_loaded(plug), @@ -387,15 +391,13 @@ static void prefs_plugin_sel (GtkTreeSelection *sel, GtkTreeModel *model) { - gchar *buf, *pname, *pdesc, *pauth, *pweb; + gchar *buf, *tmp, *name, *version; GtkTreeIter iter; GValue val; PurplePlugin *plug; if (!gtk_tree_selection_get_selected (sel, &model, &iter)) { - /* Clear the old plugin details */ - gtk_label_set_markup(GTK_LABEL(plugin_details), ""); gtk_widget_set_sensitive(pref_button, FALSE); /* Collapse and disable the expander widget */ @@ -411,32 +413,36 @@ gtk_tree_model_get_value (model, &iter, 2, &val); plug = g_value_get_pointer(&val); - pname = g_markup_escape_text(_(plug->info->name), -1); - pdesc = (plug->info->description) ? - g_markup_escape_text(_(plug->info->description), -1) : NULL; - pauth = (plug->info->author) ? - g_markup_escape_text(_(plug->info->author), -1) : NULL; - pweb = (plug->info->homepage) ? - g_markup_escape_text(_(plug->info->homepage), -1) : NULL; + name = g_markup_escape_text(_(plug->info->name), -1); + version = g_markup_escape_text(plug->info->version, -1); buf = g_strdup_printf( - _("%s%s" - "Written by:\t%s\n" - "Website:\t\t%s\n" - "Filename:\t\t%s"), - pdesc ? pdesc : "", pdesc ? "\n\n" : "", - pauth ? pauth : "", pweb ? pweb : "", plug->path); + "%s " + "%s", + name, version); + gtk_label_set_markup(plugin_name, buf); + g_free(buf); - if (plug->error != NULL) + gtk_text_buffer_set_text(plugin_desc, plug->info->description, -1); + gtk_label_set_text(plugin_author, plug->info->author); + gtk_label_set_text(plugin_website, plug->info->homepage); + gtk_label_set_text(plugin_filename, plug->path); + + if (plug->error == NULL) { - char *tmp = g_strdup_printf( - _("%s\n" - "" + gtk_label_set_text(plugin_error, NULL); + } + else + { + tmp = g_markup_escape_text(plug->error, -1); + buf = g_strdup_printf( + _("" "Error: %s\n" "Check the plugin website for an update." ""), - buf, plug->error); + tmp); + gtk_label_set_markup(plugin_error, buf); g_free(buf); - buf = tmp; + g_free(tmp); } gtk_widget_set_sensitive(pref_button, @@ -446,18 +452,10 @@ || (plug->info->prefs_info && plug->info->prefs_info->get_plugin_pref_frame))); - gtk_label_set_markup(GTK_LABEL(plugin_details), buf); - /* Make sure the selected plugin is still visible */ g_idle_add(ensure_plugin_visible, sel); - g_value_unset(&val); - g_free(buf); - g_free(pname); - g_free(pdesc); - g_free(pauth); - g_free(pweb); } static void plugin_dialog_response_cb(GtkWidget *d, int response, GtkTreeSelection *sel) @@ -588,6 +586,66 @@ return TRUE; } +static GtkWidget * +create_details() +{ + GtkBox *vbox = GTK_BOX(gtk_vbox_new(FALSE, 3)); + GtkSizeGroup *sg = gtk_size_group_new(GTK_SIZE_GROUP_HORIZONTAL); + GtkWidget *label, *view; + + plugin_name = GTK_LABEL(gtk_label_new(NULL)); + gtk_misc_set_alignment(GTK_MISC(plugin_name), 0, 0); + gtk_label_set_line_wrap(plugin_name, FALSE); + gtk_label_set_selectable(plugin_name, TRUE); + gtk_box_pack_start(vbox, GTK_WIDGET(plugin_name), FALSE, FALSE, 0); + + view = gtk_text_view_new(); + plugin_desc = gtk_text_view_get_buffer(GTK_TEXT_VIEW(view)); + g_object_set(view, "wrap-mode", GTK_WRAP_WORD, + "editable", FALSE, + "left-margin", PIDGIN_HIG_CAT_SPACE, + "right-margin", PIDGIN_HIG_CAT_SPACE, + NULL); + gtk_box_pack_start(vbox, view, TRUE, TRUE, 0); + + plugin_error = GTK_LABEL(gtk_label_new(NULL)); + gtk_misc_set_alignment(GTK_MISC(plugin_error), 0, 0); + gtk_label_set_line_wrap(plugin_error, FALSE); + gtk_label_set_selectable(plugin_error, TRUE); + gtk_box_pack_start(vbox, GTK_WIDGET(plugin_error), FALSE, FALSE, 0); + + + plugin_author = GTK_LABEL(gtk_label_new(NULL)); + gtk_label_set_line_wrap(plugin_author, FALSE); + gtk_misc_set_alignment(GTK_MISC(plugin_author), 0, 0); + gtk_label_set_selectable(plugin_author, TRUE); + pidgin_add_widget_to_vbox(vbox, "", sg, + GTK_WIDGET(plugin_author), TRUE, &label); + gtk_label_set_markup(GTK_LABEL(label), _("Written by:")); + gtk_misc_set_alignment(GTK_MISC(label), 0, 0); + + plugin_website = GTK_LABEL(gtk_label_new(NULL)); + gtk_label_set_line_wrap(plugin_website, FALSE); + gtk_misc_set_alignment(GTK_MISC(plugin_website), 0, 0); + gtk_label_set_selectable(plugin_website, TRUE); + pidgin_add_widget_to_vbox(vbox, "", sg, + GTK_WIDGET(plugin_website), TRUE, &label); + gtk_label_set_markup(GTK_LABEL(label), _("Web site:")); + gtk_misc_set_alignment(GTK_MISC(label), 0, 0); + + plugin_filename = GTK_LABEL(gtk_label_new(NULL)); + gtk_label_set_line_wrap(plugin_filename, FALSE); + gtk_misc_set_alignment(GTK_MISC(plugin_filename), 0, 0); + gtk_label_set_selectable(plugin_filename, TRUE); + pidgin_add_widget_to_vbox(vbox, "", sg, + GTK_WIDGET(plugin_filename), TRUE, &label); + gtk_label_set_markup(GTK_LABEL(label), _("Filename:")); + gtk_misc_set_alignment(GTK_MISC(label), 0, 0); + + return GTK_WIDGET(vbox); +} + + void pidgin_plugin_dialog_show() { GtkWidget *sw; @@ -674,16 +732,17 @@ pidgin_plugins_create_tooltip, pidgin_plugins_paint_tooltip); + expander = gtk_expander_new(_("Plugin Details")); gtk_expander_set_use_markup(GTK_EXPANDER(expander), TRUE); - plugin_details = gtk_label_new(NULL); - gtk_label_set_line_wrap(GTK_LABEL(plugin_details), TRUE); - gtk_container_add(GTK_CONTAINER(expander), plugin_details); gtk_widget_set_sensitive(expander, FALSE); - gtk_box_pack_start(GTK_BOX(GTK_DIALOG(plugin_dialog)->vbox), expander, FALSE, FALSE, 0); + gtk_container_add(GTK_CONTAINER(expander), create_details()); + gtk_box_pack_start(GTK_BOX(GTK_DIALOG(plugin_dialog)->vbox), expander, + FALSE, FALSE, 0); + g_signal_connect (G_OBJECT (sel), "changed", G_CALLBACK (prefs_plugin_sel), NULL); g_signal_connect(G_OBJECT(plugin_dialog), "response", G_CALLBACK(plugin_dialog_response_cb), sel); - gtk_window_set_default_size(GTK_WINDOW(plugin_dialog), 430, 430); + gtk_window_set_default_size(GTK_WINDOW(plugin_dialog), 430, 530); gtk_widget_show_all(plugin_dialog); }