2
* Copyright (C) 2005-2007 Imendio AB
3
* Copyright (C) 2007-2011 Collabora Ltd.
5
* This program is free software; you can redistribute it and/or
6
* modify it under the terms of the GNU General Public License as
7
* published by the Free Software Foundation; either version 2 of the
8
* License, or (at your option) any later version.
10
* This program is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
* General Public License for more details.
15
* You should have received a copy of the GNU General Public
16
* License along with this program; if not, write to the
17
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
18
* Boston, MA 02110-1301 USA
20
* Authors: Mikael Hallendal <micke@imendio.com>
21
* Martyn Russell <martyn@imendio.com>
22
* Xavier Claessens <xclaesse@gmail.com>
23
* Travis Reitter <travis.reitter@collabora.co.uk>
31
#include <glib/gi18n-lib.h>
34
#include <folks/folks.h>
35
#include <folks/folks-telepathy.h>
36
#include <telepathy-glib/util.h>
38
#include <libempathy/empathy-utils.h>
39
#include <libempathy/empathy-enum-types.h>
40
#include <libempathy/empathy-individual-manager.h>
42
#include "empathy-individual-store-manager.h"
44
#include "empathy-ui-utils.h"
45
#include "empathy-gtk-enum-types.h"
47
#define DEBUG_FLAG EMPATHY_DEBUG_CONTACT
48
#include <libempathy/empathy-debug.h>
50
struct _EmpathyIndividualStoreManagerPriv
52
EmpathyIndividualManager *manager;
53
gboolean setup_idle_id;
59
PROP_INDIVIDUAL_MANAGER,
63
G_DEFINE_TYPE (EmpathyIndividualStoreManager, empathy_individual_store_manager,
64
EMPATHY_TYPE_INDIVIDUAL_STORE);
67
individual_store_manager_members_changed_cb (EmpathyIndividualManager *manager,
72
EmpathyIndividualStoreManager *self)
75
EmpathyIndividualStore *store = EMPATHY_INDIVIDUAL_STORE (self);
77
for (l = removed; l; l = l->next)
79
DEBUG ("Individual %s %s",
80
folks_individual_get_id (l->data), "removed");
82
individual_store_remove_individual_and_disconnect (store, l->data);
85
for (l = added; l; l = l->next)
87
DEBUG ("Individual %s %s", folks_individual_get_id (l->data), "added");
89
individual_store_add_individual_and_connect (store, l->data);
94
individual_store_manager_groups_changed_cb (EmpathyIndividualManager *manager,
95
FolksIndividual *individual,
98
EmpathyIndividualStoreManager *self)
100
EmpathyIndividualStore *store = EMPATHY_INDIVIDUAL_STORE (self);
102
DEBUG ("Updating groups for individual %s",
103
folks_individual_get_id (individual));
105
/* We do this to make sure the groups are correct, if not, we
106
* would have to check the groups already set up for each
107
* contact and then see what has been updated.
109
empathy_individual_store_refresh_individual (store, individual);
113
individual_store_manager_manager_setup (gpointer user_data)
115
EmpathyIndividualStoreManager *self = user_data;
118
/* Signal connection. */
120
DEBUG ("handling individual renames unimplemented");
122
g_signal_connect (self->priv->manager,
124
G_CALLBACK (individual_store_manager_members_changed_cb), self);
126
g_signal_connect (self->priv->manager,
128
G_CALLBACK (individual_store_manager_groups_changed_cb), self);
130
/* Add contacts already created. */
131
individuals = empathy_individual_manager_get_members (self->priv->manager);
132
if (individuals != NULL)
134
individual_store_manager_members_changed_cb (self->priv->manager, "initial add",
135
individuals, NULL, 0, self);
136
g_list_free (individuals);
139
self->priv->setup_idle_id = 0;
144
individual_store_manager_set_individual_manager (
145
EmpathyIndividualStoreManager *self,
146
EmpathyIndividualManager *manager)
148
g_assert (self->priv->manager == NULL); /* construct only */
149
self->priv->manager = g_object_ref (manager);
151
/* Let a chance to have all properties set before populating */
152
self->priv->setup_idle_id = g_idle_add (
153
individual_store_manager_manager_setup, self);
157
individual_store_manager_member_renamed_cb (EmpathyIndividualManager *manager,
158
FolksIndividual *old_individual,
159
FolksIndividual *new_individual,
161
const gchar *message,
162
EmpathyIndividualStoreManager *self)
164
EmpathyIndividualStore *store = EMPATHY_INDIVIDUAL_STORE (self);
166
DEBUG ("Individual %s renamed to %s",
167
folks_individual_get_id (old_individual),
168
folks_individual_get_id (new_individual));
170
/* remove old contact */
171
individual_store_remove_individual_and_disconnect (store, old_individual);
173
/* add the new contact */
174
individual_store_add_individual_and_connect (store, new_individual);
178
individual_store_manager_dispose (GObject *object)
180
EmpathyIndividualStoreManager *self = EMPATHY_INDIVIDUAL_STORE_MANAGER (
182
EmpathyIndividualStore *store = EMPATHY_INDIVIDUAL_STORE (object);
183
GList *individuals, *l;
185
individuals = empathy_individual_manager_get_members (self->priv->manager);
186
for (l = individuals; l; l = l->next)
188
empathy_individual_store_disconnect_individual (store,
189
FOLKS_INDIVIDUAL (l->data));
191
tp_clear_pointer (&individuals, g_list_free);
193
if (self->priv->manager != NULL)
195
g_signal_handlers_disconnect_by_func (self->priv->manager,
196
G_CALLBACK (individual_store_manager_member_renamed_cb), object);
197
g_signal_handlers_disconnect_by_func (self->priv->manager,
198
G_CALLBACK (individual_store_manager_members_changed_cb), object);
199
g_signal_handlers_disconnect_by_func (self->priv->manager,
200
G_CALLBACK (individual_store_manager_groups_changed_cb), object);
201
g_clear_object (&self->priv->manager);
204
if (self->priv->setup_idle_id != 0)
206
g_source_remove (self->priv->setup_idle_id);
207
self->priv->setup_idle_id = 0;
210
G_OBJECT_CLASS (empathy_individual_store_manager_parent_class)->dispose (
215
individual_store_manager_get_property (GObject *object,
220
EmpathyIndividualStoreManager *self = EMPATHY_INDIVIDUAL_STORE_MANAGER (
225
case PROP_INDIVIDUAL_MANAGER:
226
g_value_set_object (value, self->priv->manager);
229
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec);
235
individual_store_manager_set_property (GObject *object,
242
case PROP_INDIVIDUAL_MANAGER:
243
individual_store_manager_set_individual_manager (
244
EMPATHY_INDIVIDUAL_STORE_MANAGER (object),
245
g_value_get_object (value));
248
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec);
254
individual_store_manager_reload_individuals (EmpathyIndividualStore *store)
256
EmpathyIndividualStoreManager *self = EMPATHY_INDIVIDUAL_STORE_MANAGER (
260
contacts = empathy_individual_manager_get_members (self->priv->manager);
262
individual_store_manager_members_changed_cb (self->priv->manager,
263
"re-adding members: toggled group visibility",
264
contacts, NULL, 0, self);
266
g_list_free (contacts);
270
individual_store_manager_initial_loading (EmpathyIndividualStore *store)
272
EmpathyIndividualStoreManager *self = EMPATHY_INDIVIDUAL_STORE_MANAGER (
275
return self->priv->setup_idle_id != 0;
279
empathy_individual_store_manager_class_init (
280
EmpathyIndividualStoreManagerClass *klass)
282
GObjectClass *object_class = G_OBJECT_CLASS (klass);
283
EmpathyIndividualStoreClass *store_class = EMPATHY_INDIVIDUAL_STORE_CLASS (
286
object_class->dispose = individual_store_manager_dispose;
287
object_class->get_property = individual_store_manager_get_property;
288
object_class->set_property = individual_store_manager_set_property;
290
store_class->reload_individuals = individual_store_manager_reload_individuals;
291
store_class->initial_loading = individual_store_manager_initial_loading;
293
g_object_class_install_property (object_class,
294
PROP_INDIVIDUAL_MANAGER,
295
g_param_spec_object ("individual-manager",
296
"Individual manager",
297
"Individual manager",
298
EMPATHY_TYPE_INDIVIDUAL_MANAGER,
299
G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE));
301
g_type_class_add_private (object_class,
302
sizeof (EmpathyIndividualStoreManagerPriv));
306
empathy_individual_store_manager_init (EmpathyIndividualStoreManager *self)
308
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
309
EMPATHY_TYPE_INDIVIDUAL_STORE_MANAGER, EmpathyIndividualStoreManagerPriv);
312
EmpathyIndividualStoreManager *
313
empathy_individual_store_manager_new (EmpathyIndividualManager *manager)
315
g_return_val_if_fail (EMPATHY_IS_INDIVIDUAL_MANAGER (manager), NULL);
317
return g_object_new (EMPATHY_TYPE_INDIVIDUAL_STORE_MANAGER,
318
"individual-manager", manager, NULL);
321
EmpathyIndividualManager *
322
empathy_individual_store_manager_get_manager (
323
EmpathyIndividualStoreManager *self)
325
g_return_val_if_fail (EMPATHY_IS_INDIVIDUAL_STORE_MANAGER (self), FALSE);
327
return self->priv->manager;