Final touches

Zakhar Timoshenko 4 years ago
parent 5b35441bf2
commit b5c830e10e

@ -29,7 +29,7 @@ class NicovideoSeigaParser(override val context: MangaLoaderContext) : MangaPars
override suspend fun getUsername(): String { override suspend fun getUsername(): String {
val body = context.httpGet("https://app.nicovideo.jp/my/apps").parseHtml().body() val body = context.httpGet("https://app.nicovideo.jp/my/apps").parseHtml().body()
return body.selectFirst("#userinfo > div > div > strong")?.text() ?: parseFailed("Cannot get username") return body.selectFirst("#userinfo > div > div > strong")?.text() ?: throw AuthRequiredException(source)
} }
override val sortOrders: Set<SortOrder> = EnumSet.of( override val sortOrders: Set<SortOrder> = EnumSet.of(
@ -46,10 +46,13 @@ class NicovideoSeigaParser(override val context: MangaLoaderContext) : MangaPars
sortOrder: SortOrder?, sortOrder: SortOrder?,
): List<Manga> { ): List<Manga> {
val page = (offset / 20f).toIntUp().inc() val page = (offset / 20f).toIntUp().inc()
if (!query.isNullOrEmpty()) { val url = when {
return if (offset == 0) getSearchList(query, page) else emptyList() !query.isNullOrEmpty() -> return if (offset == 0) getSearchList(query, page) else emptyList()
tags.isNullOrEmpty() -> "https://${getDomain()}/manga/list?page=$page&sort=${getSortKey(sortOrder)}"
tags.size == 1 -> "https://${getDomain()}${tags.first().key}?page=$page&sort=${getSortKey(sortOrder)}"
tags.size > 1 -> throw IllegalArgumentException("This source supports only 1 category")
else -> "https://${getDomain()}/manga/list?page=$page&sort=${getSortKey(sortOrder)}"
} }
val url = "/manga/list?page=$page&sort=${getSortKey(sortOrder)}".withDomain()
val doc = context.httpGet(url).parseHtml() val doc = context.httpGet(url).parseHtml()
val comicList = doc.body().select("#comic_list > ul > li") ?: parseFailed("Container not found") val comicList = doc.body().select("#comic_list > ul > li") ?: parseFailed("Container not found")
val items = comicList.select("div > .description > div > div") val items = comicList.select("div > .description > div > div")
@ -65,7 +68,13 @@ class NicovideoSeigaParser(override val context: MangaLoaderContext) : MangaPars
rating = RATING_UNKNOWN, rating = RATING_UNKNOWN,
url = href, url = href,
isNsfw = false, isNsfw = false,
tags = emptySet(), tags = item.getElementsByAttributeValueContaining("href", "?category=").mapToSet { a ->
MangaTag(
key = a.attr("href").substringAfterLast('='),
title = a.ownText().trim(),
source = source,
)
},
state = when (statusText) { state = when (statusText) {
STATUS_ONGOING -> MangaState.ONGOING STATUS_ONGOING -> MangaState.ONGOING
STATUS_FINISHED -> MangaState.FINISHED STATUS_FINISHED -> MangaState.FINISHED
@ -89,6 +98,7 @@ class NicovideoSeigaParser(override val context: MangaLoaderContext) : MangaPars
STATUS_FINISHED -> MangaState.FINISHED STATUS_FINISHED -> MangaState.FINISHED
else -> null else -> null
}, },
isNsfw = contents.select(".icon_adult").isNotEmpty(),
chapters = contents.select("#episode_list > ul > li").mapIndexedNotNull { i, li -> chapters = contents.select("#episode_list > ul > li").mapIndexedNotNull { i, li ->
val href = li.selectFirst("div > div.description > div.title > a")?.attrAsRelativeUrl("href") ?: parseFailed() val href = li.selectFirst("div > div.description > div.title > a")?.attrAsRelativeUrl("href") ?: parseFailed()
MangaChapter( MangaChapter(
@ -124,7 +134,16 @@ class NicovideoSeigaParser(override val context: MangaLoaderContext) : MangaPars
} }
override suspend fun getTags(): Set<MangaTag> { override suspend fun getTags(): Set<MangaTag> {
return emptySet() val doc = context.httpGet("https://${getDomain()}/manga/list").parseHtml()
val root = doc.body().select("#mg_category_list > ul > li") ?: parseFailed("Cannot find tags")
return root.mapToSet { li ->
val a = li.selectFirst("a") ?: parseFailed("a is null")
MangaTag(
title = a.text(),
key = a.attrAsRelativeUrlOrNull("href").orEmpty(),
source = source,
)
}
} }
private suspend fun getSearchList(query: String, page: Int): List<Manga> { private suspend fun getSearchList(query: String, page: Int): List<Manga> {

Loading…
Cancel
Save