MangaRawTheme: allow missing titles. Remove mangaraw.ru (#17399)

* MangaRawTheme: allow missing titles

* nsfw
This commit is contained in:
Vetle Ledaal 2023-08-06 16:09:31 +00:00 committed by GitHub
parent 6b5545e778
commit f2367aa484
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 8 additions and 77 deletions

View File

@ -1,73 +0,0 @@
package eu.kanade.tachiyomi.extension.ja.mangarawru
import eu.kanade.tachiyomi.multisrc.mangaraw.ImageListParser
import eu.kanade.tachiyomi.multisrc.mangaraw.MangaRawTheme
import eu.kanade.tachiyomi.network.GET
import eu.kanade.tachiyomi.source.model.FilterList
import eu.kanade.tachiyomi.source.model.Page
import eu.kanade.tachiyomi.source.model.SManga
import okhttp3.Request
import org.jsoup.nodes.Document
import org.jsoup.nodes.Element
import org.jsoup.select.Evaluator
class MangaRawRU : MangaRawTheme("MangaRawRU", "https://mangaraw.ru") {
override fun popularMangaRequest(page: Int): Request = latestUpdatesRequest(page)
override val supportsLatest = false
override fun String.sanitizeTitle(): String {
val index = lastIndexOf("Raw", ignoreCase = true)
if (index == -1) return this
return substring(0, index)
.trimEnd('(', ' ', ',')
}
override fun popularMangaSelector() = "#list_videos_videos_items:nth-child(2) .thumb.item>a"
override fun popularMangaFromElement(element: Element) = SManga.create().apply {
setUrlWithoutDomain(element.attr("href"))
title = element.select("h3").text().sanitizeTitle()
thumbnail_url = element.select("img").attr("abs:src")
}
override fun popularMangaNextPageSelector() = ".pagination__link"
override fun searchMangaRequest(page: Int, query: String, filters: FilterList) =
GET("$baseUrl/?s=$query&page=$page")
override fun searchMangaFromElement(element: Element) = popularMangaFromElement(element)
override fun searchMangaSelector(): String = ".thumb.item>a"
override fun mangaDetailsParse(document: Document): SManga {
val manga = SManga.create()
manga.title = document.select("h1").text().sanitizeTitle()
manga.description = document.select(".video-info__box.b-content strong").text()
manga.thumbnail_url = document.select(".player-holder img").attr("abs:src")
val genres = document.select(".category")
.map { element -> element.text() }
.toMutableSet()
manga.genre = genres.toList().joinToString(", ")
return manga
}
override fun Document.getSanitizedDetails(): Element = this
override fun chapterListSelector() = ".chapter-l a"
override fun String.sanitizeChapter() = substringAfterLast(" ").substringBeforeLast("漫画")
override fun pageSelector(): Evaluator {
return Evaluator.Tag("img")
}
override fun pageListParse(document: Document): List<Page> {
val position = 32
val parser = ImageListParser(document.html(), position)
return parser.getImageList().orEmpty().mapIndexed { i, imageUrl ->
Page(i, imageUrl = imageUrl)
}
}
}

View File

@ -8,12 +8,11 @@ class MangaRawGenerator : ThemeSourceGenerator {
override val themePkg = "mangaraw"
override val baseVersionCode = 4
override val baseVersionCode = 5
override val sources = listOf(
SingleLang("SyoSetu", "https://syosetu.top", "ja"),
SingleLang("MangaRaw", "https://manga1001.in", "ja", pkgName = "manga9co", overrideVersionCode = 2),
SingleLang("MangaRawRU", "https://mangaraw.ru", "ja", overrideVersionCode = 1),
SingleLang("MangaRaw", "https://manga1001.in", "ja", pkgName = "manga9co", isNsfw = true, overrideVersionCode = 2),
)
companion object {

View File

@ -5,6 +5,7 @@ import eu.kanade.tachiyomi.source.model.Page
import eu.kanade.tachiyomi.source.model.SChapter
import eu.kanade.tachiyomi.source.model.SManga
import eu.kanade.tachiyomi.source.online.ParsedHttpSource
import okhttp3.HttpUrl.Companion.toHttpUrl
import org.jsoup.nodes.Document
import org.jsoup.nodes.Element
import org.jsoup.select.Evaluator
@ -23,7 +24,11 @@ abstract class MangaRawTheme(
override fun popularMangaFromElement(element: Element) = SManga.create().apply {
setUrlWithoutDomain(element.selectFirst(Evaluator.Tag("a"))!!.attr("href"))
title = element.selectFirst(Evaluator.Tag("h3"))!!.text().sanitizeTitle()
// Title could be missing. Uses URL as a last effort, ex: okaeri-alice-raw
title = element.selectFirst(Evaluator.Tag("h3"))?.text()?.sanitizeTitle()
?: (baseUrl + url).toHttpUrl().pathSegments.first()
thumbnail_url = element.selectFirst(Evaluator.Tag("img"))?.absUrl("data-src")
}