aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-contact-list-view.c
diff options
context:
space:
mode:
authorxclaesse <xclaesse@4ee84921-47dd-4033-b63a-18d7a039a3e4>2007-09-11 17:26:52 +0800
committerxclaesse <xclaesse@4ee84921-47dd-4033-b63a-18d7a039a3e4>2007-09-11 17:26:52 +0800
commitb62c81bfb8d31980e785b7395549c7897450c6cb (patch)
tree8b4664d1b88b25ba55d32cf80a108bdd02b1c618 /libempathy-gtk/empathy-contact-list-view.c
parent81d3478ca631a61998a8c4a38f63b489b651c4a3 (diff)
downloadgsoc2013-empathy-b62c81bfb8d31980e785b7395549c7897450c6cb.tar
gsoc2013-empathy-b62c81bfb8d31980e785b7395549c7897450c6cb.tar.gz
gsoc2013-empathy-b62c81bfb8d31980e785b7395549c7897450c6cb.tar.bz2
gsoc2013-empathy-b62c81bfb8d31980e785b7395549c7897450c6cb.tar.lz
gsoc2013-empathy-b62c81bfb8d31980e785b7395549c7897450c6cb.tar.xz
gsoc2013-empathy-b62c81bfb8d31980e785b7395549c7897450c6cb.tar.zst
gsoc2013-empathy-b62c81bfb8d31980e785b7395549c7897450c6cb.zip
2007-09-11 Xavier Claessens <xclaesse@gmail.com>
* libempathy-gtk/empathy-main-window.c: * libempathy-gtk/empathy-group-chat.c: * libempathy-gtk/empathy-contact-list-view.c: * libempathy-gtk/empathy-contact-list-view.h: * doc/libempathy-gtk/tmpl/empathy-contact-list-view.sgml: "interactive" property on EmpathyContactListView to enable/disable contect menu and action when double-click on a contact. git-svn-id: svn+ssh://svn.gnome.org/svn/empathy/trunk@297 4ee84921-47dd-4033-b63a-18d7a039a3e4
Diffstat (limited to 'libempathy-gtk/empathy-contact-list-view.c')
-rw-r--r--libempathy-gtk/empathy-contact-list-view.c73
1 files changed, 61 insertions, 12 deletions
diff --git a/libempathy-gtk/empathy-contact-list-view.c b/libempathy-gtk/empathy-contact-list-view.c
index 8e6b2cf09..d4b222e4d 100644
--- a/libempathy-gtk/empathy-contact-list-view.c
+++ b/libempathy-gtk/empathy-contact-list-view.c
@@ -69,6 +69,7 @@ struct _EmpathyContactListViewPriv {
EmpathyContactListStore *store;
GtkUIManager *ui;
GtkTreeRowReference *drag_row;
+ gboolean interactive;
};
typedef struct {
@@ -182,6 +183,7 @@ static void contact_list_view_voip_activated (EmpathyContactLi
enum {
PROP_0,
+ PROP_INTERACTIVE
};
static const GtkActionEntry entries[] = {
@@ -313,6 +315,14 @@ empathy_contact_list_view_class_init (EmpathyContactListViewClass *klass)
G_TYPE_NONE,
3, EMPATHY_TYPE_CONTACT, G_TYPE_STRING, G_TYPE_STRING);
+ g_object_class_install_property (object_class,
+ PROP_INTERACTIVE,
+ g_param_spec_boolean ("interactive",
+ "View is interactive",
+ "Is the view interactive",
+ FALSE,
+ G_PARAM_READWRITE));
+
g_type_class_add_private (object_class, sizeof (EmpathyContactListViewPriv));
}
@@ -394,6 +404,9 @@ contact_list_view_get_property (GObject *object,
priv = GET_PRIV (object);
switch (param_id) {
+ case PROP_INTERACTIVE:
+ g_value_set_boolean (value, priv->interactive);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec);
break;
@@ -406,11 +419,15 @@ contact_list_view_set_property (GObject *object,
const GValue *value,
GParamSpec *pspec)
{
+ EmpathyContactListView *view = EMPATHY_CONTACT_LIST_VIEW (object);
EmpathyContactListViewPriv *priv;
priv = GET_PRIV (object);
switch (param_id) {
+ case PROP_INTERACTIVE:
+ empathy_contact_list_view_set_interactive (view, g_value_get_boolean (value));
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec);
break;
@@ -432,6 +449,28 @@ empathy_contact_list_view_new (EmpathyContactListStore *store)
return view;
}
+void
+empathy_contact_list_view_set_interactive (EmpathyContactListView *view,
+ gboolean interactive)
+{
+ EmpathyContactListViewPriv *priv = GET_PRIV (view);
+
+ g_return_if_fail (EMPATHY_IS_CONTACT_LIST_VIEW (view));
+
+ priv->interactive = interactive;
+ g_object_notify (G_OBJECT (view), "interactive");
+}
+
+gboolean
+empathy_contact_list_view_get_interactive (EmpathyContactListView *view)
+{
+ EmpathyContactListViewPriv *priv = GET_PRIV (view);
+
+ g_return_val_if_fail (EMPATHY_IS_CONTACT_LIST_VIEW (view), FALSE);
+
+ return priv->interactive;
+}
+
EmpathyContact *
empathy_contact_list_view_get_selected (EmpathyContactListView *view)
{
@@ -1192,12 +1231,12 @@ contact_list_view_button_press_event_cb (EmpathyContactListView *view,
gboolean row_exists;
GtkWidget *menu;
- if (event->button != 3) {
+ priv = GET_PRIV (view);
+
+ if (!priv->interactive || event->button != 3) {
return FALSE;
}
- priv = GET_PRIV (view);
-
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (view));
model = gtk_tree_view_get_model (GTK_TREE_VIEW (view));
@@ -1241,13 +1280,18 @@ contact_list_view_button_press_event_cb (EmpathyContactListView *view,
static void
contact_list_view_row_activated_cb (EmpathyContactListView *view,
- GtkTreePath *path,
- GtkTreeViewColumn *col,
- gpointer user_data)
+ GtkTreePath *path,
+ GtkTreeViewColumn *col,
+ gpointer user_data)
{
- EmpathyContact *contact;
- GtkTreeModel *model;
- GtkTreeIter iter;
+ EmpathyContactListViewPriv *priv = GET_PRIV (view);
+ EmpathyContact *contact;
+ GtkTreeModel *model;
+ GtkTreeIter iter;
+
+ if (!priv->interactive) {
+ return;
+ }
model = gtk_tree_view_get_model (GTK_TREE_VIEW (view));
@@ -1265,9 +1309,14 @@ contact_list_view_voip_activated_cb (EmpathyCellRendererActivatable *cell,
const gchar *path_string,
EmpathyContactListView *view)
{
- GtkTreeModel *model;
- GtkTreeIter iter;
- EmpathyContact *contact;
+ EmpathyContactListViewPriv *priv = GET_PRIV (view);
+ GtkTreeModel *model;
+ GtkTreeIter iter;
+ EmpathyContact *contact;
+
+ if (!priv->interactive) {
+ return;
+ }
model = gtk_tree_view_get_model (GTK_TREE_VIEW (view));
if (!gtk_tree_model_get_iter_from_string (model, &iter, path_string)) {