static const gchar *conv_services[] = {"RTCOM_EL_SERVICE_SMS",
"RTCOM_EL_SERVICE_CHAT",
NULL};
-static const gchar *conv_event_types[] = {"RTCOM_EL_EVENTTYPE_SMS_INBOUND",
- "RTCOM_EL_EVENTTYPE_CHAT_INBOUND",
+static const gchar *conv_event_types[] = {"RTCOM_EL_EVENTTYPE_SMS_MESSAGE",
+ "RTCOM_EL_EVENTTYPE_CHAT_MESSAGE",
NULL};
typedef enum {
show_event (ELHomeApplet *self, RTComElIter *it)
{
ELHomeAppletPrivate *priv = self->priv;
- const gchar *remote = NULL;
+ gchar *remote = NULL;
gchar *received = NULL;
- GValueArray *event = NULL;
if (it && rtcom_el_iter_first (it)) {
-
- event = rtcom_el_iter_get_valuearray (it,
- "id",
- "start-time",
- "local-uid",
- "remote-uid",
- "remote-name",
- "remote-ebook-uid",
- "free-text",
- "group-uid",
- NULL);
- if (event) {
- time_t received_t;
-#define _VARR_DUP_STR(array, i) g_value_dup_string (g_value_array_get_nth ((array), (i)))
-
- priv->event_id = g_value_get_int (g_value_array_get_nth (event, 0));
- received_t = g_value_get_int (g_value_array_get_nth (event, 1));
+ time_t received_t;
+
+ if (rtcom_el_iter_get_values (it,
+ "id", &priv->event_id,
+ "start-time", &received_t,
+ "local-uid", &priv->local_id,
+ "remote-uid", &priv->remote_id,
+ "remote-name", &remote,
+ "remote-ebook-uid", &priv->contact_id,
+ "free-text", &priv->message,
+ "group-uid", &priv->group_uid,
+ NULL)) {
received = format_time (received_t, priv->time_fmt_24h);
- priv->local_id = _VARR_DUP_STR (event, 2);
- priv->remote_id = _VARR_DUP_STR (event, 3);
- if (priv->remote_id && priv->remote_id[0]) {
- remote = g_value_get_string (g_value_array_get_nth (event, 4));
- if (!remote)
- remote = priv->remote_id;
- priv->contact_id = _VARR_DUP_STR (event, 5);
- }
- else if (priv->remote_id) {
+
+ if (priv->remote_id && !priv->remote_id[0]) {
g_free (priv->remote_id);
priv->remote_id = NULL;
}
-
- priv->message = _VARR_DUP_STR (event, 6);
- priv->group_uid = _VARR_DUP_STR (event, 7);
-
-#undef _VARR_DUP_STR
}
+ else
+ priv->event_id = -1;
}
- else {
+ else
priv->event_id = -1;
- }
- if (priv->message) {
+ if (priv->message)
gtk_widget_hide (priv->empty);
- }
- else {
+ else
gtk_widget_show (priv->empty);
- }
gtk_label_set_text (GTK_LABEL (priv->received), received);
- if (remote)
+ if (remote && remote[0])
gtk_label_set_text (GTK_LABEL (priv->sender), remote);
else
gtk_label_set_text (GTK_LABEL (priv->sender), priv->remote_id);
priv->message_surface = NULL;
}
- if (event)
- g_value_array_free (event);
-
gtk_widget_hide (priv->cut_message);
gtk_widget_queue_draw (GTK_WIDGET (self));
}
else {
rtcom_el_query_prepare (query,
"is-read", FALSE, RTCOM_EL_OP_EQUAL,
+ "outgoing", FALSE, RTCOM_EL_OP_EQUAL,
"service", conv_services, RTCOM_EL_OP_IN_STRV,
"event-type", conv_event_types, RTCOM_EL_OP_IN_STRV,
NULL);