aboutsummaryrefslogtreecommitdiff
path: root/app/src/main/java
diff options
context:
space:
mode:
Diffstat (limited to 'app/src/main/java')
-rw-r--r--app/src/main/java/com/zeapo/pwdstore/git/GitServerConfigActivity.kt34
1 files changed, 19 insertions, 15 deletions
diff --git a/app/src/main/java/com/zeapo/pwdstore/git/GitServerConfigActivity.kt b/app/src/main/java/com/zeapo/pwdstore/git/GitServerConfigActivity.kt
index f8c67e51..f1d195ac 100644
--- a/app/src/main/java/com/zeapo/pwdstore/git/GitServerConfigActivity.kt
+++ b/app/src/main/java/com/zeapo/pwdstore/git/GitServerConfigActivity.kt
@@ -6,6 +6,7 @@ package com.zeapo.pwdstore.git
import android.os.Bundle
import android.os.Handler
+import android.view.View
import androidx.core.content.edit
import androidx.core.os.postDelayed
import androidx.core.widget.doOnTextChanged
@@ -50,18 +51,20 @@ class GitServerConfigActivity : BaseGitActivity() {
}
}
- binding.connectionModeGroup.check(when (connectionMode) {
- ConnectionMode.SshKey -> R.id.connection_mode_ssh_key
- ConnectionMode.Password -> R.id.connection_mode_password
- ConnectionMode.OpenKeychain -> R.id.connection_mode_open_keychain
- ConnectionMode.None -> R.id.connection_mode_none
- })
- binding.connectionModeGroup.setOnCheckedChangeListener { group, _ ->
- when (group.checkedRadioButtonId) {
- R.id.connection_mode_ssh_key -> connectionMode = ConnectionMode.SshKey
- R.id.connection_mode_open_keychain -> connectionMode = ConnectionMode.OpenKeychain
- R.id.connection_mode_password -> connectionMode = ConnectionMode.Password
- R.id.connection_mode_none -> connectionMode = ConnectionMode.None
+ binding.connectionModeGroup.apply {
+ when (connectionMode) {
+ ConnectionMode.SshKey -> check(R.id.connection_mode_ssh_key)
+ ConnectionMode.Password -> check(R.id.connection_mode_password)
+ ConnectionMode.OpenKeychain -> check(R.id.connection_mode_open_keychain)
+ ConnectionMode.None -> uncheck(checkedButtonId)
+ }
+ addOnButtonCheckedListener { group, _, _ ->
+ when (checkedButtonId) {
+ R.id.connection_mode_ssh_key -> connectionMode = ConnectionMode.SshKey
+ R.id.connection_mode_open_keychain -> connectionMode = ConnectionMode.OpenKeychain
+ R.id.connection_mode_password -> connectionMode = ConnectionMode.Password
+ View.NO_ID -> connectionMode = ConnectionMode.None
+ }
}
}
updateConnectionModeToggleGroup()
@@ -120,12 +123,14 @@ class GitServerConfigActivity : BaseGitActivity() {
private fun updateConnectionModeToggleGroup() {
if (protocol == Protocol.Ssh) {
- if (binding.connectionModeNone.isChecked)
+ // Reset connection mode to SSH key if the current value (none) is not valid for SSH
+ if (binding.connectionModeGroup.checkedButtonIds.isEmpty())
binding.connectionModeGroup.check(R.id.connection_mode_ssh_key)
binding.connectionModeSshKey.isEnabled = true
binding.connectionModeOpenKeychain.isEnabled = true
- binding.connectionModeNone.isEnabled = false
+ binding.connectionModeGroup.isSelectionRequired = true
} else {
+ binding.connectionModeGroup.isSelectionRequired = false
// Reset connection mode to password if the current value is not valid for HTTPS
// Important note: This has to happen before disabling the other toggle buttons or they
// won't uncheck.
@@ -133,7 +138,6 @@ class GitServerConfigActivity : BaseGitActivity() {
binding.connectionModeGroup.check(R.id.connection_mode_password)
binding.connectionModeSshKey.isEnabled = false
binding.connectionModeOpenKeychain.isEnabled = false
- binding.connectionModeNone.isEnabled = true
}
}