aboutsummaryrefslogtreecommitdiffstats
path: root/modules/prefer-plain/plugin/config-ui.c
diff options
context:
space:
mode:
Diffstat (limited to 'modules/prefer-plain/plugin/config-ui.c')
-rw-r--r--modules/prefer-plain/plugin/config-ui.c192
1 files changed, 192 insertions, 0 deletions
diff --git a/modules/prefer-plain/plugin/config-ui.c b/modules/prefer-plain/plugin/config-ui.c
new file mode 100644
index 0000000000..29b81a60fe
--- /dev/null
+++ b/modules/prefer-plain/plugin/config-ui.c
@@ -0,0 +1,192 @@
+/*
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) version 3.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <gtk/gtk.h>
+#include <glib/gi18n.h>
+
+#include <mail/em-config.h>
+
+#include <libedataserverui/libedataserverui.h>
+
+GtkWidget *prefer_plain_page_factory (EPlugin *ep, EConfigHookItemFactoryData *hook_data);
+
+enum {
+ EPP_NORMAL,
+ EPP_PREFER,
+ EPP_TEXT
+};
+
+static GSettings *epp_settings = NULL;
+static gint epp_mode = -1;
+static gboolean epp_show_suppressed = TRUE;
+
+static struct {
+ const gchar *key;
+ const gchar *label;
+ const gchar *description;
+} epp_options[] = {
+ { "normal",
+ N_("Show HTML if present"),
+ N_("Let Evolution choose the best part to show.") },
+
+ { "prefer_plain",
+ N_("Show plain text if present"),
+ N_("Show plain text part, if present, otherwise "
+ "let Evolution choose the best part to show.") },
+
+ { "only_plain",
+ N_("Only ever show plain text"),
+ N_("Always show plain text part and make attachments "
+ "from other parts, if requested.") },
+};
+
+static void
+update_info_label (GtkWidget *info_label,
+ guint mode)
+{
+ gchar *str = g_strconcat ("<i>", _(epp_options[mode > 2 ? 0 : mode].description), "</i>", NULL);
+
+ gtk_label_set_markup (GTK_LABEL (info_label), str);
+
+ g_free (str);
+}
+
+static void
+epp_mode_changed (GtkComboBox *dropdown,
+ GtkWidget *info_label)
+{
+ epp_mode = gtk_combo_box_get_active (dropdown);
+ if (epp_mode > 2)
+ epp_mode = 0;
+
+ g_settings_set_string (epp_settings, "mode", epp_options[epp_mode].key);
+ update_info_label (info_label, epp_mode);
+}
+
+static void
+epp_show_suppressed_toggled (GtkToggleButton *check,
+ gpointer data)
+{
+ g_return_if_fail (check != NULL);
+
+ epp_show_suppressed = gtk_toggle_button_get_active (check);
+ g_settings_set_boolean (epp_settings, "show-suppressed", epp_show_suppressed);
+}
+
+GtkWidget *
+prefer_plain_page_factory (EPlugin *epl,
+ struct _EConfigHookItemFactoryData *data)
+{
+ GtkComboBox *dropdown;
+ GtkCellRenderer *cell;
+ GtkListStore *store;
+ GtkWidget *dropdown_label, *info, *check;
+ guint i;
+ GtkTreeIter iter;
+
+ if (data->old)
+ return data->old;
+
+ check = gtk_check_button_new_with_mnemonic (_("Show s_uppressed HTML parts as attachments"));
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check), epp_show_suppressed);
+ gtk_widget_show (check);
+ g_signal_connect (
+ check, "toggled",
+ G_CALLBACK (epp_show_suppressed_toggled), NULL);
+
+ dropdown = (GtkComboBox *) gtk_combo_box_new ();
+ cell = gtk_cell_renderer_text_new ();
+ store = gtk_list_store_new (1, G_TYPE_STRING);
+ for (i = 0; i < G_N_ELEMENTS (epp_options); i++) {
+ gtk_list_store_append (store, &iter);
+ gtk_list_store_set (store, &iter, 0, _(epp_options[i].label), -1);
+ }
+
+ gtk_cell_layout_pack_start ((GtkCellLayout *) dropdown, cell, TRUE);
+ gtk_cell_layout_set_attributes((GtkCellLayout *)dropdown, cell, "text", 0, NULL);
+ gtk_combo_box_set_model (dropdown, (GtkTreeModel *) store);
+ /*gtk_combo_box_set_active(dropdown, -1);*/
+ gtk_combo_box_set_active (dropdown, epp_mode);
+ gtk_widget_show ((GtkWidget *) dropdown);
+
+ dropdown_label = gtk_label_new_with_mnemonic (_("HTML _Mode"));
+ gtk_widget_show (dropdown_label);
+ gtk_label_set_mnemonic_widget (GTK_LABEL (dropdown_label), (GtkWidget *) dropdown);
+
+ info = gtk_label_new (NULL);
+ gtk_misc_set_alignment (GTK_MISC (info), 0.0, 0.5);
+ gtk_label_set_line_wrap (GTK_LABEL (info), TRUE);
+
+ gtk_widget_show (info);
+ update_info_label (info, epp_mode);
+
+ g_signal_connect (
+ dropdown, "changed",
+ G_CALLBACK (epp_mode_changed), info);
+
+ g_object_get (data->parent, "n-rows", &i, NULL);
+ gtk_table_attach ((GtkTable *) data->parent, check, 0, 2, i, i + 1, GTK_FILL | GTK_EXPAND, 0, 0, 0);
+ gtk_table_attach ((GtkTable *) data->parent, dropdown_label, 0, 1, i + 1, i + 2, 0, 0, 0, 0);
+ gtk_table_attach ((GtkTable *) data->parent, (GtkWidget *) dropdown, 1, 2, i + 1, i + 2, GTK_FILL | GTK_EXPAND, 0, 0, 0);
+ gtk_table_attach ((GtkTable *) data->parent, info, 1, 2, i + 2, i + 3, GTK_FILL | GTK_EXPAND, 0, 0, 0);
+
+ /* since this isnt dynamic, we don't need to track each item */
+
+ return (GtkWidget *) dropdown;
+}
+
+gint e_plugin_lib_enable (EPlugin *ep, gint enable);
+
+gint
+e_plugin_lib_enable (EPlugin *ep,
+ gint enable)
+{
+ gchar *key;
+ gint i;
+
+ if (epp_settings || epp_mode != -1)
+ return 0;
+
+ if (enable) {
+
+ epp_settings = g_settings_new ("org.gnome.evolution.plugin.prefer-plain");
+ key = g_settings_get_string (epp_settings, "mode");
+ if (key) {
+ for (i = 0; i < G_N_ELEMENTS (epp_options); i++) {
+ if (!strcmp (epp_options[i].key, key)) {
+ epp_mode = i;
+ break;
+ }
+ }
+ g_free (key);
+ } else {
+ epp_mode = 0;
+ }
+
+ epp_show_suppressed = g_settings_get_boolean (epp_settings, "show-suppressed");
+ } else {
+ if (epp_settings) {
+ g_object_unref (epp_settings);
+ epp_settings = NULL;
+ }
+ }
+
+ return 0;
+}