X-Git-Url: https://git.ktnx.net/?p=mobile-ledger-staging.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2Factivity%2FNewTransactionItemHolder.java;h=f83eec8ae036b859f5de9f3b57cca88b922e9329;hp=fc17560614e9d85e8e72a30ce8d9cc59c678d861;hb=a08a6e0d8f07a3d709aa4efa0cce5d8a444a2dfe;hpb=5563af1247c470c3e38b5a64f5509ad3a077e852 diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionItemHolder.java b/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionItemHolder.java index fc175606..f83eec8a 100644 --- a/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionItemHolder.java +++ b/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionItemHolder.java @@ -38,6 +38,7 @@ import net.ktnx.mobileledger.async.DescriptionSelectedCallback; import net.ktnx.mobileledger.model.Data; import net.ktnx.mobileledger.model.LedgerTransactionAccount; import net.ktnx.mobileledger.model.MobileLedgerProfile; +import net.ktnx.mobileledger.ui.AutoCompleteTextViewWithClear; import net.ktnx.mobileledger.ui.DatePickerFragment; import net.ktnx.mobileledger.utils.Logger; import net.ktnx.mobileledger.utils.MLDB; @@ -96,7 +97,14 @@ class NewTransactionItemHolder extends RecyclerView.ViewHolder boolean wasSyncing = syncingData; syncingData = true; try { - adapter.updateFocusedItem(getAdapterPosition()); + final int pos = getAdapterPosition(); + adapter.updateFocusedItem(pos); + if (v instanceof AutoCompleteTextViewWithClear) { + adapter.noteFocusIsOnAccount(pos); + } + else { + adapter.noteFocusIsOnAmount(pos); + } } finally { syncingData = wasSyncing; @@ -233,10 +241,15 @@ class NewTransactionItemHolder extends RecyclerView.ViewHolder case transactionRow: // do nothing if a row element already has the focus if (!itemView.hasFocus()) { - focused = tvAccount.requestFocus(); - tvAccount.dismissDropDown(); - if (focused) - Misc.showSoftKeyboard((NewTransactionActivity) tvAccount.getContext()); + if (item.focusIsOnAmount()) { + tvAmount.requestFocus(); + } + else { + focused = tvAccount.requestFocus(); + tvAccount.dismissDropDown(); + if (focused) + Misc.showSoftKeyboard((NewTransactionActivity) tvAccount.getContext()); + } } break;