[DamCoNuong] Fixes

master
Koitharu 1 year ago
parent 5fa7590550
commit 2175e91db7
Signed by: Koitharu
GPG Key ID: 676DEE768C17A9D7

@ -4,18 +4,23 @@ import org.jsoup.nodes.Document
import org.koitharu.kotatsu.parsers.MangaLoaderContext import org.koitharu.kotatsu.parsers.MangaLoaderContext
import org.koitharu.kotatsu.parsers.MangaSourceParser import org.koitharu.kotatsu.parsers.MangaSourceParser
import org.koitharu.kotatsu.parsers.config.ConfigKey import org.koitharu.kotatsu.parsers.config.ConfigKey
import org.koitharu.kotatsu.parsers.exception.ParseException
import org.koitharu.kotatsu.parsers.core.LegacyPagedMangaParser import org.koitharu.kotatsu.parsers.core.LegacyPagedMangaParser
import org.koitharu.kotatsu.parsers.exception.ParseException
import org.koitharu.kotatsu.parsers.model.* import org.koitharu.kotatsu.parsers.model.*
import org.koitharu.kotatsu.parsers.util.* import org.koitharu.kotatsu.parsers.util.*
import org.koitharu.kotatsu.parsers.util.suspendlazy.getOrNull
import org.koitharu.kotatsu.parsers.util.suspendlazy.suspendLazy
import java.text.SimpleDateFormat import java.text.SimpleDateFormat
import java.util.* import java.util.*
@MangaSourceParser("DAMCONUONG", "Dâm Cô Nương", "vi", type = ContentType.HENTAI) @MangaSourceParser("DAMCONUONG", "Dâm Cô Nương", "vi", type = ContentType.HENTAI)
internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(context, MangaParserSource.DAMCONUONG, 30) { internal class DamCoNuong(context: MangaLoaderContext) :
LegacyPagedMangaParser(context, MangaParserSource.DAMCONUONG, 30) {
override val configKeyDomain = ConfigKey.Domain("damconuong.fit") override val configKeyDomain = ConfigKey.Domain("damconuong.fit")
private val availableTags = suspendLazy(initializer = ::fetchTags)
override fun onCreateConfig(keys: MutableCollection<ConfigKey<*>>) { override fun onCreateConfig(keys: MutableCollection<ConfigKey<*>>) {
super.onCreateConfig(keys) super.onCreateConfig(keys)
keys.add(userAgentKey) keys.add(userAgentKey)
@ -38,7 +43,7 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
) )
override suspend fun getFilterOptions() = MangaListFilterOptions( override suspend fun getFilterOptions() = MangaListFilterOptions(
availableTags = fetchTags(), availableTags = availableTags.get(),
availableStates = EnumSet.of(MangaState.ONGOING, MangaState.FINISHED), availableStates = EnumSet.of(MangaState.ONGOING, MangaState.FINISHED),
) )
@ -57,10 +62,10 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
SortOrder.ALPHABETICAL -> "name" SortOrder.ALPHABETICAL -> "name"
SortOrder.ALPHABETICAL_DESC -> "-name" SortOrder.ALPHABETICAL_DESC -> "-name"
else -> "-updated_at" else -> "-updated_at"
} },
) )
if (filter.states.isNotEmpty()) { if (filter.states.isNotEmpty()) {
append("&filter[status]=") append("&filter[status]=")
filter.states.forEach { filter.states.forEach {
append( append(
@ -91,41 +96,40 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
} }
private suspend fun parseMangaList(doc: Document): List<Manga> { private suspend fun parseMangaList(doc: Document): List<Manga> {
return doc.select("div.border.rounded-lg.border-gray-300.dark\\:border-dark-blue.bg-white.dark\\:bg-fire-blue.manga-vertical").map { element -> return doc.select("div.border.rounded-lg.border-gray-300.dark\\:border-dark-blue.bg-white.dark\\:bg-fire-blue.manga-vertical")
val mainA = element.selectFirst("div.relative a") .map { element ->
val href = mainA?.attr("href") ?: "" val mainA = element.selectFirstOrThrow("div.relative a")
val title = element.selectFirst("div.latest-chapter a.text-white.capitalize").text() ?: "No name" val href = mainA.attrAsRelativeUrl("href")
val coverUrl = element.selectFirst("img.rounded-t-lg.cover.lazyload")?.attr("data-src") ?: "" val title = element.selectFirst("div.latest-chapter a.text-white.capitalize")?.textOrNull() ?: "No name"
val coverUrl = element.selectFirst("img.rounded-t-lg.cover.lazyload")?.src()
Manga(
id = generateUid(href), Manga(
title = title, id = generateUid(href),
altTitles = emptySet(), title = title,
url = href, altTitles = emptySet(),
publicUrl = href.toAbsoluteUrl(domain), url = href,
rating = RATING_UNKNOWN, publicUrl = href.toAbsoluteUrl(domain),
contentRating = ContentRating.ADULT, rating = RATING_UNKNOWN,
coverUrl = coverUrl, contentRating = ContentRating.ADULT,
tags = emptySet(), coverUrl = coverUrl,
state = null, tags = emptySet(),
authors = emptySet(), state = null,
source = source, authors = emptySet(),
) source = source,
} )
}
} }
override suspend fun getDetails(manga: Manga): Manga { override suspend fun getDetails(manga: Manga): Manga {
val url = manga.url.toAbsoluteUrl(domain) val url = manga.url.toAbsoluteUrl(domain)
val doc = webClient.httpGet(url).parseHtml() val doc = webClient.httpGet(url).parseHtml()
val altTitles = doc.select("div.mt-2:contains(Tên khác:) span").map { it.text() }.toSet().orEmpty() val altTitles = doc.select("div.mt-2:contains(Tên khác:) span").mapNotNullToSet { it.textOrNull() }
val tags = doc.select("div.mt-2:contains(Thể loại:) a").map { a -> val allTags = availableTags.getOrNull().orEmpty()
MangaTag( val tags = doc.select("div.mt-2:contains(Thể loại:) a").mapToSet { a ->
key = "", // Auto-detected by title, idk val title = a.text().toTitleCase()
title = a.text(), allTags.find { x -> x.title == title }
source = source, }
)
}.toSet()
val stateText = doc.selectFirst("div.mt-2:contains(Tình trạng:) span")?.text() val stateText = doc.selectFirst("div.mt-2:contains(Tình trạng:) span")?.text()
val state = when (stateText) { val state = when (stateText) {
@ -133,19 +137,20 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
else -> MangaState.FINISHED else -> MangaState.FINISHED
} }
val chapterListDiv = doc.selectFirst("div#chapterList.justify-between.border-2.border-gray-100.dark\\:border-dark-blue.p-3.bg-white.dark\\:bg-fire-blue.shadow-md.rounded.dark\\:shadow-gray-900.mb-4") val chapterListDiv =
?: throw ParseException("Chapters list not found!", url) doc.selectFirst("div#chapterList.justify-between.border-2.border-gray-100.dark\\:border-dark-blue.p-3.bg-white.dark\\:bg-fire-blue.shadow-md.rounded.dark\\:shadow-gray-900.mb-4")
?: throw ParseException("Chapters list not found!", url)
val chapterLinks = chapterListDiv.select("a.block") val chapterLinks = chapterListDiv.select("a.block")
val chapters = chapterLinks.mapIndexed { index, a -> val chapters = chapterLinks.mapChapters(reversed = true) { index, a ->
val title = a.selectFirst("span.text-ellipsis")?.text().orEmpty() val title = a.selectFirst("span.text-ellipsis")?.textOrNull()
val href = a.attr("href") val href = a.attrAsRelativeUrl("href")
val uploadDate = a.selectFirst("span.ml-2.whitespace-nowrap")?.text().orEmpty() val uploadDate = a.selectFirst("span.ml-2.whitespace-nowrap")?.text()
MangaChapter( MangaChapter(
id = generateUid(href), id = generateUid(href),
title = title, title = title,
number = (chapterLinks.size - index).toFloat(), number = index + 1f,
volume = 0, volume = 0,
url = href, url = href,
scanlator = null, scanlator = null,
@ -153,7 +158,7 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
branch = null, branch = null,
source = source, source = source,
) )
}.reversed() }
return manga.copy( return manga.copy(
altTitles = altTitles, altTitles = altTitles,
@ -163,9 +168,9 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
) )
} }
override suspend fun getPages(chapter: MangaChapter): List<MangaPage> { override suspend fun getPages(chapter: MangaChapter): List<MangaPage> {
val doc = webClient.httpGet(chapter.url.toAbsoluteUrl(domain)).parseHtml() val doc = webClient.httpGet(chapter.url.toAbsoluteUrl(domain)).parseHtml()
return doc.select("div.text-center img.max-w-full.my-0.mx-auto").mapNotNull { img -> return doc.select("div.text-center img.max-w-full.my-0.mx-auto").map { img ->
val url = img.requireSrc() val url = img.requireSrc()
MangaPage( MangaPage(
id = generateUid(url), id = generateUid(url),
@ -176,7 +181,7 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
} }
} }
private fun parseChapterDate(date: String?): Long { private fun parseChapterDate(date: String?): Long {
if (date == null) return 0 if (date == null) return 0
return when { return when {
date.contains("giây trước") -> System.currentTimeMillis() - date.removeSuffix(" giây trước").toLong() * 1000 date.contains("giây trước") -> System.currentTimeMillis() - date.removeSuffix(" giây trước").toLong() * 1000
@ -204,21 +209,17 @@ internal class DamCoNuong(context: MangaLoaderContext) : LegacyPagedMangaParser(
private suspend fun fetchTags(): Set<MangaTag> { private suspend fun fetchTags(): Set<MangaTag> {
val doc = webClient.httpGet("https://$domain/tim-kiem").parseHtml() val doc = webClient.httpGet("https://$domain/tim-kiem").parseHtml()
return doc.select("label.ml-3.inline-flex.items-center.cursor-pointer.select-none").map { label -> val regex = Regex("toggleGenre\\('([0-9]+)'\\)")
val key = label.attr("@click").substringAfter("toggleGenre('").substringBefore("')").trim() return doc.body().getElementsByAttribute("@click")
// val key = getKeyTags(rawKey) .mapNotNullToSet { label ->
val title = label.selectFirst("span.ml-2.text-sm.font-semibold.text-blueGray-600.text-ellipsis")?.text() ?: "" // @click="toggleGenre('1')"
MangaTag( val attr = label.attr("@click")
key = key, val number = attr.findGroupValue(regex) ?: return@mapNotNullToSet null
title = title, MangaTag(
source = source, key = number,
) title = label.textOrNull()?.toTitleCase(sourceLocale) ?: return@mapNotNullToSet null,
}.toSet() source = source,
)
}
} }
// Fix tags, if its necessary!
// private fun getKeyTags(rawKey: String): String {
// val number = rawKey.trim().replace(Regex("[^0-9]"), "")
// return (number.toIntOrNull()?.plus(1) ?: 0).toString()
// }
} }

Loading…
Cancel
Save