aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--e-util/e-config.c110
1 files changed, 99 insertions, 11 deletions
diff --git a/e-util/e-config.c b/e-util/e-config.c
index c6676fbb77..5925489dd8 100644
--- a/e-util/e-config.c
+++ b/e-util/e-config.c
@@ -31,6 +31,7 @@
#include <glib/gi18n.h>
#include "e-config.h"
+#include "e-binding.h"
#include <glib/gi18n.h>
@@ -1558,22 +1559,105 @@ emph_free_group(struct _EConfigHookGroup *group)
}
static GtkWidget *
-ech_config_widget_factory(EConfig *ec, EConfigItem *item, GtkWidget *parent, GtkWidget *old, gpointer data)
+ech_config_widget_factory (EConfig *config,
+ EConfigItem *item,
+ GtkWidget *parent,
+ GtkWidget *old,
+ gpointer data)
{
struct _EConfigHookGroup *group = data;
+ EConfigHookItemFactoryData factory_data;
+ GtkWidget *widget;
+ EPlugin *plugin;
+
+ factory_data.config = config;
+ factory_data.item = item;
+ factory_data.target = config->target;
+ factory_data.parent = parent;
+ factory_data.old = old;
+
+ plugin = group->hook->hook.plugin;
+ widget = e_plugin_invoke (plugin, item->user_data, &factory_data);
+
+ /* Sanity check the result. */
+ if (widget == NULL)
+ g_warning (
+ "%s() returned NULL instead of a GtkWidget",
+ (gchar *) item->user_data);
+ else if (!GTK_IS_WIDGET (widget))
+ g_warning (
+ "%s() returned a %s instead of a GtkWidget",
+ (gchar *) item->user_data,
+ G_OBJECT_TYPE_NAME (widget));
+
+ return widget;
+}
+
+static GtkWidget *
+ech_config_section_factory (EConfig *config,
+ EConfigItem *item,
+ GtkWidget *parent,
+ GtkWidget *old,
+ gpointer data)
+{
+ struct _EConfigHookGroup *group = data;
+ GtkWidget *label;
+ GtkWidget *widget;
+ EPlugin *plugin;
+
+ if (item->label != NULL) {
+ const gchar *translated;
+ gchar *markup;
+
+ translated = gettext (item->label);
+ markup = g_markup_printf_escaped ("<b>%s</b>", translated);
+
+ label = gtk_label_new (markup);
+ gtk_label_set_use_markup (GTK_LABEL (label), TRUE);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_widget_show (label);
+
+ g_free (markup);
+ }
+
+ widget = gtk_frame_new (NULL);
+ gtk_frame_set_label_widget (GTK_FRAME (widget), label);
+ gtk_frame_set_shadow_type (GTK_FRAME (widget), GTK_SHADOW_NONE);
+ gtk_box_pack_start (GTK_BOX (parent), widget, FALSE, FALSE, 0);
- if (group->hook->hook.plugin->enabled) {
- EConfigHookItemFactoryData hdata;
+ /* This is why we have a custom factory for sections.
+ * When the plugin is disabled the frame is invisible. */
+ plugin = group->hook->hook.plugin;
+ e_binding_new (plugin, "enabled", widget, "visible");
+
+ parent = widget;
+
+ widget = gtk_alignment_new (0.0, 0.0, 1.0, 1.0);
+ gtk_alignment_set_padding (GTK_ALIGNMENT (widget), 6, 0, 12, 0);
+ gtk_container_add (GTK_CONTAINER (parent), widget);
+ gtk_widget_show (widget);
+
+ parent = widget;
+
+ switch (item->type) {
+ case E_CONFIG_SECTION:
+ widget = gtk_vbox_new (FALSE, 6);
+ break;
+
+ case E_CONFIG_SECTION_TABLE:
+ widget = gtk_table_new (1, 1, FALSE);
+ gtk_table_set_col_spacings (GTK_TABLE (widget), 6);
+ gtk_table_set_row_spacings (GTK_TABLE (widget), 6);
+ break;
+
+ default:
+ g_return_val_if_reached (NULL);
+ }
- hdata.config = ec;
- hdata.item = item;
- hdata.target = ec->target;
- hdata.parent = parent;
- hdata.old = old;
+ gtk_container_add (GTK_CONTAINER (parent), widget);
+ gtk_widget_show (widget);
- return (GtkWidget *)e_plugin_invoke(group->hook->hook.plugin, (gchar *)item->user_data, &hdata);
- } else
- return NULL;
+ return widget;
}
static struct _EConfigItem *
@@ -1595,6 +1679,10 @@ emph_construct_item(EPluginHook *eph, EConfigHookGroup *menu, xmlNodePtr root, E
if (item->user_data)
item->factory = ech_config_widget_factory;
+ else if (item->type == E_CONFIG_SECTION)
+ item->factory = ech_config_section_factory;
+ else if (item->type == E_CONFIG_SECTION_TABLE)
+ item->factory = ech_config_section_factory;
d(printf(" path=%s label=%s factory=%s\n", item->path, item->label, (gchar *)item->user_data));