aboutsummaryrefslogtreecommitdiffstats
path: root/mail/em-folder-selector.c
diff options
context:
space:
mode:
authorEttore Perazzoli <ettore@src.gnome.org>2003-10-22 02:28:34 +0800
committerEttore Perazzoli <ettore@src.gnome.org>2003-10-22 02:28:34 +0800
commit0fb08f3ff81575a4749d851404233f34252dd2f2 (patch)
tree7e03befedc3a76fd104921dbbc616810d87333be /mail/em-folder-selector.c
parent0e19f2c16de592607a341eb9974d31e4e47e02b5 (diff)
downloadgsoc2013-evolution-0fb08f3ff81575a4749d851404233f34252dd2f2.tar.gz
gsoc2013-evolution-0fb08f3ff81575a4749d851404233f34252dd2f2.tar.zst
gsoc2013-evolution-0fb08f3ff81575a4749d851404233f34252dd2f2.zip
Merge new-ui-branch to the trunk.
svn path=/trunk/; revision=22964
Diffstat (limited to 'mail/em-folder-selector.c')
-rw-r--r--mail/em-folder-selector.c349
1 files changed, 349 insertions, 0 deletions
diff --git a/mail/em-folder-selector.c b/mail/em-folder-selector.c
new file mode 100644
index 0000000000..3ccf00e497
--- /dev/null
+++ b/mail/em-folder-selector.c
@@ -0,0 +1,349 @@
+/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*-
+ *
+ * Copyright(C) 2000, 2001, 2002, 2003 Ximian, Inc.
+ *
+ * Authors: Ettore Perazzoli
+ * Michael Zucchi
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of version 2 of the GNU General Public
+ * License as published by the Free Software Foundation.
+ *
+ * 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
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include "em-folder-selector.h"
+
+#include "shell/e-storage-set-view.h"
+#include "shell/e-storage-set.h"
+
+#include <libgnome/gnome-i18n.h>
+
+#include <gal/util/e-util.h>
+#include <gal/widgets/e-gui-utils.h>
+
+#include <gtk/gtkentry.h>
+#include <gtk/gtkbox.h>
+#include <gtk/gtkhbox.h>
+#include <gtk/gtklabel.h>
+#include <gtk/gtkscrolledwindow.h>
+#include <gtk/gtksignal.h>
+#include <gtk/gtkstock.h>
+
+#include <camel/camel-url.h>
+
+#include <string.h>
+
+#define PARENT_TYPE (gtk_dialog_get_type())
+static GtkDialogClass *parent_class = NULL;
+
+static gboolean
+check_folder_type_valid(EMFolderSelector *emfs)
+{
+ const char *selected;
+ EFolder *folder;
+
+ selected = e_storage_set_view_get_current_folder(emfs->essv);
+ if (selected == NULL)
+ return FALSE;
+
+ folder = e_storage_set_get_folder(emfs->ess, selected);
+ if (folder == NULL)
+ return FALSE;
+
+ return TRUE;
+}
+
+#if 0 /* EPFIXME */
+static void
+folder_creation_dialog_result_cb(EShell *shell,
+ EShellFolderCreationDialogResult result,
+ const char *path,
+ void *data)
+{
+ EMFolderSelector *dialog;
+
+ dialog = EM_FOLDER_SELECTOR(data);
+
+ if (result == E_SHELL_FOLDER_CREATION_DIALOG_RESULT_SUCCESS)
+ e_storage_set_view_set_current_folder(E_STORAGE_SET_VIEW(priv->storage_set_view),
+ path);
+}
+#endif
+
+static void
+emfs_dispose(GObject *object)
+{
+ EMFolderSelector *emfs = (EMFolderSelector *)object;
+
+ if (emfs->ess != NULL) {
+ g_object_unref(emfs->ess);
+ emfs->ess = NULL;
+ emfs->essv = NULL;
+ }
+
+ (* G_OBJECT_CLASS(parent_class)->dispose)(object);
+}
+
+static void
+emfs_finalize(GObject *object)
+{
+ /*EMFolderSelector *emfs = (EMFolderSelector *)object;*/
+
+ (* G_OBJECT_CLASS(parent_class)->finalize)(object);
+}
+
+static void
+emfs_response(GtkDialog *dialog, int response)
+{
+ EMFolderSelector *emfs = (EMFolderSelector *)dialog;
+ const char *path;
+
+ switch (response) {
+ case EM_FOLDER_SELECTOR_RESPONSE_NEW:
+ path = e_storage_set_view_get_current_folder(emfs->essv);
+
+ printf("create new folder, default parent '%s'\n", path);
+ break;
+ }
+}
+
+static void
+emfs_class_init(EMFolderSelectorClass *klass)
+{
+ GObjectClass *object_class;
+ GtkDialogClass *dialog_class;
+
+ parent_class = g_type_class_ref(PARENT_TYPE);
+ object_class = G_OBJECT_CLASS(klass);
+ dialog_class = GTK_DIALOG_CLASS(klass);
+
+ object_class->dispose = emfs_dispose;
+ object_class->finalize = emfs_finalize;
+
+ dialog_class->response = emfs_response;
+}
+
+static void
+emfs_init(EMFolderSelector *emfs)
+{
+ emfs->flags = 0;
+}
+
+static void
+folder_selected_cb(EStorageSetView *essv, const char *path, EMFolderSelector *emfs)
+{
+ if (check_folder_type_valid(emfs))
+ gtk_dialog_set_response_sensitive(GTK_DIALOG(emfs), GTK_RESPONSE_OK, TRUE);
+ else
+ gtk_dialog_set_response_sensitive(GTK_DIALOG(emfs), GTK_RESPONSE_OK, FALSE);
+}
+
+static void
+double_click_cb(EStorageSetView *essv, int row, ETreePath path, int col, GdkEvent *event, EMFolderSelector *emfs)
+{
+ if (check_folder_type_valid(emfs)) {
+ /*g_signal_emit(emfs, signals[FOLDER_SELECTED], 0,
+ em_folder_selector_get_selected(emfs));*/
+ printf("double clicked!\n");
+ }
+}
+
+void
+em_folder_selector_construct(EMFolderSelector *emfs, EStorageSet *ess, guint32 flags, const char *title, const char *text)
+{
+ GtkWidget *scrolled_window;
+ GtkWidget *text_label;
+
+ gtk_window_set_default_size(GTK_WINDOW(emfs), 350, 300);
+ gtk_window_set_modal(GTK_WINDOW(emfs), TRUE);
+ gtk_window_set_title(GTK_WINDOW(emfs), title);
+ gtk_container_set_border_width(GTK_CONTAINER(emfs), 6);
+
+ emfs->flags = flags;
+ if (flags & EM_FOLDER_SELECTOR_CAN_CREATE)
+ gtk_dialog_add_buttons(GTK_DIALOG(emfs), GTK_STOCK_NEW, EM_FOLDER_SELECTOR_RESPONSE_NEW, NULL);
+
+ gtk_dialog_add_buttons(GTK_DIALOG(emfs),
+ GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
+ GTK_STOCK_OK, GTK_RESPONSE_OK,
+ NULL);
+
+ gtk_dialog_set_response_sensitive(GTK_DIALOG(emfs), GTK_RESPONSE_OK, FALSE);
+ gtk_dialog_set_default_response(GTK_DIALOG(emfs), GTK_RESPONSE_OK);
+
+ emfs->ess = ess;
+ g_object_ref(ess);
+
+ emfs->essv = (EStorageSetView *)e_storage_set_create_new_view(ess, NULL);
+ e_storage_set_view_set_allow_dnd(emfs->essv, FALSE);
+ e_storage_set_view_enable_search(emfs->essv, TRUE);
+
+ g_signal_connect(emfs->essv, "double_click", G_CALLBACK(double_click_cb), emfs);
+ g_signal_connect(emfs->essv, "folder_selected", G_CALLBACK(folder_selected_cb), emfs);
+
+ scrolled_window = gtk_scrolled_window_new(NULL, NULL);
+ gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scrolled_window), GTK_SHADOW_IN);
+ gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled_window),
+ GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
+
+ gtk_container_add(GTK_CONTAINER(scrolled_window), (GtkWidget *)emfs->essv);
+
+ gtk_box_pack_end(GTK_BOX(GTK_DIALOG(emfs)->vbox), scrolled_window, TRUE, TRUE, 6);
+ gtk_box_set_spacing(GTK_BOX(GTK_DIALOG(emfs)->vbox), 6);
+
+ gtk_container_set_border_width(GTK_CONTAINER(GTK_DIALOG(emfs)->vbox), 6);
+
+ gtk_widget_show((GtkWidget *)emfs->essv);
+ gtk_widget_show(scrolled_window);
+
+ if (text != NULL) {
+ text_label = gtk_label_new(text);
+ gtk_label_set_justify(GTK_LABEL(text_label), GTK_JUSTIFY_LEFT);
+ gtk_widget_show(text_label);
+
+ gtk_box_pack_end(GTK_BOX(GTK_DIALOG(emfs)->vbox), text_label, FALSE, TRUE, 6);
+ gtk_box_set_spacing(GTK_BOX(GTK_DIALOG(emfs)->vbox), 6);
+ }
+
+ GTK_WIDGET_SET_FLAGS((GtkWidget *)emfs->essv, GTK_CAN_FOCUS);
+ gtk_widget_grab_focus((GtkWidget *)emfs->essv);
+}
+
+GtkWidget *
+em_folder_selector_new(EStorageSet *ess, guint32 flags, const char *title, const char *text)
+{
+ EMFolderSelector *emfs;
+
+ g_return_val_if_fail(E_IS_STORAGE_SET(ess), NULL);
+
+ emfs = g_object_new(em_folder_selector_get_type(), NULL);
+ em_folder_selector_construct(emfs, ess, flags, title, text);
+
+ return GTK_WIDGET(emfs);
+}
+
+static void
+emfs_create_name_changed(GtkEntry *entry, EMFolderSelector *emfs)
+{
+ int active;
+
+ active = e_storage_set_view_get_current_folder(emfs->essv) != NULL
+ && emfs->name_entry->text_length > 0;
+
+ gtk_dialog_set_response_sensitive((GtkDialog *)emfs, GTK_RESPONSE_OK, active);
+}
+
+static void
+emfs_create_name_activate(GtkEntry *entry, EMFolderSelector *emfs)
+{
+ printf("entry activated, woop\n");
+}
+
+GtkWidget *
+em_folder_selector_create_new(EStorageSet *ess, guint32 flags, const char *title, const char *text)
+{
+ EMFolderSelector *emfs;
+ GtkWidget *hbox, *w;
+
+ g_return_val_if_fail(E_IS_STORAGE_SET(ess), NULL);
+
+ emfs = g_object_new(em_folder_selector_get_type(), NULL);
+ em_folder_selector_construct(emfs, ess, flags, title, text);
+
+ hbox = gtk_hbox_new(FALSE, 0);
+ w = gtk_label_new_with_mnemonic(_("Folder _name"));
+ gtk_box_pack_start((GtkBox *)hbox, w, FALSE, FALSE, 6);
+ emfs->name_entry = (GtkEntry *)gtk_entry_new();
+ g_signal_connect(emfs->name_entry, "changed", G_CALLBACK(emfs_create_name_changed), emfs);
+ g_signal_connect(emfs->name_entry, "activate", G_CALLBACK(emfs_create_name_activate), emfs);
+ gtk_box_pack_start((GtkBox *)hbox, (GtkWidget *)emfs->name_entry, TRUE, FALSE, 6);
+ gtk_widget_show_all(hbox);
+
+ gtk_box_pack_start((GtkBox *)((GtkDialog *)emfs)->vbox, hbox, FALSE, TRUE, 0);
+
+ return GTK_WIDGET(emfs);
+}
+
+void
+em_folder_selector_set_selected(EMFolderSelector *emfs, const char *path)
+{
+ e_storage_set_view_set_current_folder(emfs->essv, path);
+}
+
+void
+em_folder_selector_set_selected_uri(EMFolderSelector *emfs, const char *uri)
+{
+ const char *path;
+
+ path = e_storage_set_get_path_for_physical_uri(emfs->ess, uri);
+ if (path)
+ e_storage_set_view_set_current_folder(emfs->essv, path);
+}
+
+const char *
+em_folder_selector_get_selected(EMFolderSelector *emfs)
+{
+ const char *path;
+
+ path = e_storage_set_view_get_current_folder(emfs->essv);
+ if (emfs->name_entry) {
+ g_free(emfs->selected);
+ emfs->selected = g_strdup_printf("%s/%s", path, gtk_entry_get_text(emfs->name_entry));
+ path = emfs->selected;
+ }
+
+ return path;
+}
+
+const char *
+em_folder_selector_get_selected_uri(EMFolderSelector *emfs)
+{
+ const char *path;
+ EFolder *folder;
+
+ path = e_storage_set_view_get_current_folder(emfs->essv);
+ if (path == NULL) {
+ printf("current folder is null?\n");
+ return NULL;
+ }
+
+ folder = e_storage_set_get_folder(emfs->ess, path);
+ if (folder == NULL) {
+ printf("path ok, but can't get folder?\n");
+ return NULL;
+ }
+
+ path = e_folder_get_physical_uri(folder);
+ if (path && emfs->name_entry) {
+ CamelURL *url;
+ char *newpath;
+
+ url = camel_url_new(path, NULL);
+ newpath = g_strdup_printf("%s/%s", url->fragment?url->fragment:url->path, gtk_entry_get_text(emfs->name_entry));
+ if (url->fragment)
+ camel_url_set_fragment(url, newpath);
+ else
+ camel_url_set_path(url, newpath);
+ g_free(emfs->selected_uri);
+ emfs->selected_uri = camel_url_to_string(url, 0);
+ camel_url_free(url);
+ path = emfs->selected_uri;
+ }
+
+ return path;
+}
+
+E_MAKE_TYPE(em_folder_selector, "EMFolderSelector", EMFolderSelector, emfs_class_init, emfs_init, PARENT_TYPE)