diff options
author | Emilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk> | 2011-04-29 20:05:50 +0800 |
---|---|---|
committer | Danielle Madeley <danielle.madeley@collabora.co.uk> | 2011-10-21 14:04:50 +0800 |
commit | cac6aa1626dcfe6c3503ee78c863f218c6a26551 (patch) | |
tree | e21a676035c87341abaacf40607f9db0bb5a161b /src | |
parent | 1cc11526cb28298f79ba6b194abfe24b14b229cd (diff) | |
download | gsoc2013-empathy-cac6aa1626dcfe6c3503ee78c863f218c6a26551.tar.gz gsoc2013-empathy-cac6aa1626dcfe6c3503ee78c863f218c6a26551.tar.zst gsoc2013-empathy-cac6aa1626dcfe6c3503ee78c863f218c6a26551.zip |
Show an infobar if there's not enough credit
With a button to buy some if desired.
Diffstat (limited to 'src')
-rw-r--r-- | src/empathy-call-handler.c | 9 | ||||
-rw-r--r-- | src/empathy-call-window.c | 103 |
2 files changed, 106 insertions, 6 deletions
diff --git a/src/empathy-call-handler.c b/src/empathy-call-handler.c index 9fe89337d..0f197bf5d 100644 --- a/src/empathy-call-handler.c +++ b/src/empathy-call-handler.c @@ -190,13 +190,18 @@ static void on_call_state_changed_cb (TpyCallChannel *call, TpyCallState state, TpyCallFlags flags, - const GValueArray *call_state_reason, + const GValueArray *call_state_reason, GHashTable *call_state_details, EmpathyCallHandler *handler) { EmpathyCallHandlerPriv *priv = handler->priv; + gchar *dbus_reason; + guint actor, reason; - g_signal_emit (handler, signals[STATE_CHANGED], 0, state); + tp_value_array_unpack ((GValueArray *) call_state_reason, 3, + &actor, &reason, &dbus_reason); + + g_signal_emit (handler, signals[STATE_CHANGED], 0, state, dbus_reason); if (state == TPY_CALL_STATE_ENDED) { diff --git a/src/empathy-call-window.c b/src/empathy-call-window.c index d2e32a10a..2ec79516e 100644 --- a/src/empathy-call-window.c +++ b/src/empathy-call-window.c @@ -2893,14 +2893,37 @@ empathy_call_window_update_timer (gpointer user_data) return TRUE; } -#if 0 +enum +{ + EMP_RESPONSE_BALANCE +}; + +static void +on_error_infobar_response_cb (GtkInfoBar *info_bar, + gint response_id, + gpointer user_data) +{ + switch (response_id) + { + case GTK_RESPONSE_CLOSE: + gtk_widget_destroy (GTK_WIDGET (info_bar)); + break; + case EMP_RESPONSE_BALANCE: + empathy_url_show (GTK_WIDGET (info_bar), + g_object_get_data (G_OBJECT (info_bar), "uri")); + break; + } +} + static void display_error (EmpathyCallWindow *self, - TpyCallChannel *call, const gchar *img, const gchar *title, const gchar *desc, - const gchar *details) + const gchar *details, + const gchar *button_text, + const gchar *uri, + gint button_response) { EmpathyCallWindowPriv *priv = GET_PRIV (self); GtkWidget *info_bar; @@ -2915,6 +2938,14 @@ display_error (EmpathyCallWindow *self, info_bar = gtk_info_bar_new_with_buttons (GTK_STOCK_CLOSE, GTK_RESPONSE_CLOSE, NULL); + if (button_text != NULL) + { + gtk_info_bar_add_button (GTK_INFO_BAR (info_bar), + button_text, button_response); + g_object_set_data_full (G_OBJECT (info_bar), + "uri", g_strdup (uri), g_free); + } + gtk_info_bar_set_message_type (GTK_INFO_BAR (info_bar), GTK_MESSAGE_WARNING); content_area = gtk_info_bar_get_content_area (GTK_INFO_BAR (info_bar)); @@ -2962,13 +2993,14 @@ display_error (EmpathyCallWindow *self, } g_signal_connect (info_bar, "response", - G_CALLBACK (gtk_widget_destroy), NULL); + G_CALLBACK (on_error_infobar_response_cb), NULL); gtk_box_pack_start (GTK_BOX (priv->errors_vbox), info_bar, FALSE, FALSE, CONTENT_HBOX_CHILDREN_PACKING_PADDING); gtk_widget_show_all (info_bar); } +#if 0 static gchar * media_stream_error_to_txt (EmpathyCallWindow *self, TpyCallChannel *call, @@ -3088,14 +3120,77 @@ empathy_call_window_video_stream_error (TpyCallChannel *call, #endif static void +show_balance_error (GObject *object, + GAsyncResult *res, + gpointer user_data) +{ + EmpathyCallWindow *self = user_data; + TpConnection *conn = TP_CONNECTION (object); + GError *error = NULL; + gchar *balance, *tmp; + const gchar *uri, *currency; + gint amount; + guint scale; + + if (!tp_proxy_prepare_finish (conn, res, &error)) + { + DEBUG ("Failed to prepare Balance: %s", error->message); + g_error_free (error); + return; + } + + uri = tp_connection_get_balance_uri (conn); + + if (!tp_connection_get_balance (conn, &amount, &scale, ¤cy)) + { + /* unknown balance */ + balance = g_strdup ("(--)"); + } + else + { + char *money = empathy_format_currency (amount, scale, currency); + + balance = g_strdup_printf ("%s %s", + currency, money); + g_free (money); + } + + display_error (self, + NULL, + _("Sorry, you don’t have enough credit for that call."), + tmp = g_strdup_printf (_("Your current balance is %s."), + balance), + NULL, + _("Get credit..."), + uri, + EMP_RESPONSE_BALANCE); + g_free (tmp); +} + +static void empathy_call_window_state_changed_cb (EmpathyCallHandler *handler, TpyCallState state, + gchar *reason, EmpathyCallWindow *self) { EmpathyCallWindowPriv *priv = GET_PRIV (self); TpyCallChannel *call; gboolean can_send_video; + if (state == TPY_CALL_STATE_ENDED && + !tp_strdiff (reason, TP_ERROR_STR_INSUFFICIENT_BALANCE)) + { + TpConnection *conn; + GQuark features[] = { TP_CONNECTION_FEATURE_BALANCE, 0 }; + + g_object_get (self->priv->handler, "call-channel", &call, NULL); + conn = tp_channel_borrow_connection (TP_CHANNEL (call)); + g_object_unref (call); + + tp_proxy_prepare_async (conn, features, show_balance_error, self); + return; + } + if (state != TPY_CALL_STATE_ACCEPTED) return; |