- Data.accountFilter.observe(getViewLifecycleOwner(), this::onAccountNameFilterChanged);
-
- TransactionListViewModel.updating.addObserver(
- (o, arg) -> swiper.setRefreshing(TransactionListViewModel.updating.get()));
- TransactionListViewModel.updateError.addObserver((o, arg) -> {
- String err = TransactionListViewModel.updateError.get();
- if (err == null)
- return;
-
- Toast.makeText(mActivity, err, Toast.LENGTH_SHORT)
- .show();
- TransactionListViewModel.updateError.set(null);
+ model.getAccountFilter()
+ .observe(getViewLifecycleOwner(), this::onAccountNameFilterChanged);
+
+ model.getUpdatingFlag()
+ .observe(getViewLifecycleOwner(), (flag) -> b.transactionSwipe.setRefreshing(flag));
+ model.getDisplayedTransactions()
+ .observe(getViewLifecycleOwner(), list -> modelAdapter.setTransactions(list));
+
+ view.findViewById(R.id.clearAccountNameFilter)
+ .setOnClickListener(v -> {
+ model.getAccountFilter()
+ .setValue(null);
+ Globals.hideSoftKeyboard(mainActivity);
+ });
+
+ model.foundTransactionItemIndex.observe(getViewLifecycleOwner(), pos -> {
+ Logger.debug("go-to-date", String.format(Locale.US, "Found pos %d", pos));
+ if (pos != null) {
+ b.transactionRoot.scrollToPosition(pos);
+ // reset the value to avoid re-notification upon reconfiguration or app restart
+ model.foundTransactionItemIndex.setValue(null);
+ }