MangaDex - tweak group search (#3135)
This commit is contained in:
parent
27252e718f
commit
ff800f6fea
|
@ -5,7 +5,7 @@ ext {
|
||||||
appName = 'Tachiyomi: MangaDex'
|
appName = 'Tachiyomi: MangaDex'
|
||||||
pkgNameSuffix = 'all.mangadex'
|
pkgNameSuffix = 'all.mangadex'
|
||||||
extClass = '.MangadexFactory'
|
extClass = '.MangadexFactory'
|
||||||
extVersionCode = 89
|
extVersionCode = 90
|
||||||
libVersion = '1.2'
|
libVersion = '1.2'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -206,9 +206,10 @@ abstract class Mangadex(
|
||||||
return clientBuilder()
|
return clientBuilder()
|
||||||
}
|
}
|
||||||
|
|
||||||
private var groupSearch = ""
|
private var groupSearch: String? = null
|
||||||
|
|
||||||
override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request {
|
override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request {
|
||||||
|
if (page == 1) groupSearch = null
|
||||||
val genresToInclude = mutableListOf<String>()
|
val genresToInclude = mutableListOf<String>()
|
||||||
val genresToExclude = mutableListOf<String>()
|
val genresToExclude = mutableListOf<String>()
|
||||||
|
|
||||||
|
@ -302,8 +303,8 @@ abstract class Mangadex(
|
||||||
is ScanGroup -> {
|
is ScanGroup -> {
|
||||||
groupSearch = when {
|
groupSearch = when {
|
||||||
filter.state.isNotEmpty() && page == 1 -> "$baseUrl/groups/0/1/${filter.state}"
|
filter.state.isNotEmpty() && page == 1 -> "$baseUrl/groups/0/1/${filter.state}"
|
||||||
filter.state.isNotEmpty() && page > 1 -> groupSearch.dropLast(1) + page
|
filter.state.isNotEmpty() && page > 1 -> "${groupSearch!!}/$page"
|
||||||
else -> ""
|
else -> null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -318,23 +319,17 @@ abstract class Mangadex(
|
||||||
urlToUse += "&tags_exc=" + genresToExclude.joinToString(",")
|
urlToUse += "&tags_exc=" + genresToExclude.joinToString(",")
|
||||||
}
|
}
|
||||||
|
|
||||||
return if (groupSearch.isNotEmpty()) {
|
return GET(groupSearch ?: urlToUse, headersBuilder().build(), CacheControl.FORCE_NETWORK)
|
||||||
GET(groupSearch, headersBuilder().build(), CacheControl.FORCE_NETWORK)
|
|
||||||
} else {
|
|
||||||
GET(urlToUse, headersBuilder().build(), CacheControl.FORCE_NETWORK)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun searchMangaParse(response: Response): MangasPage {
|
override fun searchMangaParse(response: Response): MangasPage {
|
||||||
if (response.request().url().toString().contains("/groups/")) {
|
return if (response.request().url().toString().contains("/groups/")) {
|
||||||
response.asJsoup().select(".table > tbody:nth-child(2) > tr:nth-child(1) > td:nth-child(2) > a:nth-child(1)").attr("abs:href").let {
|
response.asJsoup().select(".table > tbody:nth-child(2) > tr:nth-child(1) > td:nth-child(2) > a").firstOrNull()?.attr("abs:href")
|
||||||
return if (it.isNotEmpty()) {
|
?.let {
|
||||||
groupSearch = "$it/manga/0/1"
|
groupSearch = "$it/manga/0"
|
||||||
super.searchMangaParse(client.newCall(GET(groupSearch, headersBuilder().build())).execute())
|
super.searchMangaParse(client.newCall(GET(groupSearch!!, headersBuilder().build())).execute())
|
||||||
} else {
|
|
||||||
MangasPage(emptyList(), false)
|
|
||||||
}
|
}
|
||||||
}
|
?: MangasPage(emptyList(), false)
|
||||||
} else {
|
} else {
|
||||||
val document = response.asJsoup()
|
val document = response.asJsoup()
|
||||||
if (document.select("#login_button").isNotEmpty()) throw Exception("Log in via WebView to enable search")
|
if (document.select("#login_button").isNotEmpty()) throw Exception("Log in via WebView to enable search")
|
||||||
|
@ -347,7 +342,7 @@ abstract class Mangadex(
|
||||||
document.select(selector).first()
|
document.select(selector).first()
|
||||||
} != null
|
} != null
|
||||||
|
|
||||||
return MangasPage(mangas, hasNextPage)
|
MangasPage(mangas, hasNextPage)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue