cleanup done

This commit is contained in:
Deltashot 2022-10-10 21:55:49 +02:00
parent 1bee855766
commit 289b076864
3 changed files with 26 additions and 26 deletions

View File

@ -70,7 +70,7 @@ fun LibraryScreen(
onChangeCurrentPage = { presenter.activeCategory = it },
onMangaClicked = onMangaClicked,
onToggleSelection = { presenter.toggleSelection(it) },
onToggleMultiSelection = { presenter.toggleMultiSelection(it) },
onToggleSelectBetween = { presenter.toggleSelectBetween(it) },
onRefresh = onClickRefresh,
onGlobalSearchClicked = onGlobalSearchClicked,
getNumberOfMangaForCategory = { presenter.getMangaCountForCategory(it) },

View File

@ -45,7 +45,7 @@ fun LibraryContent(
onChangeCurrentPage: (Int) -> Unit,
onMangaClicked: (Long) -> Unit,
onToggleSelection: (LibraryManga) -> Unit,
onToggleMultiSelection: (LibraryManga) -> Unit,
onToggleSelectBetween: (LibraryManga) -> Unit,
onRefresh: (Category?) -> Boolean,
onGlobalSearchClicked: () -> Unit,
getNumberOfMangaForCategory: @Composable (Long) -> State<Int?>,
@ -86,7 +86,7 @@ fun LibraryContent(
}
}
val onLongClickManga = { manga: LibraryManga ->
onToggleMultiSelection(manga)
onToggleSelectBetween(manga)
}
SwipeRefresh(

View File

@ -663,41 +663,41 @@ class LibraryPresenter(
state.selection = emptyList()
}
fun removeSelected(mutableList: MutableList<LibraryManga>, manga: LibraryManga): Boolean {
if(selection.fastAny { it.manga.id == manga.manga.id })
return mutableList.remove(manga);
return false
}
fun toggleSelection(manga: LibraryManga) {
val mutableList = state.selection.toMutableList()
if (selection.fastAny { it.manga.id == manga.manga.id }) {
mutableList.remove(manga)
state.selection = mutableList
} else {
if (!removeSelected(mutableList, manga)) {
mutableList.add(manga)
}
state.selection = mutableList
}
}
fun toggleMultiSelection(manga: LibraryManga) {
/**
* Selects all mangas between and including the given manga and the last pressed manga from the
* same category as the given manga
*/
fun toggleSelectBetween(manga: LibraryManga) {
val mutableList = state.selection.toMutableList()
if (selection.fastAny { it.manga.id == manga.manga.id }) {
mutableList.remove(manga)
state.selection = mutableList
} else if (mutableList.fastAny{ it.category == manga.category }) {
if (!removeSelected(mutableList, manga) &&
mutableList.fastAny{ it.category == manga.category }) {
val items = (loadedManga[manga.category] ?: emptyList()).map { it.libraryManga }
val lastMangaIndex =
items.indexOf(mutableList.findLast { it.category == manga.category })
val lastMangaIndex = items.indexOf(mutableList.findLast { it.category == manga.category })
val curMangaIndex = items.indexOf(manga)
val newList = when (lastMangaIndex >= curMangaIndex + 1) {
true -> items.subList(curMangaIndex, lastMangaIndex)
false -> items.subList(lastMangaIndex, curMangaIndex + 1)
}
state.selection = state.selection.toMutableList().apply {
addAll(newList.filterNot { it in selection }.map { it })
}
mutableList.apply { addAll(newList.filterNot { it in selection }.map { it }) }
} else {
mutableList.add(manga)
state.selection = mutableList
}
state.selection = mutableList
}
fun selectAll(index: Int) {