aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--plugins/shared-folder/share-folder-common.c29
-rw-r--r--plugins/shared-folder/share-folder.c189
2 files changed, 130 insertions, 88 deletions
diff --git a/plugins/shared-folder/share-folder-common.c b/plugins/shared-folder/share-folder-common.c
index 3c33c148a3..bdb036c821 100644
--- a/plugins/shared-folder/share-folder-common.c
+++ b/plugins/shared-folder/share-folder-common.c
@@ -1,6 +1,6 @@
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
- * Authors: Vivek Jain <jvivek@novell.com>
+ * Author: Vivek Jain <jvivek@novell.com>
*
* Copyright 2004 Novell, Inc.
*
@@ -39,6 +39,7 @@
#include <mail/em-folder-properties.h>
#include <mail/em-folder-tree.h>
#include <mail/em-folder-selector.h>
+
#include <camel/providers/groupwise/camel-groupwise-store.h>
#include <camel/providers/groupwise/camel-groupwise-folder.h>
#include <e-gw-container.h>
@@ -64,10 +65,6 @@ void
shared_folder_commit (EPlugin *ep, EConfigTarget *target)
{
- gchar *mesg = "Folder shared to you";
- gchar *sub = "Shared folder notification";
- ShareFolder *sf;
- gchar *check = NULL;
if(common)
share_folder (common);
g_object_run_dispose(common);
@@ -86,9 +83,6 @@ shared_folder_abort (EPlugin *ep, EConfigTarget *target)
-
-
-
GtkWidget *
org_gnome_shared_folder_factory (EPlugin *ep, EConfigHookItemFactoryData *hook_data)
{
@@ -115,13 +109,24 @@ org_gnome_shared_folder_factory (EPlugin *ep, EConfigHookItemFactoryData *hook_d
CamelGroupwiseStore *gw_store = CAMEL_GROUPWISE_STORE (folder->parent_store) ;
CamelGroupwiseStorePrivate *priv = gw_store->priv ;
- id = g_strdup (container_id_lookup(priv,sub));
- cnc = cnc_lookup (priv);
- g_free (sub);
+ if (priv && sub) {
+
+ id = g_strdup (container_id_lookup(priv,sub));
+ cnc = cnc_lookup (priv);
+ } else {
+ cnc = NULL;
+ id = NULL;
+ }
+
g_free (folderuri);
- sharing_tab = share_folder_new (cnc, id);
+ if (cnc && id)
+ sharing_tab = share_folder_new (cnc, id);
+ else
+ return NULL;
+
gtk_notebook_append_page((GtkNotebook *) hook_data->parent, sharing_tab->vbox, gtk_label_new_with_mnemonic N_("Sharing"));
+
common = sharing_tab;
diff --git a/plugins/shared-folder/share-folder.c b/plugins/shared-folder/share-folder.c
index 771658447b..cd83ad22d8 100644
--- a/plugins/shared-folder/share-folder.c
+++ b/plugins/shared-folder/share-folder.c
@@ -1,3 +1,24 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+/*
+ * Author: Vivek Jain <jvivek@novell.com>
+ *
+ * Copyright 2004 Novell, Inc.
+ *
+ * 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 Street #330, Boston, MA 02111-1307, USA.
+ *
+ */
+
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
@@ -32,7 +53,20 @@ static void share_folder_finalise (GObject *obj);
static void free_node(EShUsers *user);
static void free_all(ShareFolder *sf);
-
+static void update_list_update (ShareFolder *sf);
+static int find_node(GList *list, gchar *email);
+static void free_all(ShareFolder *sf);
+static void get_container_list (ShareFolder *sf);
+static void user_selected(GtkTreeSelection *selection, ShareFolder *sf);
+static void not_shared_clicked (GtkRadioButton *button, ShareFolder *sf);
+static void shared_clicked (GtkRadioButton *button, ShareFolder *sf);
+static void add_clicked(GtkButton *button, ShareFolder *sf);
+static void remove_clicked(GtkButton *button, ShareFolder *sf);
+static void not_ok_clicked(GtkButton *button, ShareFolder *sf);
+static void not_cancel_clicked(GtkButton *button, GtkWidget *window);
+static void not_cancel_clicked(GtkButton *button, GtkWidget *window);
+static void share_folder_construct (ShareFolder *sf);
+GType share_folder_get_type (void);
static GtkVBoxClass *parent_class = NULL;
@@ -50,7 +84,7 @@ share_folder_get_type (void)
NULL, NULL,
sizeof (ShareFolder),
0,
- (GInstanceInitFunc) share_folder_init,
+ (GInstanceInitFunc) share_folder_init
};
type = g_type_register_static (gtk_vbox_get_type (), "ShareFolder", &info, 0);
@@ -175,7 +209,7 @@ free_all(ShareFolder *sf)
}
-
+/* updates the rights in case changed in the prev selection*/
static void
update_list_update (ShareFolder *sf)
{
@@ -197,9 +231,27 @@ update_list_update (ShareFolder *sf)
if(delete){
rights = rights|0x4;
}
+
if(sf->update_list){
tmp = g_list_last(sf->update_list);
user = g_list_nth_data(tmp, 0);
+
+ if (sf->new_list && user->email){
+ sf->duplicate = find_node (sf->new_list, user->email);
+ if (sf->duplicate != -1) {
+ sf->update_list = g_list_remove(sf->update_list, user);
+ free_node (user);
+ if (g_list_length (sf->update_list) == 0)
+ sf->update_list = NULL;
+ user = g_list_nth_data (sf->new_list, sf->duplicate);
+ sf->duplicate = -1;
+ if(user->rights != rights)
+ user->rights= rights;
+
+ return ;
+ }
+ }
+
if(user){
if(user->rights != rights){
user->rights= rights;
@@ -227,14 +279,14 @@ display_container (EGwContainer *container , ShareFolder *sf)
gboolean byme = FALSE;
gboolean tome = FALSE;
- id_shared = e_gw_container_get_id(container);
+ id_shared = g_strdup(e_gw_container_get_id(container));
if( g_str_has_suffix (id_shared, "35")){
tail = g_strsplit(id_shared, "@", 2);
id_unshared = g_strconcat(tail[0], "@", "13", NULL);
g_strfreev(tail);
}
- if((!strcmp(id_unshared, sf->container_id)) ||(!strcmp(id_shared, sf->container_id)) ){
+ if((!strcmp(id_unshared, sf->container_id)) || (!strcmp(id_shared, sf->container_id)) ){
sf->gcontainer = container;
byme = e_gw_container_get_is_shared_by_me(container);
tome = e_gw_container_get_is_shared_to_me(container);
@@ -242,22 +294,23 @@ display_container (EGwContainer *container , ShareFolder *sf)
sf->users = e_gw_container_get_length (sf->gcontainer);
- if(sf->users != 0){
+ if(sf->users != 0) {
sf->is_shared = TRUE;
gtk_toggle_button_set_active((GtkToggleButton *) sf->shared, TRUE);
shared_clicked(sf->shared , sf);
if(tome){
- gtk_widget_set_sensitive (sf->table, FALSE);
- gtk_widget_set_sensitive (sf->shared, FALSE);
- gtk_widget_set_sensitive (sf->not_shared, FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->table), FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->shared), FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->not_shared), FALSE);
}
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->table), TRUE);
gchar *email= NULL;
gchar *msg;
- for(i = 0; i < sf->users; i++){
+ for(i = 0; i < sf->users; i++) {
- email = g_strdup (e_gw_container_get_email(container, i));
+ email = g_strdup (e_gw_container_get_email (sf->gcontainer, i));
msg = g_strdup_printf ("%s", email);
gtk_list_store_append (GTK_LIST_STORE (sf->model), &(sf->iter));
gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 0, msg, -1);
@@ -317,20 +370,20 @@ user_selected(GtkTreeSelection *selection, ShareFolder *sf)
gtk_tree_selection_set_mode(selection, GTK_SELECTION_SINGLE);
if (gtk_tree_selection_get_selected (selection, &(sf->model), &(sf->iter))){
- gtk_widget_set_sensitive (sf->frame, TRUE);
- gtk_widget_set_sensitive (sf->remove, TRUE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->frame), TRUE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->remove), TRUE);
- gtk_toggle_button_set_active (sf->add, FALSE);
- gtk_toggle_button_set_active (sf->del, FALSE);
- gtk_toggle_button_set_active (sf->edit, FALSE);
- gtk_tree_model_get (sf->model, &(sf->iter), 0, &email, -1);
- index = (gint)g_ascii_strtod(gtk_tree_model_get_string_from_iter(sf->model, &(sf->iter)), NULL);
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON ( sf->add), FALSE);
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sf->del), FALSE);
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sf->edit), FALSE);
+ gtk_tree_model_get (GTK_LIST_STORE (sf->model), &(sf->iter), 0, &email, -1);
+ index = (gint)g_ascii_strtod(gtk_tree_model_get_string_from_iter(GTK_LIST_STORE (sf->model), &(sf->iter)), NULL);
- gtk_label_set_text (sf->user_rights, email);
+ gtk_label_set_text (GTK_LABEL (sf->user_rights), email);
sf->duplicate = find_node(sf->update_list, email);
- if( sf->duplicate == -1){
- if (sf->shared && index < sf->users){
+ if( sf->duplicate == -1) {
+ if (sf->shared && index < sf->users) {
rights = e_gw_container_get_rights (sf->gcontainer, email);
} else {
user = g_list_nth_data (sf->new_list, index - sf->users);
@@ -341,22 +394,22 @@ user_selected(GtkTreeSelection *selection, ShareFolder *sf)
rights = user->rights;
sf->duplicate = -1;
}
- if(rights & 0x1)
- gtk_toggle_button_set_active (sf->add, TRUE);
- if(rights & 0x2)
- gtk_toggle_button_set_active (sf->edit, TRUE);
- if(rights & 0x4)
- gtk_toggle_button_set_active (sf->del, TRUE);
+ if (rights & 0x1)
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sf->add), TRUE);
+ if (rights & 0x2)
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sf->edit), TRUE);
+ if (rights & 0x4)
+ gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (sf->del), TRUE);
user = g_new0(EShUsers, 1);
user->email = g_strdup (email);
user->rights = rights;
- if(sf->duplicate != -1) {
+ if (sf->duplicate != -1) {
EShUsers *usr = NULL;
usr = g_list_nth_data (sf->update_list, sf->duplicate);
- if(usr){
+ if (usr) {
sf->update_list = g_list_remove (sf->update_list, usr);
free_node (usr);
}
@@ -369,8 +422,8 @@ user_selected(GtkTreeSelection *selection, ShareFolder *sf)
length = g_list_length (sf->update_list);
}
else {
- gtk_widget_set_sensitive (sf->frame, FALSE);
- gtk_widget_set_sensitive (sf->remove, FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->frame), FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->remove), FALSE);
}
@@ -386,7 +439,7 @@ static void
shared_clicked (GtkRadioButton *button, ShareFolder *sf)
{
- gtk_widget_set_sensitive (sf->table ,TRUE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->table) ,TRUE);
sf->flag_for_ok = 0;
}
@@ -396,17 +449,17 @@ not_shared_clicked (GtkRadioButton *button, ShareFolder *sf)
{
if (!sf->is_shared) {
sf->flag_for_ok = 0;
- }else{
+ } else {
sf->flag_for_ok = 2;
}
- gtk_widget_set_sensitive (sf->table, FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->table), FALSE);
}
-void
-add_clicked(GtkButton *button, ShareFolder *sf)
+static void
+add_clicked(GtkButton *button, ShareFolder *sf)
{
static gchar *email = NULL;
EShUsers *user = NULL;
@@ -416,18 +469,19 @@ add_clicked(GtkButton *button, ShareFolder *sf)
gchar *msg = NULL;
gboolean add,edit, delete;
- email = gtk_entry_get_text (sf->name);
+ email = gtk_entry_get_text (GTK_ENTRY (sf->name));
if (strcmp (email, "" )) {
update_list_update (sf);
user = g_new0 (EShUsers, 1);
user->email = g_strdup(email);
- }else{
+ } else {
return;
+
}
/*check whether already exists*/
e_gw_container_get_user_list (sf->gcontainer, &list);
- if(list && user->email){
+ if (list && user->email){
sf->duplicate = find_node (list, user->email);
if (sf->duplicate != -1) {
@@ -435,7 +489,7 @@ add_clicked(GtkButton *button, ShareFolder *sf)
return ;
}
}
- if(sf->new_list && user->email){
+ if (sf->new_list && user->email){
sf->duplicate = find_node (sf->new_list, user->email);
if (sf->duplicate != -1) {
@@ -444,21 +498,7 @@ add_clicked(GtkButton *button, ShareFolder *sf)
}
}
- add = gtk_toggle_button_get_active (sf->add);
- edit = gtk_toggle_button_get_active (sf->edit);
- delete = gtk_toggle_button_get_active (sf->del);
- if(add) {
- rights = rights|0x1;
- }
- if(edit) {
- rights = rights|0x2;
- }
- if(delete) {
- rights = rights|0x4;
- }
-
-
- e_gw_container_set_rights (user, rights);
+ user->rights = rights;
msg = g_strdup (user->email);
gtk_list_store_append (GTK_LIST_STORE (sf->model), &(sf->iter));
gtk_list_store_set (GTK_LIST_STORE (sf->model), &(sf->iter), 0, msg, -1);
@@ -470,7 +510,6 @@ add_clicked(GtkButton *button, ShareFolder *sf)
sf->flag_for_ok = 0;
gtk_entry_set_text (sf->name, "");
-
}
@@ -484,7 +523,7 @@ remove_clicked(GtkButton *button, ShareFolder *sf)
gchar *removed_addr;
/*check whether this is required*/
- gtk_tree_model_get (sf->model, &(sf->iter), 0, &email, -1);
+ gtk_tree_model_get (GTK_LIST_STORE(sf->model), &(sf->iter), 0, &email, -1);
list = g_list_last (sf->update_list);
usr = g_list_nth_data (list, 0);
@@ -544,17 +583,17 @@ share_folder (ShareFolder *sf)
if (sf->new_list) {
- if (e_gw_connection_share_folder (sf->cnc, sf->gcontainer, sf->new_list, sf->sub, sf->mesg, 0) == E_GW_CONNECTION_STATUS_OK);
+ if (e_gw_connection_share_folder (sf->cnc, sf->container_id, sf->new_list, sf->sub, sf->mesg, 0) == E_GW_CONNECTION_STATUS_OK);
}
if (sf->update_list) {
- if (e_gw_connection_share_folder (sf->cnc, sf->gcontainer, sf->update_list, sf->sub, sf->mesg, 2) == E_GW_CONNECTION_STATUS_OK);
+ if (e_gw_connection_share_folder (sf->cnc, sf->container_id, sf->update_list, sf->sub, sf->mesg, 2) == E_GW_CONNECTION_STATUS_OK);
}
}
if (sf->remove_list) {
- if (e_gw_connection_share_folder (sf->cnc, sf->gcontainer, sf->remove_list, sf->sub, sf->mesg, 1) == E_GW_CONNECTION_STATUS_OK);
+ if (e_gw_connection_share_folder (sf->cnc, sf->container_id, sf->remove_list, sf->sub, sf->mesg, 1) == E_GW_CONNECTION_STATUS_OK);
}
}
else
@@ -591,7 +630,7 @@ not_ok_clicked(GtkButton *button, ShareFolder *sf)
if(msg)
sf->mesg = msg;
- gtk_widget_destroy(sf->window);
+ gtk_widget_destroy (GTK_WIDGET (sf->window));
}
@@ -608,14 +647,13 @@ notification_clicked(GtkButton *button, ShareFolder *sf)
{
static GladeXML *xmln;
- GtkWidget *not_ok;
- GtkWidget *not_cancel;
- int length = 0;
-
+ GtkButton *not_ok;
+ GtkButton *not_cancel;
+
xmln = glade_xml_new (EVOLUTION_GLADEDIR "/properties.glade" ,"window1", NULL);
sf->window = GTK_WINDOW (glade_xml_get_widget (xmln, "window1"));
sf->subject = GTK_ENTRY (glade_xml_get_widget (xmln, "entry3"));
- gtk_entry_set_text(sf->subject , sf->sub);
+ gtk_entry_set_text(GTK_ENTRY (sf->subject) , sf->sub);
sf->message = GTK_TEXT_VIEW (glade_xml_get_widget (xmln, "textview1"));
not_ok = GTK_BUTTON (glade_xml_get_widget (xmln, "nOK"));
@@ -639,9 +677,8 @@ share_folder_construct (ShareFolder *sf)
sf->vbox = GTK_VBOX(glade_xml_get_widget(sf->xml, "vboxSharing"));
- sf->table = GTK_TABLE (glade_xml_get_widget (sf->xml, "table26"));
- if(!sf->table)
- gtk_widget_set_sensitive (sf->table, FALSE);
+ sf->table = GTK_WIDGET (glade_xml_get_widget (sf->xml, "table26"));
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->table), FALSE);
sf->shared = GTK_RADIO_BUTTON (glade_xml_get_widget (sf->xml, "radShared"));
g_signal_connect ((gpointer) sf->shared, "clicked", G_CALLBACK (shared_clicked), sf);
@@ -651,14 +688,14 @@ share_folder_construct (ShareFolder *sf)
sf->add_book = GTK_BUTTON (glade_xml_get_widget (sf->xml, "Address"));
- gtk_widget_set_sensitive (sf->add_book, FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (sf->add_book), FALSE);
sf->add_button = GTK_BUTTON (glade_xml_get_widget(sf->xml, "Add"));
g_signal_connect((GtkWidget *) sf->add_button, "clicked", G_CALLBACK (add_clicked), sf);
sf->remove = GTK_BUTTON(glade_xml_get_widget(sf->xml, "Remove"));
g_signal_connect ((GtkWidget *) sf->remove, "clicked", G_CALLBACK (remove_clicked), sf);
- gtk_widget_set_sensitive(sf->remove, FALSE);
+ gtk_widget_set_sensitive(GTK_WIDGET (sf->remove), FALSE);
sf->notification = GTK_BUTTON (glade_xml_get_widget (sf->xml, "Notification"));
g_signal_connect((GtkWidget *) sf->notification, "clicked", G_CALLBACK (notification_clicked), sf);
@@ -666,10 +703,10 @@ share_folder_construct (ShareFolder *sf)
sf->name = GTK_ENTRY (glade_xml_get_widget (sf->xml, "entry2"));
/*TODO:connect name and label*/
- gtk_widget_show(sf->name);
+ gtk_widget_show (GTK_WIDGET(sf->name));
sf->frame = GTK_FRAME (glade_xml_get_widget(sf->xml, "frame1"));
- gtk_widget_set_sensitive(sf->frame, FALSE);
+ gtk_widget_set_sensitive(GTK_WIDGET (sf->frame), FALSE);
sf->add = GTK_TOGGLE_BUTTON (glade_xml_get_widget (sf->xml, "checkbutton1"));
@@ -680,7 +717,7 @@ share_folder_construct (ShareFolder *sf)
sf->user_rights = GTK_LABEL (glade_xml_get_widget (sf->xml,"label550"));
- sf->scrolledwindow = GTK_SCROLLED_WINDOW (glade_xml_get_widget (sf->xml,"scrolledwindow1"));
+ sf->scrolledwindow = GTK_WIDGET (glade_xml_get_widget (sf->xml,"scrolledwindow1"));
gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sf->scrolledwindow), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
@@ -688,7 +725,7 @@ share_folder_construct (ShareFolder *sf)
sf->user_list = gtk_tree_view_new ();
gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (sf->scrolledwindow), sf->user_list);
gtk_tree_view_set_model (GTK_TREE_VIEW (sf->user_list), GTK_TREE_MODEL (sf->model));
- gtk_widget_show (sf->user_list);
+ gtk_widget_show (GTK_WIDGET (sf->user_list));
sf->cell = gtk_cell_renderer_text_new ();
@@ -696,7 +733,7 @@ share_folder_construct (ShareFolder *sf)
gtk_tree_view_append_column (GTK_TREE_VIEW (sf->user_list),
GTK_TREE_VIEW_COLUMN (sf->column));
- g_signal_connect(gtk_tree_view_get_selection(sf->user_list), "changed", G_CALLBACK (user_selected), sf);
+ g_signal_connect(gtk_tree_view_get_selection(GTK_TREE_VIEW (sf->user_list)), "changed", G_CALLBACK (user_selected), sf);
}