From 9e0f72e10134388b4fd1d2af349f06d642c91680 Mon Sep 17 00:00:00 2001 From: Fabian Diener Date: Wed, 27 Sep 2023 17:13:58 +0200 Subject: [PATCH 1/3] Factor out logic to get notes into separate function Signed-off-by: Fabian Diener --- .../owncloud/notes/main/MainActivity.java | 53 ++++++++++--------- 1 file changed, 29 insertions(+), 24 deletions(-) diff --git a/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java b/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java index 43e482a75..4e9e5ccd6 100644 --- a/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java +++ b/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java @@ -137,6 +137,33 @@ public class MainActivity extends LockedActivity implements NoteClickListener, A boolean canMoveNoteToAnotherAccounts = false; + private void getNotesListLiveData() { + mainViewModel.getNotesListLiveData().observe(this, notes -> { + // https://stackoverflow.com/a/37342327 + itemTouchHelper.attachToRecyclerView(null); + itemTouchHelper.attachToRecyclerView(listView); + adapter.setItemList(notes); + binding.activityNotesListView.progressCircular.setVisibility(GONE); + binding.activityNotesListView.emptyContentView.getRoot().setVisibility(notes.size() > 0 ? GONE : VISIBLE); + // Remove deleted notes from the selection + if (tracker.hasSelection()) { + final var deletedNotes = new LinkedList(); + for (final var id : tracker.getSelection()) { + if (notes + .stream() + .filter(item -> !item.isSection()) + .map(item -> (Note) item) + .noneMatch(item -> item.getId() == id)) { + deletedNotes.add(id); + } + } + for (final var id : deletedNotes) { + tracker.deselect(id); + } + } + }); + } + @Override protected void onCreate(Bundle savedInstanceState) { SplashScreen.installSplashScreen(this); @@ -264,30 +291,8 @@ protected void onCreate(Bundle savedInstanceState) { startActivityForResult(createIntent, REQUEST_CODE_CREATE_NOTE); }); }); - mainViewModel.getNotesListLiveData().observe(this, notes -> { - // https://stackoverflow.com/a/37342327 - itemTouchHelper.attachToRecyclerView(null); - itemTouchHelper.attachToRecyclerView(listView); - adapter.setItemList(notes); - binding.activityNotesListView.progressCircular.setVisibility(GONE); - binding.activityNotesListView.emptyContentView.getRoot().setVisibility(notes.size() > 0 ? GONE : VISIBLE); - // Remove deleted notes from the selection - if (tracker.hasSelection()) { - final var deletedNotes = new LinkedList(); - for (final var id : tracker.getSelection()) { - if (notes - .stream() - .filter(item -> !item.isSection()) - .map(item -> (Note) item) - .noneMatch(item -> item.getId() == id)) { - deletedNotes.add(id); - } - } - for (final var id : deletedNotes) { - tracker.deselect(id); - } - } - }); + + getNotesListLiveData(); mainViewModel.getSearchTerm().observe(this, adapter::setHighlightSearchQuery); mainViewModel.getCategorySortingMethodOfSelectedCategory().observe(this, methodOfCategory -> { updateSortMethodIcon(methodOfCategory.second); From 77a5cde6dc89884fcbf2e3d49d6f7218114b0587 Mon Sep 17 00:00:00 2001 From: Fabian Diener Date: Wed, 27 Sep 2023 17:13:58 +0200 Subject: [PATCH 2/3] Only get notes when app is unlocked Signed-off-by: Fabian Diener --- .../java/it/niedermann/owncloud/notes/main/MainActivity.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java b/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java index 4e9e5ccd6..5b179fb4b 100644 --- a/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java +++ b/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java @@ -65,6 +65,7 @@ import it.niedermann.android.util.ColorUtil; import it.niedermann.owncloud.notes.LockedActivity; +import it.niedermann.owncloud.notes.NotesApplication; import it.niedermann.owncloud.notes.R; import it.niedermann.owncloud.notes.accountpicker.AccountPickerListener; import it.niedermann.owncloud.notes.accountswitcher.AccountSwitcherDialog; @@ -292,7 +293,9 @@ protected void onCreate(Bundle savedInstanceState) { }); }); - getNotesListLiveData(); + if (!NotesApplication.isLocked()) { + getNotesListLiveData(); + } mainViewModel.getSearchTerm().observe(this, adapter::setHighlightSearchQuery); mainViewModel.getCategorySortingMethodOfSelectedCategory().observe(this, methodOfCategory -> { updateSortMethodIcon(methodOfCategory.second); From d052d96e078dfcc5adc03510ce4128af928ae3a9 Mon Sep 17 00:00:00 2001 From: Fabian Diener Date: Wed, 27 Sep 2023 17:13:58 +0200 Subject: [PATCH 3/3] Load notes list when app got unlocked Signed-off-by: Fabian Diener --- .../java/it/niedermann/owncloud/notes/LockedActivity.java | 2 +- .../it/niedermann/owncloud/notes/main/MainActivity.java | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/it/niedermann/owncloud/notes/LockedActivity.java b/app/src/main/java/it/niedermann/owncloud/notes/LockedActivity.java index f5695a408..ab68ff34f 100644 --- a/app/src/main/java/it/niedermann/owncloud/notes/LockedActivity.java +++ b/app/src/main/java/it/niedermann/owncloud/notes/LockedActivity.java @@ -17,7 +17,7 @@ public abstract class LockedActivity extends BrandedActivity { private static final String TAG = LockedActivity.class.getSimpleName(); - private static final int REQUEST_CODE_UNLOCK = 100; + protected static final int REQUEST_CODE_UNLOCK = 100; @Override diff --git a/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java b/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java index 5b179fb4b..948a0abc8 100644 --- a/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java +++ b/app/src/main/java/it/niedermann/owncloud/notes/main/MainActivity.java @@ -691,6 +691,12 @@ protected void onActivityResult(int requestCode, int resultCode, Intent data) { } break; } + case REQUEST_CODE_UNLOCK: { + if (RESULT_OK == resultCode) { + getNotesListLiveData(); + } + break; + } default: { try { AccountImporter.onActivityResult(requestCode, resultCode, data, this, (ssoAccount) -> {