- swiper.setColorSchemeResources(R.color.colorPrimary, R.color.colorAccent);
-
- vAccountFilter = mActivity.findViewById(R.id.transaction_list_account_name_filter);
- accNameFilter = mActivity.findViewById(R.id.transaction_filter_account_name);
- bTransactionListCancelDownload =
- mActivity.findViewById(R.id.transaction_list_cancel_download);
-
- TransactionListFragment me = this;
- MLDB.hook_autocompletion_adapter(mActivity, accNameFilter, "accounts", "name");
- accNameFilter.setOnItemClickListener(new AdapterView.OnItemClickListener() {
- @Override
- public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
- Log.d("tmp", "direct onItemClick");
- model.reloadTransactions(me);
- MatrixCursor mc = (MatrixCursor) parent.getItemAtPosition(position);
- modelAdapter.setBoldAccountName(mc.getString(1));
- modelAdapter.notifyDataSetChanged();
- Globals.hideSoftKeyboard(mActivity);
+ Data.accountFilter.observe(getViewLifecycleOwner(), this::onAccountNameFilterChanged);
+
+ TransactionListViewModel.updating.addObserver(
+ (o, arg) -> refreshLayout.setRefreshing(TransactionListViewModel.updating.get()));
+ TransactionListViewModel.updateError.addObserver((o, arg) -> {
+ String err = TransactionListViewModel.updateError.get();
+ if (err == null)
+ return;
+
+ Snackbar.make(this.root, err, Snackbar.LENGTH_LONG)
+ .show();
+ TransactionListViewModel.updateError.set(null);
+ });
+ Data.transactions.addObserver(
+ (o, arg) -> mainActivity.runOnUiThread(() -> modelAdapter.notifyDataSetChanged()));
+
+ mainActivity.findViewById(R.id.clearAccountNameFilter)
+ .setOnClickListener(v -> {
+ Data.accountFilter.setValue(null);
+ vAccountFilter.setVisibility(View.GONE);
+ menuTransactionListFilter.setVisible(true);
+ Globals.hideSoftKeyboard(mainActivity);
+ });
+
+ Data.foundTransactionItemIndex.observe(getViewLifecycleOwner(), pos -> {
+ Logger.debug("go-to-date", String.format(Locale.US, "Found pos %d", pos));
+ if (pos != null) {
+ root.scrollToPosition(pos);
+ // reset the value to avoid re-notification upon reconfiguration or app restart
+ Data.foundTransactionItemIndex.setValue(null);