diff options
author | pacien | 2019-03-24 22:14:49 +0100 |
---|---|---|
committer | pacien | 2019-03-24 22:14:49 +0100 |
commit | ac694d006dbda068370a6e81105763d857e42aa1 (patch) | |
tree | 9d9a121e87ab462c5f8ee859b2c7b52acebe4d42 /app/src/main/java | |
parent | e104556bd46822254afc85c67f01f8f3474cc009 (diff) | |
download | tincapp-ac694d006dbda068370a6e81105763d857e42aa1.tar.gz |
submit key unlock form on virtual keyboard DONE event
github ref: closes #81
Diffstat (limited to 'app/src/main/java')
-rw-r--r-- | app/src/main/java/org/pacien/tincapp/activities/start/ConnectionStarter.kt | 15 | ||||
-rw-r--r-- | app/src/main/java/org/pacien/tincapp/extensions/View.kt | 35 |
2 files changed, 47 insertions, 3 deletions
diff --git a/app/src/main/java/org/pacien/tincapp/activities/start/ConnectionStarter.kt b/app/src/main/java/org/pacien/tincapp/activities/start/ConnectionStarter.kt index d1ccd3f..c0c6e02 100644 --- a/app/src/main/java/org/pacien/tincapp/activities/start/ConnectionStarter.kt +++ b/app/src/main/java/org/pacien/tincapp/activities/start/ConnectionStarter.kt | |||
@@ -1,6 +1,6 @@ | |||
1 | /* | 1 | /* |
2 | * Tinc App, an Android binding and user interface for the tinc mesh VPN daemon | 2 | * Tinc App, an Android binding and user interface for the tinc mesh VPN daemon |
3 | * Copyright (C) 2017-2018 Pacien TRAN-GIRARD | 3 | * Copyright (C) 2017-2019 Pacien TRAN-GIRARD |
4 | * | 4 | * |
5 | * This program is free software: you can redistribute it and/or modify | 5 | * This program is free software: you can redistribute it and/or modify |
6 | * it under the terms of the GNU General Public License as published by | 6 | * it under the terms of the GNU General Public License as published by |
@@ -20,11 +20,13 @@ package org.pacien.tincapp.activities.start | |||
20 | 20 | ||
21 | import android.net.VpnService | 21 | import android.net.VpnService |
22 | import android.support.v7.app.AlertDialog | 22 | import android.support.v7.app.AlertDialog |
23 | import android.view.inputmethod.EditorInfo | ||
23 | import kotlinx.android.synthetic.main.base_activity.* | 24 | import kotlinx.android.synthetic.main.base_activity.* |
24 | import kotlinx.android.synthetic.main.dialog_decrypt_keys.view.* | 25 | import kotlinx.android.synthetic.main.dialog_decrypt_keys.view.* |
25 | import org.pacien.tincapp.R | 26 | import org.pacien.tincapp.R |
26 | import org.pacien.tincapp.service.TincVpnService | 27 | import org.pacien.tincapp.service.TincVpnService |
27 | import org.pacien.tincapp.utils.TincKeyring | 28 | import org.pacien.tincapp.utils.TincKeyring |
29 | import org.pacien.tincapp.extensions.View.on | ||
28 | 30 | ||
29 | /** | 31 | /** |
30 | * @author pacien | 32 | * @author pacien |
@@ -54,12 +56,19 @@ class ConnectionStarter(private val parentActivity: StartActivity) { | |||
54 | private fun askForPassphrase() { | 56 | private fun askForPassphrase() { |
55 | val dialogView = parentActivity.layoutInflater.inflate(R.layout.dialog_decrypt_keys, parentActivity.base_activity_frame, false) | 57 | val dialogView = parentActivity.layoutInflater.inflate(R.layout.dialog_decrypt_keys, parentActivity.base_activity_frame, false) |
56 | 58 | ||
57 | AlertDialog.Builder(parentActivity) | 59 | val dialog = AlertDialog.Builder(parentActivity) |
58 | .setTitle(R.string.decrypt_key_modal_title) | 60 | .setTitle(R.string.decrypt_key_modal_title) |
59 | .setView(dialogView) | 61 | .setView(dialogView) |
60 | .setPositiveButton(R.string.decrypt_key_modal_action_unlock) { _, _ -> tryStart(passphrase = dialogView.passphrase.text.toString()) } | 62 | .setPositiveButton(R.string.decrypt_key_modal_action_unlock) { _, _ -> tryStart(passphrase = dialogView.passphrase.text.toString()) } |
61 | .setNegativeButton(R.string.decrypt_key_modal_action_cancel) { _, _ -> Unit } | 63 | .setNegativeButton(R.string.decrypt_key_modal_action_cancel) { _, _ -> Unit } |
62 | .show() | 64 | .create() |
65 | |||
66 | dialogView.passphrase.on(EditorInfo.IME_ACTION_DONE) { | ||
67 | dialog.dismiss() | ||
68 | tryStart(passphrase = dialogView.passphrase.text.toString()) | ||
69 | } | ||
70 | |||
71 | dialog.show() | ||
63 | } | 72 | } |
64 | 73 | ||
65 | private fun startVpn(netName: String, passphrase: String? = null) { | 74 | private fun startVpn(netName: String, passphrase: String? = null) { |
diff --git a/app/src/main/java/org/pacien/tincapp/extensions/View.kt b/app/src/main/java/org/pacien/tincapp/extensions/View.kt new file mode 100644 index 0000000..19e33dc --- /dev/null +++ b/app/src/main/java/org/pacien/tincapp/extensions/View.kt | |||
@@ -0,0 +1,35 @@ | |||
1 | /* | ||
2 | * Tinc App, an Android binding and user interface for the tinc mesh VPN daemon | ||
3 | * Copyright (C) 2017-2019 Pacien TRAN-GIRARD | ||
4 | * | ||
5 | * This program is free software: you can redistribute it and/or modify | ||
6 | * it under the terms of the GNU General Public License as published by | ||
7 | * the Free Software Foundation, either version 3 of the License, or | ||
8 | * (at your option) any later version. | ||
9 | * | ||
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 | ||
13 | * GNU General Public License for more details. | ||
14 | * | ||
15 | * You should have received a copy of the GNU General Public License | ||
16 | * along with this program. If not, see <https://www.gnu.org/licenses/>. | ||
17 | */ | ||
18 | |||
19 | package org.pacien.tincapp.extensions | ||
20 | |||
21 | import android.widget.EditText | ||
22 | |||
23 | /** | ||
24 | * @author pacien | ||
25 | */ | ||
26 | object View { | ||
27 | |||
28 | fun EditText.on(actionId: Int, func: () -> Unit) { | ||
29 | setOnEditorActionListener { _, receivedActionId, _ -> | ||
30 | if (actionId == receivedActionId) func() | ||
31 | true | ||
32 | } | ||
33 | } | ||
34 | |||
35 | } | ||