diff --git a/src/calls-call-display.c b/src/calls-call-display.c
index 1fab03b..737a882 100644
--- a/src/calls-call-display.c
+++ b/src/calls-call-display.c
@@ -42,12 +42,13 @@ struct _CallsCallDisplay
guint timeout;
GtkBox *party_box;
- GtkLabel *name;
+ GtkLabel *primary_contact_info;
+ GtkLabel *secondary_contact_info;
GtkLabel *status;
GtkLabel *time;
GtkButton *answer;
- GtkToggleButton *hold;
+ GtkToggleButton *mute;
GtkButton *hang_up;
GtkToggleButton *speaker;
};
@@ -86,7 +87,7 @@ hang_up_clicked_cb (GtkButton *button,
}
static void
-hold_toggled_cb (GtkToggleButton *togglebutton,
+mute_toggled_cb (GtkToggleButton *togglebutton,
CallsCallDisplay *self)
{
}
@@ -135,7 +136,7 @@ timeout_cb (CallsCallDisplay *self)
}
minutes = (guint)(elapsed / MINUTE);
- g_string_append_printf (str, "%u:", minutes);
+ g_string_append_printf (str, "%02u:", minutes);
elapsed -= (minutes * MINUTE);
g_string_append_printf (str, "%02u", (guint)elapsed);
@@ -166,7 +167,7 @@ call_state_changed_cb (CallsCallDisplay *self,
{
case CALLS_CALL_STATE_INCOMING:
gtk_widget_show (GTK_WIDGET (self->answer));
- gtk_widget_hide (GTK_WIDGET (self->hold));
+ gtk_widget_hide (GTK_WIDGET (self->mute));
gtk_widget_hide (GTK_WIDGET (self->speaker));
break;
case CALLS_CALL_STATE_ACTIVE:
@@ -175,7 +176,7 @@ call_state_changed_cb (CallsCallDisplay *self,
case CALLS_CALL_STATE_ALERTING:
case CALLS_CALL_STATE_WAITING:
gtk_widget_hide (GTK_WIDGET (self->answer));
- gtk_widget_show (GTK_WIDGET (self->hold));
+ gtk_widget_show (GTK_WIDGET (self->mute));
gtk_widget_show (GTK_WIDGET (self->speaker));
break;
case CALLS_CALL_STATE_DISCONNECTED:
@@ -209,13 +210,18 @@ static void
set_party (CallsCallDisplay *self, CallsParty *party)
{
GtkWidget *image;
+ const gchar *name, *number;
image = calls_party_create_image (party);
gtk_box_pack_start (self->party_box, image, TRUE, TRUE, 0);
gtk_image_set_pixel_size (GTK_IMAGE (image), 100);
gtk_widget_show (image);
- gtk_label_set_text (self->name, calls_party_get_label (party));
+ name = calls_party_get_name (party);
+ number = calls_party_get_number (party);
+
+ gtk_label_set_text (self->primary_contact_info, name != NULL ? name : number);
+ gtk_label_set_text (self->secondary_contact_info, name != NULL ? number : NULL);
}
@@ -313,15 +319,16 @@ calls_call_display_class_init (CallsCallDisplayClass *klass)
gtk_widget_class_set_template_from_resource (widget_class, "/sm/puri/calls/ui/call-display.ui");
gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, party_box);
- gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, name);
+ gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, primary_contact_info);
+ gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, secondary_contact_info);
gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, status);
gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, time);
gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, answer);
- gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, hold);
+ gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, mute);
gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, hang_up);
gtk_widget_class_bind_template_child (widget_class, CallsCallDisplay, speaker);
gtk_widget_class_bind_template_callback (widget_class, answer_clicked_cb);
gtk_widget_class_bind_template_callback (widget_class, hang_up_clicked_cb);
- gtk_widget_class_bind_template_callback (widget_class, hold_toggled_cb);
+ gtk_widget_class_bind_template_callback (widget_class, mute_toggled_cb);
gtk_widget_class_bind_template_callback (widget_class, speaker_toggled_cb);
}
diff --git a/src/calls-encryption-indicator.c b/src/calls-encryption-indicator.c
new file mode 100644
index 0000000..63aca8a
--- /dev/null
+++ b/src/calls-encryption-indicator.c
@@ -0,0 +1,138 @@
+/*
+ * Copyright (C) 2018 Purism SPC
+ *
+ * This file is part of Calls.
+ *
+ * Calls is free software: you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Calls 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 Calls. If not, see .
+ *
+ * Author: Adrien Plazas
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ *
+ */
+
+#include "calls-encryption-indicator.h"
+
+#include
+
+struct _CallsEncryptionIndicator
+{
+ GtkStack parent_instance;
+
+ GtkBox *is_not_encrypted;
+ GtkBox *is_encrypted;
+};
+
+G_DEFINE_TYPE (CallsEncryptionIndicator, calls_encryption_indicator, GTK_TYPE_STACK);
+
+enum {
+ PROP_0,
+ PROP_ENCRYPTED,
+ PROP_LAST_PROP,
+};
+static GParamSpec *props[PROP_LAST_PROP];
+
+
+void
+calls_encryption_indicator_set_encrypted (CallsEncryptionIndicator *self,
+ gboolean encrypted)
+{
+ g_return_if_fail (CALLS_IS_ENCRYPTION_INDICATOR (self));
+
+ encrypted = !!encrypted;
+
+ gtk_stack_set_visible_child (
+ GTK_STACK (self),
+ GTK_WIDGET (encrypted ? self->is_encrypted : self->is_not_encrypted));
+}
+
+
+gboolean
+calls_encryption_indicator_get_encrypted (CallsEncryptionIndicator *self)
+{
+ g_return_val_if_fail (CALLS_IS_ENCRYPTION_INDICATOR (self), FALSE);
+
+ return gtk_stack_get_visible_child (GTK_STACK (self)) == GTK_WIDGET (self->is_encrypted);
+}
+
+
+static void
+calls_encryption_indicator_init (CallsEncryptionIndicator *self)
+{
+ gtk_widget_init_template (GTK_WIDGET (self));
+}
+
+
+static void
+set_property (GObject *object,
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ CallsEncryptionIndicator *self = CALLS_ENCRYPTION_INDICATOR (object);
+
+ switch (property_id) {
+ case PROP_ENCRYPTED:
+ calls_encryption_indicator_set_encrypted (self, g_value_get_boolean (value));
+ break;
+
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ break;
+ }
+}
+
+
+static void
+get_property (GObject *object,
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ CallsEncryptionIndicator *self = CALLS_ENCRYPTION_INDICATOR (object);
+
+ switch (property_id) {
+ case PROP_ENCRYPTED:
+ g_value_set_boolean (value, calls_encryption_indicator_get_encrypted (self));
+ break;
+
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ break;
+ }
+}
+
+
+static void
+calls_encryption_indicator_class_init (CallsEncryptionIndicatorClass *klass)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+ GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
+
+ object_class->set_property = set_property;
+ object_class->get_property = get_property;
+
+ props[PROP_ENCRYPTED] =
+ g_param_spec_boolean ("encrypted",
+ _("Encrypted"),
+ _("The party participating in the call"),
+ FALSE,
+ G_PARAM_READWRITE);
+
+ g_object_class_install_properties (object_class, PROP_LAST_PROP, props);
+ gtk_widget_class_set_template_from_resource (widget_class, "/sm/puri/calls/ui/encryption-indicator.ui");
+ gtk_widget_class_bind_template_child (widget_class, CallsEncryptionIndicator, is_not_encrypted);
+ gtk_widget_class_bind_template_child (widget_class, CallsEncryptionIndicator, is_encrypted);
+}
+
diff --git a/src/calls-encryption-indicator.h b/src/calls-encryption-indicator.h
new file mode 100644
index 0000000..2e891fa
--- /dev/null
+++ b/src/calls-encryption-indicator.h
@@ -0,0 +1,45 @@
+/*
+ * Copyright (C) 2018 Purism SPC
+ *
+ * This file is part of Calls.
+ *
+ * Calls is free software: you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Calls 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 Calls. If not, see .
+ *
+ * Author: Adrien Plazas
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ *
+ */
+
+#ifndef CALLS_ENCRYPTION_INDICATOR_H__
+#define CALLS_ENCRYPTION_INDICATOR_H__
+
+#include
+
+G_BEGIN_DECLS
+
+#define CALLS_TYPE_ENCRYPTION_INDICATOR (calls_encryption_indicator_get_type ())
+
+G_DECLARE_FINAL_TYPE (CallsEncryptionIndicator, calls_encryption_indicator, CALLS, ENCRYPTION_INDICATOR, GtkStack);
+
+
+void calls_encryption_indicator_set_encrypted (CallsEncryptionIndicator *self,
+ gboolean encrypted);
+gboolean calls_encryption_indicator_get_encrypted (CallsEncryptionIndicator *self);
+
+
+G_END_DECLS
+
+#endif /* CALLS_ENCRYPTION_INDICATOR_H__ */
+
diff --git a/src/calls-party.c b/src/calls-party.c
index 8c70b66..cc45fbc 100644
--- a/src/calls-party.c
+++ b/src/calls-party.c
@@ -73,7 +73,7 @@ calls_party_new (const gchar *name, const gchar *number)
GtkWidget *
calls_party_create_image (CallsParty *party)
{
- return gtk_image_new_from_icon_name ("face-smile", GTK_ICON_SIZE_DIALOG);
+ return gtk_image_new_from_icon_name ("avatar-default-symbolic", GTK_ICON_SIZE_DIALOG);
}
diff --git a/src/calls.gresources.xml b/src/calls.gresources.xml
index 6912186..cbaa257 100644
--- a/src/calls.gresources.xml
+++ b/src/calls.gresources.xml
@@ -4,5 +4,6 @@
main-window.ui
call-display.ui
call-selector-item.ui
+ encryption-indicator.ui
diff --git a/src/main.c b/src/main.c
index 1c2dc55..f240cd9 100644
--- a/src/main.c
+++ b/src/main.c
@@ -27,6 +27,7 @@
#define HANDY_USE_UNSTABLE_API
#include
+#include "calls-encryption-indicator.h"
#include "calls-main-window.h"
#include "calls-ofono-provider.h"
@@ -38,6 +39,7 @@ show_window (GtkApplication *app)
CallsProvider *provider;
CallsMainWindow *main_window;
+ CALLS_TYPE_ENCRYPTION_INDICATOR;
HDY_TYPE_DIALER;
connection = g_bus_get_sync (G_BUS_TYPE_SYSTEM, NULL, &error);
diff --git a/src/meson.build b/src/meson.build
index 204f8fe..7d987ef 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -40,6 +40,7 @@ calls_sources = ['calls-message-source.c', 'calls-message-source.h',
'calls-call-holder.c', 'calls-call-holder.h',
'calls-call-display.c', 'calls-call-display.h',
'calls-call-selector-item.c', 'calls-call-selector-item.h',
+ 'calls-encryption-indicator.c', 'calls-encryption-indicator.h',
'calls-main-window.c', 'calls-main-window.h',
'util.c', 'util.h',
]
diff --git a/src/ui/call-display.ui b/src/ui/call-display.ui
index b025f48..c07f4c5 100644
--- a/src/ui/call-display.ui
+++ b/src/ui/call-display.ui
@@ -5,31 +5,40 @@
True
False
+ center
+ 8
+ 12
+ 12
+ 8
vertical
+ center
+ 300
-
- True
-
@@ -47,7 +56,12 @@
True
False
- 0:00
+ 00:00
+ 30
+ 40
+
+
+
@@ -64,50 +78,99 @@
True
False
+ 12
+ True
+ 65
+ 65
-
- Hold
+
True
True
True
True
-
+
+
+
+ True
+ False
+ microphone-sensitivity-muted-symbolic
+ 3
+
+
-
- Hang up
+
True
True
True
-
+ True
+
+
+ True
+ False
+ input-dialpad-symbolic
+ 3
+
+
-
- True
-
- Speaker
True
True
True
True
+
+
+ True
+ False
+ audio-volume-high-symbolic
+ 3
+
+
+
+
+
+
+
+
+ False
+ 30
+ True
+
+
+
+
+ True
+ True
+ center
+ 65
+ False
+ start
+ True
+ 150
+
+
+
+
+ Hang up
+
+
+
+
+ True
+ call-stop-symbolic
+ 5
-
- True
-
-
-
-
-
-
-
diff --git a/src/ui/encryption-indicator.ui b/src/ui/encryption-indicator.ui
new file mode 100644
index 0000000..32adc20
--- /dev/null
+++ b/src/ui/encryption-indicator.ui
@@ -0,0 +1,52 @@
+
+
+
+
+
+ False
+
+
+ False
+ 6
+ center
+ True
+
+
+ True
+ changes-allow-symbolic
+ 1
+
+
+
+
+ False
+ This call is not encrypted
+ True
+
+
+
+
+
+
+ False
+ 6
+ center
+ True
+
+
+ True
+ changes-prevent-symbolic
+ 1
+
+
+
+
+ False
+ This call is encrypted
+ True
+
+
+
+
+
+