Move manga to default category (#166)
Also removed option for how to move manga between categories, will always keep category's sorting
This commit is contained in:
parent
7325a79318
commit
3ccaf92770
@ -145,8 +145,6 @@ object PreferenceKeys {
|
|||||||
|
|
||||||
const val updateOnRefresh = "update_on_refresh"
|
const val updateOnRefresh = "update_on_refresh"
|
||||||
|
|
||||||
const val keepCatSort = "keep_cat_sort"
|
|
||||||
|
|
||||||
const val alwaysShowChapterTransition = "always_show_chapter_transition"
|
const val alwaysShowChapterTransition = "always_show_chapter_transition"
|
||||||
|
|
||||||
@Deprecated("Use the preferences of the source")
|
@Deprecated("Use the preferences of the source")
|
||||||
|
@ -251,8 +251,6 @@ class PreferencesHelper(val context: Context) {
|
|||||||
|
|
||||||
fun unreadBadgeType() = rxPrefs.getInteger("unread_badge_type", 2)
|
fun unreadBadgeType() = rxPrefs.getInteger("unread_badge_type", 2)
|
||||||
|
|
||||||
fun keepCatSort() = rxPrefs.getInteger(Keys.keepCatSort, 0)
|
|
||||||
|
|
||||||
fun hideFiltersAtStart() = rxPrefs.getBoolean("hide_filters_at_start", false)
|
fun hideFiltersAtStart() = rxPrefs.getBoolean("hide_filters_at_start", false)
|
||||||
|
|
||||||
fun alwaysShowChapterTransition() = rxPrefs.getBoolean(Keys.alwaysShowChapterTransition, true)
|
fun alwaysShowChapterTransition() = rxPrefs.getBoolean(Keys.alwaysShowChapterTransition, true)
|
||||||
|
@ -15,12 +15,6 @@ class CenteredToolbar@JvmOverloads constructor(context: Context, attrs: Attribut
|
|||||||
toolbar_title.text = null
|
toolbar_title.text = null
|
||||||
} else {
|
} else {
|
||||||
toolbar_title.text = context.getString(resId)
|
toolbar_title.text = context.getString(resId)
|
||||||
post {
|
|
||||||
if (navigationIcon !is DrawerArrowDrawable) {
|
|
||||||
toolbar_title.text = context.getString(resId)
|
|
||||||
requestLayout()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
super.setTitle(null)
|
super.setTitle(null)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -31,12 +25,6 @@ class CenteredToolbar@JvmOverloads constructor(context: Context, attrs: Attribut
|
|||||||
toolbar_title.text = ""
|
toolbar_title.text = ""
|
||||||
} else {
|
} else {
|
||||||
toolbar_title.text = title
|
toolbar_title.text = title
|
||||||
post {
|
|
||||||
if (navigationIcon !is DrawerArrowDrawable) {
|
|
||||||
toolbar_title.text = title
|
|
||||||
requestLayout()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
super.setTitle(null)
|
super.setTitle(null)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -97,7 +97,7 @@ class LibraryCategoryAdapter(val libraryListener: LibraryListener) :
|
|||||||
val db: DatabaseHelper by injectLazy()
|
val db: DatabaseHelper by injectLazy()
|
||||||
return when (val item: IFlexible<*>? = getItem(position)) {
|
return when (val item: IFlexible<*>? = getItem(position)) {
|
||||||
is LibraryHeaderItem ->
|
is LibraryHeaderItem ->
|
||||||
if (preferences.hideCategories().getOrDefault()) null
|
if (preferences.hideCategories().getOrDefault() || item.category.id == 0) null
|
||||||
else getFirstLetter(item.category.name) +
|
else getFirstLetter(item.category.name) +
|
||||||
"\u200B".repeat(max(0, item.category.order))
|
"\u200B".repeat(max(0, item.category.order))
|
||||||
is LibraryItem -> {
|
is LibraryItem -> {
|
||||||
|
@ -23,8 +23,6 @@ import androidx.recyclerview.widget.ItemTouchHelper
|
|||||||
import androidx.recyclerview.widget.LinearLayoutManager
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
import androidx.recyclerview.widget.RecyclerView
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
import com.afollestad.materialdialogs.MaterialDialog
|
import com.afollestad.materialdialogs.MaterialDialog
|
||||||
import com.afollestad.materialdialogs.checkbox.checkBoxPrompt
|
|
||||||
import com.afollestad.materialdialogs.checkbox.isCheckPromptChecked
|
|
||||||
import com.afollestad.materialdialogs.list.listItemsSingleChoice
|
import com.afollestad.materialdialogs.list.listItemsSingleChoice
|
||||||
import com.bluelinelabs.conductor.ControllerChangeHandler
|
import com.bluelinelabs.conductor.ControllerChangeHandler
|
||||||
import com.bluelinelabs.conductor.ControllerChangeType
|
import com.bluelinelabs.conductor.ControllerChangeType
|
||||||
@ -73,7 +71,6 @@ import kotlinx.android.synthetic.main.main_activity.*
|
|||||||
import kotlinx.coroutines.delay
|
import kotlinx.coroutines.delay
|
||||||
import uy.kohesive.injekt.Injekt
|
import uy.kohesive.injekt.Injekt
|
||||||
import uy.kohesive.injekt.api.get
|
import uy.kohesive.injekt.api.get
|
||||||
import java.util.Locale
|
|
||||||
import kotlin.math.abs
|
import kotlin.math.abs
|
||||||
import kotlin.math.roundToInt
|
import kotlin.math.roundToInt
|
||||||
|
|
||||||
@ -158,7 +155,7 @@ class LibraryController(
|
|||||||
scrollDistance = 0f
|
scrollDistance = 0f
|
||||||
}
|
}
|
||||||
} else scrollDistance = 0f
|
} else scrollDistance = 0f
|
||||||
if (order != null && order != activeCategory) {
|
if (order != null && order != activeCategory && lastItem == null) {
|
||||||
preferences.lastUsedCategory().set(order)
|
preferences.lastUsedCategory().set(order)
|
||||||
activeCategory = order
|
activeCategory = order
|
||||||
setTitle()
|
setTitle()
|
||||||
@ -663,10 +660,16 @@ class LibraryController(
|
|||||||
|
|
||||||
override fun onItemMove(fromPosition: Int, toPosition: Int) {
|
override fun onItemMove(fromPosition: Int, toPosition: Int) {
|
||||||
// Because padding a recycler causes it to scroll up we have to scroll it back down... wild
|
// Because padding a recycler causes it to scroll up we have to scroll it back down... wild
|
||||||
if ((adapter.getItem(fromPosition) is LibraryItem && adapter.getItem(fromPosition) is LibraryItem) || adapter.getItem(
|
if ((adapter.getItem(fromPosition) is LibraryItem && adapter.getItem(fromPosition) is
|
||||||
|
LibraryItem) || adapter.getItem(
|
||||||
fromPosition
|
fromPosition
|
||||||
) == null
|
) == null
|
||||||
) recycler.scrollBy(0, recycler.paddingTop)
|
) {
|
||||||
|
recycler.scrollBy(0, recycler.paddingTop)
|
||||||
|
view?.post {
|
||||||
|
setTitle()
|
||||||
|
}
|
||||||
|
}
|
||||||
activity?.appbar?.y = 0f
|
activity?.appbar?.y = 0f
|
||||||
if (lastItemPosition == toPosition) lastItemPosition = null
|
if (lastItemPosition == toPosition) lastItemPosition = null
|
||||||
else if (lastItemPosition == null) lastItemPosition = fromPosition
|
else if (lastItemPosition == null) lastItemPosition = fromPosition
|
||||||
@ -676,7 +679,7 @@ class LibraryController(
|
|||||||
if (adapter.isSelected(fromPosition)) toggleSelection(fromPosition)
|
if (adapter.isSelected(fromPosition)) toggleSelection(fromPosition)
|
||||||
val item = adapter.getItem(fromPosition) as? LibraryItem ?: return false
|
val item = adapter.getItem(fromPosition) as? LibraryItem ?: return false
|
||||||
val newHeader = adapter.getSectionHeader(toPosition) as? LibraryHeaderItem
|
val newHeader = adapter.getSectionHeader(toPosition) as? LibraryHeaderItem
|
||||||
if (toPosition <= 1) return false
|
if (toPosition < 1) return false
|
||||||
return (adapter.getItem(toPosition) !is LibraryHeaderItem) && (newHeader?.category?.id == item.manga.category || !presenter.mangaIsInCategory(
|
return (adapter.getItem(toPosition) !is LibraryHeaderItem) && (newHeader?.category?.id == item.manga.category || !presenter.mangaIsInCategory(
|
||||||
item.manga, newHeader?.category?.id
|
item.manga, newHeader?.category?.id
|
||||||
))
|
))
|
||||||
@ -687,6 +690,7 @@ class LibraryController(
|
|||||||
lastItemPosition = null
|
lastItemPosition = null
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
lastItem = null
|
||||||
destroyActionModeIfNeeded()
|
destroyActionModeIfNeeded()
|
||||||
// if nothing moved
|
// if nothing moved
|
||||||
if (lastItemPosition == null) return
|
if (lastItemPosition == null) return
|
||||||
@ -705,36 +709,9 @@ class LibraryController(
|
|||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if (newHeader?.category?.mangaSort == null) {
|
if (newHeader?.category != null) moveMangaToCategory(
|
||||||
moveMangaToCategory(item.manga, newHeader?.category, mangaIds, true)
|
item.manga, newHeader.category, mangaIds
|
||||||
} else {
|
|
||||||
val keepCatSort = preferences.keepCatSort().getOrDefault()
|
|
||||||
if (keepCatSort == 0) {
|
|
||||||
MaterialDialog(activity!!).message(R.string.switch_to_dnd)
|
|
||||||
.positiveButton(R.string.action_switch) {
|
|
||||||
moveMangaToCategory(
|
|
||||||
item.manga, newHeader.category, mangaIds, true
|
|
||||||
)
|
)
|
||||||
if (it.isCheckPromptChecked()) preferences.keepCatSort().set(2)
|
|
||||||
}.checkBoxPrompt(R.string.remember_choice) {}.negativeButton(
|
|
||||||
text = resources?.getString(
|
|
||||||
R.string.keep_current_sort,
|
|
||||||
resources!!.getString(newHeader.category.sortRes()).toLowerCase(
|
|
||||||
Locale.getDefault()
|
|
||||||
)
|
|
||||||
)
|
|
||||||
) {
|
|
||||||
moveMangaToCategory(
|
|
||||||
item.manga, newHeader.category, mangaIds, false
|
|
||||||
)
|
|
||||||
if (it.isCheckPromptChecked()) preferences.keepCatSort().set(1)
|
|
||||||
}.cancelOnTouchOutside(false).show()
|
|
||||||
} else {
|
|
||||||
moveMangaToCategory(
|
|
||||||
item.manga, newHeader.category, mangaIds, keepCatSort == 2
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
lastItemPosition = null
|
lastItemPosition = null
|
||||||
}
|
}
|
||||||
@ -742,12 +719,11 @@ class LibraryController(
|
|||||||
private fun moveMangaToCategory(
|
private fun moveMangaToCategory(
|
||||||
manga: LibraryManga,
|
manga: LibraryManga,
|
||||||
category: Category?,
|
category: Category?,
|
||||||
mangaIds: List<Long>,
|
mangaIds: List<Long>
|
||||||
useDND: Boolean
|
|
||||||
) {
|
) {
|
||||||
if (category?.id == null) return
|
if (category?.id == null) return
|
||||||
val oldCatId = manga.category
|
val oldCatId = manga.category
|
||||||
presenter.moveMangaToCategory(manga, category.id, mangaIds, useDND)
|
presenter.moveMangaToCategory(manga, category.id, mangaIds)
|
||||||
snack?.dismiss()
|
snack?.dismiss()
|
||||||
snack = view?.snack(
|
snack = view?.snack(
|
||||||
resources!!.getString(R.string.moved_to_category, category.name)
|
resources!!.getString(R.string.moved_to_category, category.name)
|
||||||
@ -755,7 +731,7 @@ class LibraryController(
|
|||||||
anchorView = bottom_sheet
|
anchorView = bottom_sheet
|
||||||
setAction(R.string.action_undo) {
|
setAction(R.string.action_undo) {
|
||||||
manga.category = category.id!!
|
manga.category = category.id!!
|
||||||
presenter.moveMangaToCategory(manga, oldCatId, mangaIds, useDND)
|
presenter.moveMangaToCategory(manga, oldCatId, mangaIds)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -853,28 +853,20 @@ class LibraryPresenter(
|
|||||||
fun moveMangaToCategory(
|
fun moveMangaToCategory(
|
||||||
manga: LibraryManga,
|
manga: LibraryManga,
|
||||||
catId: Int?,
|
catId: Int?,
|
||||||
mangaIds: List<Long>,
|
mangaIds: List<Long>
|
||||||
useDND: Boolean
|
|
||||||
) {
|
) {
|
||||||
GlobalScope.launch(Dispatchers.IO) {
|
GlobalScope.launch(Dispatchers.IO) {
|
||||||
val categoryId = catId ?: return@launch
|
val categoryId = catId ?: return@launch
|
||||||
val category = categories.find { catId == it.id } ?: return@launch
|
val category = categories.find { catId == it.id } ?: return@launch
|
||||||
|
|
||||||
/*val mangaMap = currentMangaMap?.toMutableMap() ?: return@launch
|
|
||||||
val oldCatId = item.manga.category
|
|
||||||
val oldCatMap = mangaMap[manga.category]?.toMutableList() ?: return@launch
|
|
||||||
val newCatMap = mangaMap[catId]?.toMutableList() ?: return@launch
|
|
||||||
oldCatMap.remove(item)
|
|
||||||
newCatMap.add(item)
|
|
||||||
mangaMap[oldCatId] = oldCatMap
|
|
||||||
mangaMap[catId] = newCatMap
|
|
||||||
currentMangaMap = mangaMap*/
|
|
||||||
|
|
||||||
val oldCatId = manga.category
|
val oldCatId = manga.category
|
||||||
manga.category = categoryId
|
manga.category = categoryId
|
||||||
|
|
||||||
val mc = ArrayList<MangaCategory>()
|
val mc = ArrayList<MangaCategory>()
|
||||||
val categories = db.getCategoriesForManga(manga).executeAsBlocking()
|
val categories =
|
||||||
|
if (catId == 0) emptyList()
|
||||||
|
else
|
||||||
|
db.getCategoriesForManga(manga).executeAsBlocking()
|
||||||
.filter { it.id != oldCatId } + listOf(category)
|
.filter { it.id != oldCatId } + listOf(category)
|
||||||
|
|
||||||
for (cat in categories) {
|
for (cat in categories) {
|
||||||
@ -883,8 +875,7 @@ class LibraryPresenter(
|
|||||||
|
|
||||||
db.setMangaCategories(mc, listOf(manga))
|
db.setMangaCategories(mc, listOf(manga))
|
||||||
|
|
||||||
if (useDND) {
|
if (category.mangaSort == null) {
|
||||||
category.mangaSort = null
|
|
||||||
val ids = mangaIds.toMutableList()
|
val ids = mangaIds.toMutableList()
|
||||||
if (!ids.contains(manga.id!!)) ids.add(manga.id!!)
|
if (!ids.contains(manga.id!!)) ids.add(manga.id!!)
|
||||||
category.mangaOrder = ids
|
category.mangaOrder = ids
|
||||||
|
@ -29,14 +29,6 @@ class SettingsLibraryController : SettingsController() {
|
|||||||
titleRes = R.string.pref_category_library
|
titleRes = R.string.pref_category_library
|
||||||
preferenceCategory {
|
preferenceCategory {
|
||||||
titleRes = R.string.pref_category_library_display
|
titleRes = R.string.pref_category_library_display
|
||||||
/*
|
|
||||||
switchPreference {
|
|
||||||
key = Keys.libraryAsSingleList
|
|
||||||
titleRes = R.string.pref_library_single_list
|
|
||||||
summaryRes = R.string.pref_library_single_list_summary
|
|
||||||
defaultValue = false
|
|
||||||
}*/
|
|
||||||
|
|
||||||
switchPreference {
|
switchPreference {
|
||||||
key = Keys.removeArticles
|
key = Keys.removeArticles
|
||||||
titleRes = R.string.pref_remove_articles
|
titleRes = R.string.pref_remove_articles
|
||||||
@ -75,19 +67,6 @@ class SettingsLibraryController : SettingsController() {
|
|||||||
true
|
true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
intListPreference(activity) {
|
|
||||||
titleRes = R.string.pref_keep_category_sorting
|
|
||||||
key = Keys.keepCatSort
|
|
||||||
|
|
||||||
customSummary = context.getString(R.string.pref_keep_category_sorting_summary)
|
|
||||||
entries = listOf(
|
|
||||||
context.getString(R.string.always_ask),
|
|
||||||
context.getString(R.string.option_keep_category_sort),
|
|
||||||
context.getString(R.string.option_switch_to_dnd)
|
|
||||||
)
|
|
||||||
entryRange = 0..2
|
|
||||||
defaultValue = 0
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
preferenceCategory {
|
preferenceCategory {
|
||||||
|
@ -260,14 +260,6 @@
|
|||||||
when updating library (overwrites local covers)</string>
|
when updating library (overwrites local covers)</string>
|
||||||
|
|
||||||
<string name="pref_category_library_migration">Migration</string>
|
<string name="pref_category_library_migration">Migration</string>
|
||||||
<string name="pref_keep_category_sorting">Change category sorting when moving</string>
|
|
||||||
<string name="pref_keep_category_sorting_summary">Should dragging and
|
|
||||||
dropping an entry into a new category change the category\'s sorting to drag &
|
|
||||||
drop?</string>
|
|
||||||
<string name="always_ask">Always ask</string>
|
|
||||||
<string name="option_keep_category_sort">Keep category\'s current sorting</string>
|
|
||||||
<string name="option_switch_to_dnd">Switch to Drag & Drop</string>
|
|
||||||
|
|
||||||
|
|
||||||
<!-- Extension section -->
|
<!-- Extension section -->
|
||||||
<string name="all_lang">All</string>
|
<string name="all_lang">All</string>
|
||||||
@ -460,13 +452,11 @@
|
|||||||
<string name="category_is_empty">Category is empty</string>
|
<string name="category_is_empty">Category is empty</string>
|
||||||
<string name="local_source_badge">Local</string>
|
<string name="local_source_badge">Local</string>
|
||||||
<string name="confirm_manga_deletion">Remove from library?</string>
|
<string name="confirm_manga_deletion">Remove from library?</string>
|
||||||
<string name="switch_to_dnd">Switch to Drag & Drop mode?</string>
|
|
||||||
<string name="what_should_update">What should update?</string>
|
<string name="what_should_update">What should update?</string>
|
||||||
<string name="top_category">Top category (%1$s)</string>
|
<string name="top_category">Top category (%1$s)</string>
|
||||||
<string name="first_category">First category</string>
|
<string name="first_category">First category</string>
|
||||||
<string name="categories_on_manual">Categories to update when manually refreshing</string>
|
<string name="categories_on_manual">Categories to update when manually refreshing</string>
|
||||||
<string name="categories_in_global_update">All categories in global update</string>
|
<string name="categories_in_global_update">All categories in global update</string>
|
||||||
<string name="keep_current_sort">Keep sorting by %1$s</string>
|
|
||||||
<string name="confirm_category_deletion">Delete category?</string>
|
<string name="confirm_category_deletion">Delete category?</string>
|
||||||
<string name="confirm_category_deletion_message">Manga in this category will moved into the
|
<string name="confirm_category_deletion_message">Manga in this category will moved into the
|
||||||
default category.</string>
|
default category.</string>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user