Fix Anibel issues

pull/30/head
ztimms73 5 years ago
parent 323c1defaa
commit 98147d0a81

@ -14,7 +14,7 @@ class AnibelRepository(loaderContext: MangaLoaderContext) : RemoteMangaRepositor
override val defaultDomain = "anibel.net" override val defaultDomain = "anibel.net"
override val sortOrders: Set<SortOrder> = EnumSet.of( override val sortOrders: Set<SortOrder> = EnumSet.of(
SortOrder.UPDATED SortOrder.NEWEST
) )
override suspend fun getList( override suspend fun getList(
@ -26,42 +26,33 @@ class AnibelRepository(loaderContext: MangaLoaderContext) : RemoteMangaRepositor
if (!query.isNullOrEmpty()) { if (!query.isNullOrEmpty()) {
return if (offset == 0) search(query) else emptyList() return if (offset == 0) search(query) else emptyList()
} }
val page = (offset / 12).inc() val page = (offset / 12f).toIntUp().inc()
val tagPage = offset.inc() //TODO Load another pages val link = when {
val link = buildString { tag != null -> "/manga?genre[]=${tag.key}&page=$page".withDomain()
append("https://") else -> "/manga?page=$page".withDomain()
append(getDomain())
append("/manga")
if (tag != null) {
append("?genre[]=")
append(tag.key)
append("&page=")
append(tagPage)
} else {
append("?page=")
append(page)
}
} }
val doc = loaderContext.httpGet(link).parseHtml() val doc = loaderContext.httpGet(link).parseHtml()
val root = doc.body().select("div.manga-block") ?: throw ParseException("Cannot find root") val root = doc.body().select("div.manga-block") ?: throw ParseException("Cannot find root")
val items = root.select("div.anime-card") val items = root.select("div.anime-card")
return items.mapNotNull { card -> return items.mapNotNull { card ->
val href = card.select("a").attr("href") val href = card.selectFirst("a").attr("href")
val url = buildString {
append("https://")
append(getDomain())
append("/")
}
val status = card.select("tr")[2].text() val status = card.select("tr")[2].text()
Manga( Manga(
id = generateUid(href), id = generateUid(href),
title = card.selectFirst("h1.anime-card-title").text(), title = card.selectFirst("h1.anime-card-title").text(),
coverUrl = url + card.selectFirst("img").attr("data-src"), coverUrl = card.selectFirst("img").attr("data-src").withDomain(),
altTitle = null, altTitle = null,
author = null, author = null,
rating = Manga.NO_RATING, rating = Manga.NO_RATING,
url = url + href, url = href,
publicUrl = "", publicUrl = href.withDomain(),
tags = card.select("p.tupe.tag")?.select("a")?.mapNotNullToSet tags@{ x ->
MangaTag(
title = x.text(),
key = x.attr("href") ?: return@tags null,
source = source
)
}.orEmpty(),
state = when (status) { state = when (status) {
"выпускаецца" -> MangaState.ONGOING "выпускаецца" -> MangaState.ONGOING
"завершанае" -> MangaState.FINISHED "завершанае" -> MangaState.FINISHED
@ -73,19 +64,14 @@ class AnibelRepository(loaderContext: MangaLoaderContext) : RemoteMangaRepositor
} }
override suspend fun getDetails(manga: Manga): Manga { override suspend fun getDetails(manga: Manga): Manga {
val doc = loaderContext.httpGet(manga.url.withDomain()).parseHtml() val doc = loaderContext.httpGet(manga.publicUrl).parseHtml()
val root = doc.body().select("div.container") ?: throw ParseException("Cannot find root") val root = doc.body().select("div.container") ?: throw ParseException("Cannot find root")
return manga.copy( return manga.copy(
description = root.select("div.manga-block.grid-12")[2].select("p").text(), description = root.select("div.manga-block.grid-12")[2].select("p").text(),
largeCoverUrl = manga.coverUrl,
chapters = root.select("ul.series").flatMap { table -> chapters = root.select("ul.series").flatMap { table ->
table.select("li") table.select("li")
}.map { it.selectFirst("a") }.mapIndexedNotNull { i, a -> }.map { it.selectFirst("a") }.mapIndexedNotNull { i, a ->
val url = buildString { val href = a.select("a").first().attr("href").toRelativeUrl(getDomain())
append("https://")
append(getDomain())
}
val href = url + a.select("a").first().attr("href")
MangaChapter( MangaChapter(
id = generateUid(href), id = generateUid(href),
name = a.select("a").first().text(), name = a.select("a").first().text(),
@ -145,30 +131,23 @@ class AnibelRepository(loaderContext: MangaLoaderContext) : RemoteMangaRepositor
val items = root.select("div.anime-card") val items = root.select("div.anime-card")
return items.mapNotNull { card -> return items.mapNotNull { card ->
val href = card.select("a").attr("href") val href = card.select("a").attr("href")
val url = buildString {
append("https://")
append(getDomain())
}
val status = card.select("tr")[2].text() val status = card.select("tr")[2].text()
Manga( Manga(
id = generateUid(href), id = generateUid(href),
title = card.selectFirst("h1.anime-card-title").text(), title = card.selectFirst("h1.anime-card-title").text(),
coverUrl = url + card.selectFirst("img").attr("src"), coverUrl = card.selectFirst("img").attr("src").withDomain(),
altTitle = null, altTitle = null,
author = null, author = null,
rating = Manga.NO_RATING, rating = Manga.NO_RATING,
url = url + href, url = href,
publicUrl = "", publicUrl = href.withDomain(),
tags = runCatching { tags = card.select("p.tupe.tag")?.select("a")?.mapNotNullToSet tags@{ x ->
card?.select("p.tupe.tag")
?.mapToSet {
MangaTag( MangaTag(
title = it.select("a").text(), title = x.text(),
key = it.attr("href"), key = x.attr("href") ?: return@tags null,
source = source source = source
) )
} }.orEmpty(),
}.getOrNull().orEmpty(),
state = when (status) { state = when (status) {
"выпускаецца" -> MangaState.ONGOING "выпускаецца" -> MangaState.ONGOING
"завершанае" -> MangaState.FINISHED "завершанае" -> MangaState.FINISHED

Loading…
Cancel
Save