diff --git a/res/layout-sw400dp/activity_pn_mode.xml b/res/layout-sw400dp/activity_pn_mode.xml
index e2e5433453..5efbf059bd 100644
--- a/res/layout-sw400dp/activity_pn_mode.xml
+++ b/res/layout-sw400dp/activity_pn_mode.xml
@@ -1,114 +1,116 @@
-
+ android:layout_height="match_parent"
+ android:background="@drawable/default_session_background"
+ android:orientation="vertical">
-
+
+
+ android:layout_marginLeft="@dimen/very_large_spacing"
+ android:layout_marginRight="@dimen/very_large_spacing"
+ android:textSize="@dimen/very_large_font_size"
+ android:textStyle="bold"
+ android:textColor="@color/text"
+ android:text="Message Notifications" />
+
+
+
+
-
-
+ android:textStyle="bold"
+ android:text="Fast Mode" />
-
+ android:layout_marginTop="4dp"
+ android:textSize="@dimen/very_small_font_size"
+ android:textColor="@color/text"
+ android:text="You’ll be notified of new messages reliably and immediately using Google’s notification servers. The contents of your messages, and who you’re messaging, are never exposed to Google." />
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+ android:layout_marginTop="4dp"
+ android:textSize="@dimen/small_font_size"
+ android:textColor="@color/accent"
+ android:textStyle="bold"
+ android:text="@string/activity_pn_mode_recommended_option_tag" />
-
\ No newline at end of file
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/res/layout-sw400dp/fragment_pn_mode_bottom_sheet.xml b/res/layout-sw400dp/fragment_pn_mode_bottom_sheet.xml
deleted file mode 100644
index 0b01b12fdc..0000000000
--- a/res/layout-sw400dp/fragment_pn_mode_bottom_sheet.xml
+++ /dev/null
@@ -1,118 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/res/layout/activity_pn_mode.xml b/res/layout/activity_pn_mode.xml
index f8b2b75145..1b4897ae7d 100644
--- a/res/layout/activity_pn_mode.xml
+++ b/res/layout/activity_pn_mode.xml
@@ -1,114 +1,116 @@
-
+ android:layout_height="match_parent"
+ android:background="@drawable/default_session_background"
+ android:orientation="vertical">
-
+
+
+ android:layout_marginLeft="@dimen/very_large_spacing"
+ android:layout_marginRight="@dimen/very_large_spacing"
+ android:textSize="@dimen/large_font_size"
+ android:textStyle="bold"
+ android:textColor="@color/text"
+ android:text="Message Notifications" />
+
+
+
+
+ android:text="Fast Mode" />
+ android:text="You’ll be notified of new messages reliably and immediately using Google’s notification servers. The contents of your messages, and who you’re messaging, are never exposed to Google." />
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+ android:layout_marginTop="4dp"
+ android:textSize="@dimen/small_font_size"
+ android:textColor="@color/accent"
+ android:textStyle="bold"
+ android:text="@string/activity_pn_mode_recommended_option_tag" />
-
\ No newline at end of file
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/res/layout/fragment_pn_mode_bottom_sheet.xml b/res/layout/fragment_pn_mode_bottom_sheet.xml
deleted file mode 100644
index 48fc5f3a31..0000000000
--- a/res/layout/fragment_pn_mode_bottom_sheet.xml
+++ /dev/null
@@ -1,118 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/res/menu/menu_pn_mode.xml b/res/menu/menu_pn_mode.xml
new file mode 100644
index 0000000000..9fd06956f5
--- /dev/null
+++ b/res/menu/menu_pn_mode.xml
@@ -0,0 +1,11 @@
+
+
diff --git a/res/values-de/strings.xml b/res/values-de/strings.xml
index f43ff74c6b..61ac8b96ec 100644
--- a/res/values-de/strings.xml
+++ b/res/values-de/strings.xml
@@ -1341,12 +1341,6 @@ Schlüsselaustausch-Nachricht für eine ungültige Protokollversion empfangenBitte wählen Sie einen Anzeigenamen, der nur aus den Zeichen a - z, A - Z, 0 - 9 und _ besteht.
Bitte wählen Sie einen kürzeren Anzeigenamen
- Benachrichtigungen
- Session verfügt über zwei Methoden zur Verarbeitung von Benachrichtigungen. Lesen Sie die Beschreibungen sorgfältig, bevor Sie sich entscheiden.
- Firebase Cloud Messaging
- Session verwendet den Firebase Cloud Messaging-Dienst, um Push-Benachrichtigungen zu empfangen. Sie werden zuverlässig und sofort über neue Nachrichten informiert. Die Verwendung von FCM bedeutet, dass Ihre IP-Adresse und Ihr Geräte-Token für Google verfügbar sind. Wenn Sie Push-Benachrichtigungen anderer Apps verwenden, ist dies auch der Fall. Auch Loki erfährt Ihre IP-Adresse und Ihren Geräte-Token, jedoch werden Ihre Nachrichten weiterhin per Onion geroutet und durchgängig verschlüsselt, sodass der Inhalt Ihrer Nachrichten vollständig privat bleibt.
- Hintergrundabfrage
- Session sucht von Zeit zu Zeit im Hintergrund nach neuen Nachrichten. Das garantiert einen vollständigen Schutz der Metadaten, aber Benachrichtigungen können sich jedoch erheblich verzögern.EmpfohlenBitte wählen Sie eine Option aus.
@@ -1357,17 +1351,6 @@ Schlüsselaustausch-Nachricht für eine ungültige Protokollversion empfangenMöchten Sie diese Unterhaltung wirklich löschen?
Die Unterhaltung wurde gelöscht.
- Benachrichtigungen
- Session verfügt über zwei Methoden zur Verarbeitung von Benachrichtigungen. Lesen Sie die Beschreibungen sorgfältig, bevor Sie sich entscheiden.
- Firebase Cloud Messaging
- Session verwendet den Firebase Cloud Messaging-Dienst, um Push-Benachrichtigungen zu empfangen. Sie werden zuverlässig und sofort über neue Nachrichten informiert. Die Verwendung von FCM bedeutet, dass Ihre IP-Adresse und Ihr Geräte-Token für Google verfügbar sind. Wenn Sie Push-Benachrichtigungen anderer Apps verwenden, ist dies auch der Fall. Auch Loki erfährt Ihre IP-Adresse und Ihren Geräte-Token, jedoch werden Ihre Nachrichten weiterhin per Onion geroutet und durchgängig verschlüsselt, sodass der Inhalt Ihrer Nachrichten vollständig privat bleibt.
- Hintergrundabfrage
- Session sucht von Zeit zu Zeit im Hintergrund nach neuen Nachrichten. Das garantiert einen vollständigen Schutz der Metadaten, aber Benachrichtigungen können sich jedoch erheblich verzögern.
- Empfohlen
- Bitte wählen Sie eine Option aus.
- Bestätigen
- Überspringen
-
Ihr WiederherstellungssatzDas ist Ihr Wiederherstellungssatz.Ihr Wiederherstellungssatz ist der Hauptschlüssel für Ihre Session ID. Mit diesem Satz können Sie Ihre Session ID wiederherstellen, wenn Sie den Zugriff auf Ihr Gerät verlieren. Bewahren Sie Ihren Wiederherstellungssatz an einem sicheren Ort auf und geben Sie ihn an niemandem weiter.
@@ -1414,7 +1397,6 @@ Schlüsselaustausch-Nachricht für eine ungültige Protokollversion empfangenScannen Sie den QR-Code der offenen Gruppe, der Sie beitreten möchten.
Geben Sie eine offene Gruppen-URL ein.
- Offenen Gruppen kann jeder beitreten und sie bieten keinen vollständigen Schutz der Privatsphäre.EinstellungenGeben Sie einen Anzeigenamen ein.
@@ -1446,8 +1428,6 @@ Schlüsselaustausch-Nachricht für eine ungültige Protokollversion empfangenGerät (Beta) verknüpfen
Benachrichtigungsstrategie
- FCM verwenden
- Die Verwendung von Firebase Cloud Messaging ermöglicht zuverlässigere Push-Benachrichtigungen, Ihre IP- und Geräte-Token werden Google und Loki jedoch bekannt.Warten auf AutorisierungGeräteverbindung autorisiert
@@ -1481,16 +1461,6 @@ Schlüsselaustausch-Nachricht für eine ungültige Protokollversion empfangenDas ist Ihr QR-Code. Andere Benutzer können ihn scannen, um eine Session mit Ihnen zu starten.
QR-Code freigeben
- Akzeptieren
- Ablehnen
- %1$s hat Ihnen eine Session-Anfrage gesendet.
- Sie haben die Session-Anfrage von %1$s akzeptiert.
- Sie haben die Session-Anfrage von %1$s abgelehnt.
- Die Session-Anfragte von %1$s ist abgelaufen.
- Sie haben %1$s eine Session-Anfrage gesendet.
- %1$s hat Ihre Session-Anfrage akzeptiert.
- Ihre Session-Anfrage an %1$s ist abgelaufen.
-
Möchten Sie Ihre Session mit %s wiederherstellen?VerwerfenWiederherstellen
diff --git a/res/values-es/strings.xml b/res/values-es/strings.xml
index 990aae8bdf..6f1f23d7f3 100644
--- a/res/values-es/strings.xml
+++ b/res/values-es/strings.xml
@@ -1353,12 +1353,6 @@ Se recibió un mensaje de intercambio de claves para una versión no válida del
Por favor, elige un nombre para mostrar que contenga solo caracteres a-z, A-Z, 0-9 y _Por favor, elige un nombre para mostrar más corto
- Notificaciones Push
- Session tiene dos tipos de notificaciones push. Asegúrate de leer cuidadosamente las descripciones antes de elegir.
- Firebase Cloud Messaging
- Session usará el servicio Firebase Cloud Messaging para recibir notificaciones push. Recibirás notificaciones de nuevos mensajes de manera segura e inmediata. Usar FCM significa que tu dirección IP y device token serán compartidos con Google. Este sería ya el caso si recibes notificaciones push con otras aplicaciones. Tu dirección IP y device token serán compartidos con Loki, pero tus mensajes seguirán teniendo enrutamiento cebolla y encriptación de extremo a extremo, por lo que el contenido de tus mensajes seguirá siendo completamente privado.
- Sondeo en segundo plano
- Session revisará si hay nuevos mensajes en segundo plano y de manera ocasional. Esto garantiza una protección total de la privacidad, pero las notificaciones de mensajes pueden retrasarse significativamente.RecomendadoPor favor, elige una opción
@@ -1369,17 +1363,6 @@ Se recibió un mensaje de intercambio de claves para una versión no válida del
¿Seguro que quieres eliminar esta conversación?Conversación eliminada
- Notificaciones Push
- Session ahora tiene dos formas de manejar las notificaciones push. Asegúrate de leer las descripciones cuidadosamente antes de elegir.
- Firebase Cloud Messaging
- Session usará el servicio Firebase Cloud Messaging para recibir las notificaciones push. Recibirás notificaciones de nuevos mensajes de manera confiable e inmediata. Usar FCM significa que este dispositivo se comunicará directamente con los servidores de Google para recuperar las notificaciones push, lo que expondrá tu dirección IP a Google. A tus mensajes se les seguirá realizando enrutamiento cebolla y cifrado de extremo a extremo, por lo que el contenido de tus mensajes permanecerá completamente privado.
- Sondeo en segundo plano
- Session revisará si hay nuevos mensajes en segundo plano y de manera ocasional. Esto garantiza una protección total de los metadatos, pero las notificaciónes de nuevos mensajes pueden retrasarse significativamente.
- Recomendado
- Por favor, elige una opción
- Confirmar
- Omitir
-
Tu frase de recuperaciónGuarda tu frase de recuperaciónTu frase de recuperación es la llave maestra de tu ID de Session, puedes usarla para recuperar tu ID de Session en caso de pérdida de acceso a tu dispositivo. Guarda tu frase de recuperación en un lugar seguro y no se la digas a nadie.
@@ -1426,7 +1409,6 @@ Se recibió un mensaje de intercambio de claves para una versión no válida del
Escanea el código QR del grupo abierto al que quieras unirteIngresa una URL de grupo abierto
- Cualquiera puede unirse a los grupos abiertos. Esto no brinda una protección completa de privacidadAjustesIngresa un nombre para mostrar
@@ -1458,8 +1440,6 @@ Se recibió un mensaje de intercambio de claves para una versión no válida del
Enlazar un dispositivoEstrategia de notificación
- Utilizar FCM
- El uso de Firebase Cloud Messaging permite notificaciones push más seguras, pero expone tu IP a Google.Esperando la autorizaciónVinculación de dispositivo autorizada
@@ -1493,16 +1473,6 @@ Se recibió un mensaje de intercambio de claves para una versión no válida del
Este es tu código QR. Otros usuarios pueden escanearlo para empezar una Session contigo.Compartir código QR
- Aceptar
- Rechazar
- %1$s te envió una solicitud de Session
- Has aceptado la solicitud de Session de %1$s
- Has rechazado la solicitud de Session de %1$s
- La solicitud de Session de %1$s ha expirado
- Le has enviado una solicitud de Session a %1$s
- %1$s aceptó tu solicitud de Session
- Tu solicitud de Session para %1$s ha expirado
-
¿Quieres restaurar tu Session con %s?DescartarRestaurar
diff --git a/res/values-fr/strings.xml b/res/values-fr/strings.xml
index 41acef6320..b63a1c12c7 100644
--- a/res/values-fr/strings.xml
+++ b/res/values-fr/strings.xml
@@ -1348,12 +1348,6 @@ Vous avez reçu un message d’échange de clés pour une version de protocole i
Veuillez choisir un nom d\'utilisateur composé uniquement de caractères a-z, A-Z, 0-9 et _Veuillez choisir un nom d\'utilisateur plus court
- Notifications push
- Session peut gérer les notifications push de deux manières. Assurez-vous de lire attentivement les détails avant de faire votre choix.
- Firebase Cloud Messaging
- Session utilisera le service Firebase Cloud Messaging pour la réception des notifications. Vous serez notifié immédiatement des nouveaux messages. L\'utilisation de FCM signifie que votre adresse IP et votre jeton d\'appareil seront exposés à Google. Cela est déjà le cas si vous utilisez des notifications push dans d’autres applications. Ceux-ci seront également exposés à Loki. Vos messages seront toujours routés anonymement et chiffrés de bout en bout, ainsi leur contenu restera totalement confidentiel.
- Consultation d\'arrière-plan
- Session vérifiera de temps en temps les nouveaux messages en arrière-plan. Cette option garantit une confidentialité totale, mais les notifications de messages peuvent être retardées.RecommandéVeuillez choisir une option
@@ -1364,17 +1358,6 @@ Vous avez reçu un message d’échange de clés pour une version de protocole i
Voulez-vous vraiment supprimer cette conversation ?Conversation supprimée
- Notifications push
- Session propose désormais deux façons de gérer les notifications push. Assurez-vous de lire attentivement les descriptions avant de choisir.
- Messagerie Cloud Firebase
- Session utilisera le service Firebase Cloud Messaging pour la réception des notifications. Vous serez notifié immédiatement des nouveaux messages. L\'utilisation de FCM signifie que votre adresse IP et votre jeton d\'appareil seront exposés à Google. Cela est déjà le cas si vous utilisez des notifications push dans d’autres applications. Ceux-ci seront également exposés à Loki. Vos messages seront toujours routés anonymement et chiffrés de bout en bout, ainsi leur contenu restera totalement confidentiel.
- Consultation d\'arrière-plan
- Session vérifiera de temps en temps les nouveaux messages en arrière-plan. Cette option garantit une confidentialité totale, mais les notifications de messages peuvent être retardées.
- Recommandé
- Veuillez choisir une option
- Confirmer
- Ignorer
-
Votre phrase de récupérationVoici votre phrase de récupérationVotre phrase de récupération est la clé principale de votre Session ID - vous pouvez l\'utiliser pour restaurer votre Session ID si vous perdez l\'accès à votre appareil. Conservez la dans un endroit sûr et ne la donnez à personne.
@@ -1421,7 +1404,6 @@ Vous avez reçu un message d’échange de clés pour une version de protocole i
Scannez le code QR du groupe public que vous souhaitez rejoindreSaisissez une URL de groupe public
- Les groupes publics peuvent être rejoints par n\'importe qui et ne fournissent pas une confidentialité totaleParamètresSaisissez un nom d\'utilisateur
@@ -1453,8 +1435,6 @@ Vous avez reçu un message d’échange de clés pour une version de protocole i
Relier un appareilStratégie de notification
- Utiliser FCM
- L\'utilisation de Firebase Cloud Messaging permet des notifications push plus fiables, mais expose votre IP et votre jeton d\'appareil à Google et à Loki.En attente d\'autorisationLiaison de l\'appareil autorisée
@@ -1488,16 +1468,6 @@ Vous avez reçu un message d’échange de clés pour une version de protocole i
Ceci est votre code QR. Les autres utilisateurs peuvent le scanner pour démarrer une session avec vous.Partager le code QR
- Accepter
- Refuser
- %1$s vous a envoyé une demande de Session
- Vous avez accepté la demande de Session de %1$s
- Vous avez refusé la demande de Session de %1$s
- La demande de Session de %1$s a expiré
- Vous avez envoyé une demande de Session à %1$s
- %1$s a accepté votre demande de Session
- Votre demande de Session à %1$s a expiré
-
Voulez-vous restaurer votre session avec %s ?FermerRestaurer
diff --git a/res/values-it/strings.xml b/res/values-it/strings.xml
index 1928fad1b6..14a9234fe3 100644
--- a/res/values-it/strings.xml
+++ b/res/values-it/strings.xml
@@ -1349,12 +1349,6 @@ Ricevuto un messaggio di scambio chiavi per una versione di protocollo non valid
Il nome visualizzare può contenere solo i caratteri a-z, AZ, 0-9 e _ Scegli un nome più breve
- Notifiche push
- La Sessione può gestire le notifiche push in due modi. Assicurati di leggere attentamente le descrizioni prima di scegliere.
- Firebase Cloud Messaging
- La Sessione utilizzerà il Firebase Cloud Messaging per ricevere notifiche push. Riceverai una notifica per i nuovi messaggi in modo affidabile e immediato. L\'utilizzo di FCM implica che il tuo indirizzo IP e il token del dispositivo siano esposti a Google. Se usi le notifiche push per altre app, ciò succede già. Il tuo indirizzo IP e il token del dispositivo saranno esposti anche a Loki, ma i messaggi saranno comunque resi anonimi tramite onion routing e crittografia end-to-end, pertanto il contenuto dei messaggi rimarrà completamente privato.
- Polling nel background
- Occasionalmente la Sessione verificherà la presenza di nuovi messaggi in background. Ciò garantisce la protezione completa dei metadati, ma le notifiche dei messaggi potrebbero subire notevoli ritardi.ConsigliatoScegli un\'opzione
@@ -1365,17 +1359,6 @@ Ricevuto un messaggio di scambio chiavi per una versione di protocollo non valid
Sei sicuro di voler eliminare questa conversazione?Conversazione eliminata
- Notifiche push
- Ora la Sessione offre due modi per gestire le notifiche push. Assicurati di leggere attentamente le descrizioni prima di scegliere.
- Firebase Cloud Messaging
- La Sessione utilizzerà il Firebase Cloud Messaging per ricevere notifiche push. Riceverai una notifica per i nuovi messaggi in modo affidabile e immediato. L\'utilizzo di FCM implica che il tuo indirizzo IP e il token del dispositivo siano esposti a Google. Se usi le notifiche push per altre app, ciò succede già. Il tuo indirizzo IP e il token del dispositivo saranno esposti anche a Loki, ma i messaggi saranno comunque resi anonimi tramite onion routing e crittografia end-to-end, pertanto il contenuto dei messaggi rimarrà completamente privato.
- Polling nel background
- Occasionalmente la Sessione verificherà la presenza di nuovi messaggi in background. Ciò garantisce la protezione completa dei metadati, ma le notifiche dei messaggi potrebbero subire notevoli ritardi.
- Consigliato
- Scegli un\'opzione
- Conferma
- Salta
-
Frase di recuperoLa frase di recuperoLa frase di recupero è la chiave principale per la Sessione ID: puoi usarla per ripristinare la Sessione ID se perdi l\'accesso al dispositivo. Conserva la frase di recupero in un luogo sicuro e non rivelarla a nessuno.
@@ -1422,7 +1405,6 @@ Ricevuto un messaggio di scambio chiavi per una versione di protocollo non valid
Scansiona il codice QR del gruppo aperto a cui desideri partecipareInserisci l\'URL di un gruppo aperto
- I gruppi aperti non offrono una protezione completa della privacy e chiunque può unirsi ad essiImpostazioniInserisci il nome da visualizzare
@@ -1454,8 +1436,6 @@ Ricevuto un messaggio di scambio chiavi per una versione di protocollo non valid
Collega un dispositivoStrategia di notifica
- Usa FCM
- L\'uso di Firebase Cloud Messaging consente notifiche push più affidabili, ma espone l\'IP e il token del dispositivo a Google e Loki.In attesa di autorizzazioneCollegamento al dispositivo autorizzato
@@ -1489,16 +1469,6 @@ Ricevuto un messaggio di scambio chiavi per una versione di protocollo non valid
Questo è il tuo codice QR. Altri utenti possono scansionarlo per iniziare una sessione con te.Condividi codice QR
- Accetta
- Rifiuta
- %1$s ti ha inviato una richiesta
- Hai accettato la richiesta di %1$s
- Hai rifiutato la richiesta di %1$s
- La richiesta di %1$s è scaduta
- Hai inviato una richiesta a %1$s
- %1$s ha accettato la richiesta
- La tua richiesta a %1$s è scaduta
-
Desideri ripristinare la sessione con %s?RimuoviRipristina
diff --git a/res/values-pt-rBR/strings.xml b/res/values-pt-rBR/strings.xml
index b7abb0a872..f99d092a4d 100644
--- a/res/values-pt-rBR/strings.xml
+++ b/res/values-pt-rBR/strings.xml
@@ -1352,12 +1352,6 @@
Escolha um nome de exibição que contenha apenas caracteres az, AZ, 0-9 e _Escolha um nome de exibição mais curto
- Notificações via push
- Há duas maneiras pelas quais o Session pode lidar com notificações push. Certifique-se de ler as descrições cuidadosamente antes de escolher.
- Firebase Cloud Messaging
- O Session usará o serviço Firebase Cloud Messaging para receber notificações push. Você será notificado sobre novas mensagens de maneira confiável e imediata. Usar o FCM significa que seu endereço IP e token do dispositivo serão expostos ao Google. Se você usar notificações push para outros aplicativos, esse já será o caso. Seu endereço IP e o token do dispositivo também serão expostos ao Loki, mas suas mensagens ainda serão roteadas anonimamente e criptografadas de ponta a ponta, para que o conteúdo de suas mensagens permaneça completamente privado.
- Pesquisa profunda
- Ocasionalmente, o Session verifica novas mensagens em segundo plano. Isso garante proteção total aos metadados, mas as notificações de mensagens podem sofrer um atraso significativo.RecomendadoEscolha uma opção
@@ -1368,17 +1362,6 @@
Tem certeza de que deseja excluir esta conversa?Conversa excluída
- Notificações via push
- O Session agora apresenta duas maneiras de lidar com notificações push. Certifique-se de ler as descrições cuidadosamente antes de escolher.
- Firebase Cloud Messaging
- O Session usará o serviço Firebase Cloud Messaging para receber notificações push. Você será notificado sobre novas mensagens de maneira confiável e imediata. Usar o FCM significa que seu endereço IP e token do dispositivo serão expostos ao Google. Se você usar notificações push para outros aplicativos, esse já será o caso. Seu endereço IP e o token do dispositivo também serão expostos ao Loki, mas suas mensagens ainda serão roteadas anonimamente e criptografadas de ponta a ponta, para que o conteúdo de suas mensagens permaneça completamente privado.
- Pesquisa profunda
- Ocasionalmente, o Session verificará novas mensagens em segundo plano. Isso garante proteção total aos metadados, mas as notificações de mensagens podem sofrer um atraso significativo.
- Recomendado
- Escolha uma opção
- Confirmar
- Pular
-
Sua frase de recuperaçãoRevele sua frase de recuperaçãoSua frase de recuperação é a chave mestra do seu ID Session - você pode usá-la para restaurar seu ID Session se perder o acesso ao seu dispositivo. Armazene sua frase de recuperação em um local seguro e não a entregue a ninguém.
@@ -1425,7 +1408,6 @@
Escaneie o código QR do grupo aberto no qual você deseja entrarDigite a URL do grupo aberto
- Grupos abertos podem ser compostos por qualquer pessoa e não oferecem proteção total à privacidadeConfiguraçõesDigite um nome de exibição
@@ -1457,8 +1439,6 @@
Sincronizar um dispositivoEstratégia de notificação
- Usar FCM
- O uso do Firebase Cloud Messaging permite notificações push mais confiáveis, mas expõe seu IP e token de dispositivo ao Google e ao Loki.Esperando autorizaçãosincronização de dispositivo autorizada
@@ -1492,16 +1472,6 @@
Este é o seu código QR. Outros usuários podem escaneá-lo para iniciar uma sessão com você.Compartilhar código QR
- Aceitar
- Recusar
- %1$s enviou uma solicitação de sessão para você
- Você aceitou a solicitação de sessão de %1$s
- Você recusou a solicitação de sessão de %1$s
- A solicitação de sessão de %1$s expirou
- Você enviou a %1$s uma solicitação de sessão
- %1$s aceitou sua solicitação de sessão
- Sua solicitação de sessão para %1$s expirou
-
Deseja restaurar sua sessão com %s?DispensarRestaurar
diff --git a/res/values-ru/strings.xml b/res/values-ru/strings.xml
index eea7942fae..54e0ec72e5 100644
--- a/res/values-ru/strings.xml
+++ b/res/values-ru/strings.xml
@@ -1406,12 +1406,6 @@
Пожалуйста, выберите отображаемое имя состоящее только из символов a-z, A-Z, 0-9 и _Пожалуйста, выберите более короткое отображаемое имя
- Всплывающие уведомления
- Есть два метода, при помощи которых Session может присылать всплывающие уведомления. Внимательно прочитайте их отличия прежде чем сделать выбор.
- Firebase Cloud Messaging
- Session будет использовать сервис Firebase Cloud Messaging (FCM) для получения всплывающих уведомлений. Вы будете надежно и незамедлительно получать уведомления о новых сообщениях. Использование FCM означает, что ваш IP-адрес и токен устройства будут доступны Google. Обратите внимание что эта информация уже доступна Google если вы используете всплывающие уведомления в других приложениях. Ваш IP-адрес и токен устройства также будут доступны Loki, но ваши сообщения будут по-прежнему маршрутизироваться и шифроваться, поэтому содержимое ваших сообщений останется полностью конфиденциальным.
- Фоновые запросы
- Session в фоновом режиме будет периодически проверять наличие новых сообщений. При этом гарантируется полная защита метаданных, однако возможна значительная задержка при уведомлении о сообщениях.РекомендуетсяПожалуйста, выберите метод
@@ -1422,17 +1416,6 @@
Вы уверены, что хотите удалить этот разговор?Разговор удален
- Всплывающее уведомление
- Теперь при работе Session имеется два метода обработки всплывающих уведомлений. Внимательно прочитайте их отличия прежде чем сделать выбор.
- Firebase Cloud Messaging
- Session будет использовать сервис Firebase Cloud Messaging для получения всплывающих уведомлений. Вы будете надежно и незамедлительно получать уведомления о новых сообщениях. Использование FCM означает, что ваш IP-адрес и токен устройства будут доступны Google. Так будет, если вы используете всплывающие уведомления для других приложений. Ваш IP-адрес и токен устройства также будут доступны Loki, но ваши сообщения будут по-прежнему маршрутизироваться и шифроваться, поэтому содержимое ваших сообщений останется полностью конфиденциальным.
- Фоновые запросы
- Session в фоновом режиме будет периодически проверять наличие новых сообщений. При этом гарантируется полная защита метаданных, однако возможна значительная задержка при уведомлении о сообщениях.
- Рекомендуется
- Пожалуйста, выберите метод
- Подтвердить
- Пропустить
-
Ваша секретная фраза для восстановленияА вот и ваша секретная фраза для восстановленияВаша секретная фраза является главным ключом к вашему Session ID. Вы можете использовать ее для восстановления Session ID, если потеряете доступ к своему устройству. Сохраните свою секретную фразу в безопасном месте, и никому её не передавайте.
@@ -1479,7 +1462,6 @@
Отсканируйте QR-код открытой группы, в которую вы хотите вступитьВведите URL открытой группы
- К открытым группам может присоединиться кто угодно. Они не обеспечивают полной защиты конфиденциальностиНастройкиВведите отображаемое имя
@@ -1511,8 +1493,6 @@
Привязать устройствоМетод уведомлений
- Использовать FCM
- Использование Firebase Cloud Messaging позволяет получать более надежные всплывающие уведомления, но предоставляет ваш IP и токен устройства в адрес Google и Loki.Ожидание авторизацииПривязка устройства авторизована
@@ -1546,16 +1526,6 @@
Это ваш QR-код. Другие пользователи могут сканировать его, чтобы начать диалог с вами.Поделиться QR-кодом
- Принять
- Отклонить
- %1$s отправил(а) вам запрос на сессию
- Вы приняли запрос на сессию от %1$s
- Вы отклонили запрос на сессию от %1$s
- Время запроса на сессию от %1$s истекло
- Вы отправили %1$s запрос на сессию
- %1$s принял ваш запрос на сессию
- Время вашего запроса на сессию с %1$s истекло
-
Хотите восстановить сессию с %s?ОтклонитьВосстановить
diff --git a/res/values-zh-rCN/strings.xml b/res/values-zh-rCN/strings.xml
index 406fe4763e..53e332123f 100644
--- a/res/values-zh-rCN/strings.xml
+++ b/res/values-zh-rCN/strings.xml
@@ -1319,12 +1319,6 @@
请选择一个仅包含 az,AZ,0-9 和_字符的显示名称请选择一个较短的显示名称
- 推送通知
- Session可以通过两种方式处理推送通知。选择之前,请务必仔细阅读说明。
- Firebase云消息传递
- 会话将使用 Firebase 云消息服务接收推送通知。您会立即可靠地收到新消息的通知。使用 FCM 意味着您的 IP 地址和设备令牌将向 Google 公开。如果您对其他应用程序使用推送通知,则情况也如此。您的 IP 地址和设备令牌也将向 Loki 公开,但是您的消息仍将经过洋葱路由和端到端加密,因此消息的内容将完全保密。
- 背景轮询
- Session偶尔会在后台检查新消息。这样可以保证完整的元数据保护,但是消息通知可能会大大延迟。推荐的选项请选择一个选项
@@ -1335,17 +1329,6 @@
您确定要删除此对话吗?对话已删除
- 推送通知
- 会话现在具有两种处理推送通知的方式。选择之前,请务必仔细阅读说明。
- Firebase 云消息传递
- 会话将使用 Firebase 云消息服务接收推送通知。您会立即可靠地收到新消息的通知。使用 FCM 意味着您的 IP 地址和设备令牌将向 Google 公开。如果您对其他应用程序使用推送通知,则情况也如此。您的 IP 地址和设备令牌也将向 Loki 公开,但是您的消息仍将经过洋葱路由和端到端加密,因此消息的内容将完全保密。
- 背景轮询
- Session偶尔会在后台检查新消息。这样可以保证完整的元数据保护,但是消息通知可能会大大延迟。
- 推荐的
- 请选择一个选项
- 确认
- 跳过
-
您的恢复短语符合您的恢复短语恢复短语是Session ID 的主密钥 - 如果您无法访问设备,则可以使用它来恢复Session ID。将您的恢复用语存储在安全的地方,不要将其提供给任何人。
@@ -1392,7 +1375,6 @@
扫描您想加入的公开群组的二维码输入一个公开群组网址
- 公开群组可以被任何人加入,并且不能提供全面的隐私保护设置输入显示的名称
@@ -1424,8 +1406,6 @@
链接设备(测试版)通知选项
- 使用 FCM
- 使用 Firebase 云消息可以提供更可靠的推送通知,但会将您的 IP 和设备令牌公开给 Google 和 Loki。等待授权设备链接授权
@@ -1459,16 +1439,6 @@
这是您的二维码。其他用户可以对其进行扫描以开始对话。分享二维码
- 接受
- 拒绝
- %1$s向您发送了一个会话请求
- 您已接受%1$s的会话请求
- 您拒绝了%1$s的会话请求
- %1$s的会话请求已过期
- 您已向%1$s发送了会话请求
- %1$s接受了会话请求
- 您对%1$s的会话请求已过期
-
您要恢复与%s的会话吗?解散恢复
diff --git a/res/values/strings.xml b/res/values/strings.xml
index d92843d0a8..d2414c612e 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -1702,12 +1702,6 @@
Please pick a display name that consists of only a-z, A-Z, 0-9 and _ charactersPlease pick a shorter display name
- Push Notifications
- There are two ways Session can handle push notifications. Make sure to read the descriptions carefully before you choose.
- Firebase Cloud Messaging
- Session will use the Firebase Cloud Messaging service to receive push notifications. You\'ll be notified of new messages reliably and immediately. Using FCM means that your IP address and device token will be exposed to Google. If you use push notifications for other apps, this will already be the case. Your IP address and device token will also be exposed to Loki, but your messages will still be onion-routed and end-to-end encrypted, so the contents of your messages will remain completely private.
- Background Polling
- Session will occasionally check for new messages in the background. This guarantees full metadata protection, but message notifications may be significantly delayed.RecommendedPlease Pick an Option
@@ -1718,17 +1712,6 @@
Are you sure you want to delete this conversation?Conversation deleted
- Push Notifications
- Session now features two ways to handle push notifications. Make sure to read the descriptions carefully before you choose.
- Firebase Cloud Messaging
- Session will use the Firebase Cloud Messaging service to receive push notifications. You\'ll be notified of new messages reliably and immediately. Using FCM means that your IP address and device token will be exposed to Google. If you use push notifications for other apps, this will already be the case. Your IP address and device token will also be exposed to Loki, but your messages will still be onion-routed and end-to-end encrypted, so the contents of your messages will remain completely private.
- Background Polling
- Session will occasionally check for new messages in the background. This guarantees full metadata protection, but message notifications may be significantly delayed.
- Recommended
- Please Pick an Option
- Confirm
- Skip
-
Your Recovery PhraseMeet your recovery phraseYour recovery phrase is the master key to your Session ID — you can use it to restore your Session ID if you lose access to your device. Store your recovery phrase in a safe place, and don\’t give it to anyone.
@@ -1775,7 +1758,6 @@
Scan the QR code of the open group you\'d like to joinEnter an open group URL
- Open groups can be joined by anyone and do not provide full privacy protectionSettingsEnter a display name
@@ -1807,8 +1789,6 @@
Link a Device (Beta)Notification Strategy
- Use FCM
- Using Firebase Cloud Messaging allows for more reliable push notifications, but exposes your IP and device token to Google and Loki.Waiting for AuthorizationDevice Link Authorized
@@ -1842,16 +1822,6 @@
This is your QR code. Other users can scan it to start a session with you.Share QR Code
- Accept
- Decline
- %1$s sent you a session request
- You\'ve accepted %1$s\'s session request
- You\'ve declined %1$s\'s session request
- %1$s\'s session request has expired
- You\'ve sent %1$s a session request
- %1$s accepted your session request
- Your session request to %1$s has expired
-
Would you like to restore your session with %s?DismissRestore
diff --git a/res/xml/preferences_notifications.xml b/res/xml/preferences_notifications.xml
index 9a9c918179..a1b33553ac 100644
--- a/res/xml/preferences_notifications.xml
+++ b/res/xml/preferences_notifications.xml
@@ -26,8 +26,8 @@
diff --git a/src/org/thoughtcrime/securesms/loki/activities/HomeActivity.kt b/src/org/thoughtcrime/securesms/loki/activities/HomeActivity.kt
index cb9cae4fa4..b4f26eadc0 100644
--- a/src/org/thoughtcrime/securesms/loki/activities/HomeActivity.kt
+++ b/src/org/thoughtcrime/securesms/loki/activities/HomeActivity.kt
@@ -31,7 +31,6 @@ import org.thoughtcrime.securesms.database.ThreadDatabase
import org.thoughtcrime.securesms.database.model.ThreadRecord
import org.thoughtcrime.securesms.jobs.MultiDeviceBlockedUpdateJob
import org.thoughtcrime.securesms.loki.dialogs.ConversationOptionsBottomSheet
-import org.thoughtcrime.securesms.loki.dialogs.PNModeBottomSheet
import org.thoughtcrime.securesms.loki.protocol.ClosedGroupsProtocol
import org.thoughtcrime.securesms.loki.protocol.SessionResetImplementation
import org.thoughtcrime.securesms.loki.utilities.*
@@ -190,20 +189,6 @@ class HomeActivity : PassphraseRequiredActionBarActivity, ConversationClickListe
if (hasViewedSeed || !isMasterDevice) {
seedReminderView.visibility = View.GONE
}
- if (!TextSecurePreferences.hasSeenPNModeSheet(this)) {
- val bottomSheet = PNModeBottomSheet()
- bottomSheet.onConfirmTapped = { isUsingFCM ->
- TextSecurePreferences.setHasSeenPNModeSheet(this, true)
- TextSecurePreferences.setIsUsingFCM(this, isUsingFCM)
- ApplicationContext.getInstance(this).registerForFCMIfNeeded(true)
- bottomSheet.dismiss()
- }
- bottomSheet.onSkipTapped = {
- TextSecurePreferences.setHasSeenPNModeSheet(this, true)
- bottomSheet.dismiss()
- }
- bottomSheet.show(supportFragmentManager, bottomSheet.tag)
- }
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
diff --git a/src/org/thoughtcrime/securesms/loki/activities/PNModeActivity.kt b/src/org/thoughtcrime/securesms/loki/activities/PNModeActivity.kt
index 763c3cf6ba..c128e0a80c 100644
--- a/src/org/thoughtcrime/securesms/loki/activities/PNModeActivity.kt
+++ b/src/org/thoughtcrime/securesms/loki/activities/PNModeActivity.kt
@@ -3,10 +3,14 @@ package org.thoughtcrime.securesms.loki.activities
import android.app.AlertDialog
import android.content.Intent
import android.graphics.drawable.TransitionDrawable
+import android.net.Uri
import android.os.Bundle
import android.support.annotation.DrawableRes
+import android.view.Menu
+import android.view.MenuItem
import android.view.View
import android.widget.LinearLayout
+import android.widget.Toast
import kotlinx.android.synthetic.main.activity_display_name.registerButton
import kotlinx.android.synthetic.main.activity_pn_mode.*
import network.loki.messenger.R
@@ -28,6 +32,11 @@ class PNModeActivity : BaseActionBarActivity() {
backgroundPollingOptionView.setOnClickListener { toggleBackgroundPolling() }
registerButton.setOnClickListener { register() }
}
+
+ override fun onCreateOptionsMenu(menu: Menu?): Boolean {
+ menuInflater.inflate(R.menu.menu_pn_mode, menu)
+ return true
+ }
// endregion
// region Animation
@@ -39,6 +48,25 @@ class PNModeActivity : BaseActionBarActivity() {
// endregion
// region Interaction
+ override fun onOptionsItemSelected(item: MenuItem): Boolean {
+ val id = item.itemId
+ when(id) {
+ R.id.learnMoreButton -> learnMore()
+ else -> { /* Do nothing */ }
+ }
+ return super.onOptionsItemSelected(item)
+ }
+
+ private fun learnMore() {
+ try {
+ val url = "https://getsession.org/faq/#privacy"
+ val intent = Intent(Intent.ACTION_VIEW, Uri.parse(url))
+ startActivity(intent)
+ } catch (e: Exception) {
+ Toast.makeText(this, R.string.invalid_url, Toast.LENGTH_SHORT).show()
+ }
+ }
+
private fun toggleFCM() {
when (selectedOptionView) {
null -> {
diff --git a/src/org/thoughtcrime/securesms/loki/dialogs/PNModeBottomSheet.kt b/src/org/thoughtcrime/securesms/loki/dialogs/PNModeBottomSheet.kt
deleted file mode 100644
index 276f81ee43..0000000000
--- a/src/org/thoughtcrime/securesms/loki/dialogs/PNModeBottomSheet.kt
+++ /dev/null
@@ -1,100 +0,0 @@
-package org.thoughtcrime.securesms.loki.dialogs
-
-import android.app.AlertDialog
-import android.content.DialogInterface
-import android.graphics.drawable.TransitionDrawable
-import android.os.Bundle
-import android.support.annotation.DrawableRes
-import android.support.design.widget.BottomSheetDialogFragment
-import android.view.LayoutInflater
-import android.view.View
-import android.view.ViewGroup
-import android.widget.LinearLayout
-import kotlinx.android.synthetic.main.fragment_pn_mode_bottom_sheet.*
-import network.loki.messenger.R
-import org.thoughtcrime.securesms.util.TextSecurePreferences
-
-class PNModeBottomSheet : BottomSheetDialogFragment() {
- private var selectedOptionView: LinearLayout? = null
- var onConfirmTapped: ((Boolean) -> Unit)? = null
- var onSkipTapped: (() -> Unit)? = null
-
- override fun onCreate(savedInstanceState: Bundle?) {
- super.onCreate(savedInstanceState)
- setStyle(STYLE_NORMAL, R.style.SessionBottomSheetDialogTheme)
- }
-
- override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
- return inflater.inflate(R.layout.fragment_pn_mode_bottom_sheet, container, false)
- }
-
- override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
- super.onViewCreated(view, savedInstanceState)
- fcmOptionView.setOnClickListener { toggleFCM() }
- backgroundPollingOptionView.setOnClickListener { toggleBackgroundPolling() }
- confirmButton.setOnClickListener { confirm() }
- skipButton.setOnClickListener { onSkipTapped?.invoke() }
- }
-
- override fun onDismiss(dialog: DialogInterface?) {
- TextSecurePreferences.setHasSeenPNModeSheet(context, true)
- super.onDismiss(dialog)
- }
-
- // region Animation
- private fun performTransition(@DrawableRes transitionID: Int, subject: View) {
- val drawable = resources.getDrawable(transitionID, context!!.theme) as TransitionDrawable
- subject.background = drawable
- drawable.startTransition(250)
- }
- // endregion
-
- // region Interaction
- private fun toggleFCM() {
- when (selectedOptionView) {
- null -> {
- performTransition(R.drawable.pn_option_background_select_transition, fcmOptionView)
- selectedOptionView = fcmOptionView
- }
- fcmOptionView -> {
- performTransition(R.drawable.pn_option_background_deselect_transition, fcmOptionView)
- selectedOptionView = null
- }
- backgroundPollingOptionView -> {
- performTransition(R.drawable.pn_option_background_select_transition, fcmOptionView)
- performTransition(R.drawable.pn_option_background_deselect_transition, backgroundPollingOptionView)
- selectedOptionView = fcmOptionView
- }
- }
- }
-
- private fun toggleBackgroundPolling() {
- when (selectedOptionView) {
- null -> {
- performTransition(R.drawable.pn_option_background_select_transition, backgroundPollingOptionView)
- selectedOptionView = backgroundPollingOptionView
- }
- backgroundPollingOptionView -> {
- performTransition(R.drawable.pn_option_background_deselect_transition, backgroundPollingOptionView)
- selectedOptionView = null
- }
- fcmOptionView -> {
- performTransition(R.drawable.pn_option_background_select_transition, backgroundPollingOptionView)
- performTransition(R.drawable.pn_option_background_deselect_transition, fcmOptionView)
- selectedOptionView = backgroundPollingOptionView
- }
- }
- }
-
- private fun confirm() {
- if (selectedOptionView == null) {
- val dialog = AlertDialog.Builder(context)
- dialog.setTitle(R.string.sheet_pn_mode_no_option_picked_dialog_title)
- dialog.setPositiveButton(R.string.ok) { _, _ -> }
- dialog.create().show()
- return
- }
- onConfirmTapped?.invoke(selectedOptionView == fcmOptionView)
- }
- // endregion
-}
\ No newline at end of file