+ Colors.themeWatch.observe(getViewLifecycleOwner(), this::themeChanged);
+
+ vAccountFilter = view.findViewById(R.id.transaction_list_account_name_filter);
+ accNameFilter = view.findViewById(R.id.transaction_filter_account_name);
+
+ MobileLedgerProfile profile = Data.getProfile();
+ accNameFilter.setAdapter(new AccountAutocompleteAdapter(mainActivity, profile));
+ accNameFilter.setOnItemClickListener((parent, v, position, id) -> {
+// debug("tmp", "direct onItemClick");
+ model.getAccountFilter()
+ .setValue(parent.getItemAtPosition(position)
+ .toString());
+ Globals.hideSoftKeyboard(mainActivity);
+ });
+
+ model.getAccountFilter()
+ .observe(getViewLifecycleOwner(), this::onAccountNameFilterChanged);
+
+ model.getUpdatingFlag()
+ .observe(getViewLifecycleOwner(), (flag) -> refreshLayout.setRefreshing(flag));
+ model.getDisplayedTransactions()
+ .observe(getViewLifecycleOwner(), list -> modelAdapter.setTransactions(list));
+
+ view.findViewById(R.id.clearAccountNameFilter)
+ .setOnClickListener(v -> {
+ model.getAccountFilter()
+ .setValue(null);
+ vAccountFilter.setVisibility(View.GONE);
+ menuTransactionListFilter.setVisible(true);
+ Globals.hideSoftKeyboard(mainActivity);
+ });
+
+ model.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
+ model.foundTransactionItemIndex.setValue(null);
+ }
+ });
+ }
+ private void onAccountNameFilterChanged(String accName) {
+ final String fieldText = accNameFilter.getText()
+ .toString();
+ if ((accName == null) && (fieldText.equals("")))
+ return;
+
+ if (accNameFilter != null) {
+ accNameFilter.setText(accName, false);
+ }
+ final boolean filterActive = (accName != null) && !accName.isEmpty();
+ if (vAccountFilter != null) {
+ vAccountFilter.setVisibility(filterActive ? View.VISIBLE : View.GONE);
+ }
+ if (menuTransactionListFilter != null)
+ menuTransactionListFilter.setVisible(!filterActive);
+
+ model.scheduleTransactionListReload();
+
+ }