Fixed that mnitmSearchTransactions may is not initialized yet when AccountChangedListener gets called
This commit is contained in:
parent
69f058b753
commit
709066c816
|
@ -81,6 +81,7 @@ class HomeFragment : Fragment() {
|
||||||
|
|
||||||
initSearchView()
|
initSearchView()
|
||||||
|
|
||||||
|
initLogicAfterUiInitialized()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,17 +131,21 @@ class HomeFragment : Fragment() {
|
||||||
// TODO: this is such a bad code style
|
// TODO: this is such a bad code style
|
||||||
(context as? MainActivity)?.presenter?.let { presenter ->
|
(context as? MainActivity)?.presenter?.let { presenter ->
|
||||||
this.presenter = presenter
|
this.presenter = presenter
|
||||||
|
|
||||||
presenter.addAccountsChangedListener { handleAccountsChanged(it) }
|
|
||||||
|
|
||||||
presenter.addSelectedBankAccountsChangedListener { handleSelectedBankAccountsChanged(it) }
|
|
||||||
|
|
||||||
presenter.addRetrievedAccountTransactionsResponseListener { _, response ->
|
|
||||||
handleGetTransactionsResponse(response)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun initLogicAfterUiInitialized() {
|
||||||
|
presenter.addAccountsChangedListener { handleAccountsChanged(it) }
|
||||||
|
|
||||||
|
presenter.addSelectedBankAccountsChangedListener { handleSelectedBankAccountsChanged(it) }
|
||||||
|
|
||||||
|
presenter.addRetrievedAccountTransactionsResponseListener { _, response ->
|
||||||
|
handleGetTransactionsResponse(response)
|
||||||
|
}
|
||||||
|
|
||||||
|
updateTransactionsToDisplayOnUiThread()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private fun handleAccountsChanged(accounts: List<Account>) {
|
private fun handleAccountsChanged(accounts: List<Account>) {
|
||||||
context?.asActivity()?.let { activity ->
|
context?.asActivity()?.let { activity ->
|
||||||
|
@ -154,7 +159,7 @@ class HomeFragment : Fragment() {
|
||||||
private fun handleSelectedBankAccountsChanged(selectedBankAccounts: List<BankAccount>) {
|
private fun handleSelectedBankAccountsChanged(selectedBankAccounts: List<BankAccount>) {
|
||||||
context?.asActivity()?.let { activity ->
|
context?.asActivity()?.let { activity ->
|
||||||
activity.runOnUiThread {
|
activity.runOnUiThread {
|
||||||
updateTransactionsToDisplay()
|
updateTransactionsToDisplayOnUiThread()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -167,7 +172,7 @@ class HomeFragment : Fragment() {
|
||||||
context?.asActivity()?.let { activity ->
|
context?.asActivity()?.let { activity ->
|
||||||
activity.runOnUiThread {
|
activity.runOnUiThread {
|
||||||
if (response.isSuccessful) {
|
if (response.isSuccessful) {
|
||||||
updateTransactionsToDisplay()
|
updateTransactionsToDisplayOnUiThread()
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
AlertDialog.Builder(activity) // TODO: may show account name in message
|
AlertDialog.Builder(activity) // TODO: may show account name in message
|
||||||
|
@ -199,7 +204,8 @@ class HomeFragment : Fragment() {
|
||||||
override fun onQueryTextChange(query: String): Boolean {
|
override fun onQueryTextChange(query: String): Boolean {
|
||||||
appliedTransactionsFilter = query
|
appliedTransactionsFilter = query
|
||||||
|
|
||||||
updateTransactionsToDisplay()
|
updateTransactionsToDisplayOnUiThread()
|
||||||
|
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,7 +215,7 @@ class HomeFragment : Fragment() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private fun updateTransactionsToDisplay() {
|
private fun updateTransactionsToDisplayOnUiThread() {
|
||||||
transactionAdapter.items = presenter.searchSelectedAccountTransactions(appliedTransactionsFilter)
|
transactionAdapter.items = presenter.searchSelectedAccountTransactions(appliedTransactionsFilter)
|
||||||
|
|
||||||
// TODO: if transactions are filtered calculate and show balance of displayed transactions?
|
// TODO: if transactions are filtered calculate and show balance of displayed transactions?
|
||||||
|
|
Loading…
Reference in New Issue