update Bacakomik (#5014)

* update ext version

* fix image issue

* add chapter timestamp

* fix manga details issue
This commit is contained in:
Riztard Lanthorn 2020-12-04 19:50:17 +07:00 committed by GitHub
parent 4e08f4a5b7
commit 7d826f2c46
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 66 additions and 14 deletions

View File

@ -5,7 +5,7 @@ ext {
extName = 'Bacakomik' extName = 'Bacakomik'
pkgNameSuffix = 'id.bacakomik' pkgNameSuffix = 'id.bacakomik'
extClass = '.Bacakomik' extClass = '.Bacakomik'
extVersionCode = 1 extVersionCode = 2
libVersion = '1.2' libVersion = '1.2'
} }

View File

@ -13,6 +13,9 @@ import okhttp3.OkHttpClient
import okhttp3.Request import okhttp3.Request
import org.jsoup.nodes.Document import org.jsoup.nodes.Document
import org.jsoup.nodes.Element import org.jsoup.nodes.Element
import java.text.SimpleDateFormat
import java.util.Calendar
import java.util.Locale
class Bacakomik : ParsedHttpSource() { class Bacakomik : ParsedHttpSource() {
override val name = "Bacakomik" override val name = "Bacakomik"
@ -20,6 +23,7 @@ class Bacakomik : ParsedHttpSource() {
override val lang = "id" override val lang = "id"
override val supportsLatest = true override val supportsLatest = true
override val client: OkHttpClient = network.cloudflareClient override val client: OkHttpClient = network.cloudflareClient
private val dateFormat: SimpleDateFormat = SimpleDateFormat("MMM d, yyyy", Locale.US)
override fun popularMangaRequest(page: Int): Request { override fun popularMangaRequest(page: Int): Request {
return GET("$baseUrl/daftar-manga/page/$page/?order=popular", headers) return GET("$baseUrl/daftar-manga/page/$page/?order=popular", headers)
@ -91,8 +95,10 @@ class Bacakomik : ParsedHttpSource() {
val descElement = document.select("div.desc > .entry-content.entry-content-single").first() val descElement = document.select("div.desc > .entry-content.entry-content-single").first()
val sepName = infoElement.select(".infox > .spe > span:nth-child(2)").last() val sepName = infoElement.select(".infox > .spe > span:nth-child(2)").last()
val manga = SManga.create() val manga = SManga.create()
manga.author = sepName.ownText() //need authorCleaner to take "pengarang:" string to remove it from author
manga.artist = sepName.ownText() val authorCleaner = document.select(".infox .spe b:contains(Pengarang)").text()
manga.author = document.select(".infox .spe span:contains(Pengarang)").text().substringAfter(authorCleaner)
manga.artist = manga.author
val genres = mutableListOf<String>() val genres = mutableListOf<String>()
infoElement.select(".infox > .genre-info > a").forEach { element -> infoElement.select(".infox > .genre-info > a").forEach { element ->
val genre = element.text() val genre = element.text()
@ -106,22 +112,60 @@ class Bacakomik : ParsedHttpSource() {
} }
private fun parseStatus(element: String): Int = when { private fun parseStatus(element: String): Int = when {
element.toLowerCase().contains("ongoing") -> SManga.ONGOING element.toLowerCase().contains("berjalan") -> SManga.ONGOING
element.toLowerCase().contains("completed") -> SManga.COMPLETED element.toLowerCase().contains("tamat") -> SManga.COMPLETED
else -> SManga.UNKNOWN else -> SManga.UNKNOWN
} }
override fun chapterListSelector() = ".lchx" override fun chapterListSelector() = "#chapter_list li"
override fun chapterFromElement(element: Element): SChapter { override fun chapterFromElement(element: Element): SChapter {
val urlElement = element.select("a").first() val urlElement = element.select(".lchx a").first()
val chapter = SChapter.create() val chapter = SChapter.create()
chapter.setUrlWithoutDomain(urlElement.attr("href")) chapter.setUrlWithoutDomain(urlElement.attr("href"))
chapter.name = urlElement.text() chapter.name = urlElement.text()
chapter.date_upload = 0 chapter.date_upload = element.select(".dt a").first()?.text()?.let { parseChapterDate(it) } ?: 0
return chapter return chapter
} }
fun parseChapterDate(date: String): Long {
return if (date.contains("yang lalu")) {
val value = date.split(' ')[0].toInt()
when {
"detik" in date -> Calendar.getInstance().apply {
add(Calendar.SECOND, value * -1)
}.timeInMillis
"menit" in date -> Calendar.getInstance().apply {
add(Calendar.MINUTE, value * -1)
}.timeInMillis
"jam" in date -> Calendar.getInstance().apply {
add(Calendar.HOUR_OF_DAY, value * -1)
}.timeInMillis
"hari" in date -> Calendar.getInstance().apply {
add(Calendar.DATE, value * -1)
}.timeInMillis
"minggu" in date -> Calendar.getInstance().apply {
add(Calendar.DATE, value * 7 * -1)
}.timeInMillis
"bulan" in date -> Calendar.getInstance().apply {
add(Calendar.MONTH, value * -1)
}.timeInMillis
"tahun" in date -> Calendar.getInstance().apply {
add(Calendar.YEAR, value * -1)
}.timeInMillis
else -> {
0L
}
}
} else {
try {
dateFormat.parse(date)?.time ?: 0
} catch (_: Exception) {
0L
}
}
}
override fun prepareNewChapter(chapter: SChapter, manga: SManga) { override fun prepareNewChapter(chapter: SChapter, manga: SManga) {
val basic = Regex("""Chapter\s([0-9]+)""") val basic = Regex("""Chapter\s([0-9]+)""")
when { when {
@ -136,7 +180,7 @@ class Bacakomik : ParsedHttpSource() {
override fun pageListParse(document: Document): List<Page> { override fun pageListParse(document: Document): List<Page> {
val pages = mutableListOf<Page>() val pages = mutableListOf<Page>()
var i = 0 var i = 0
document.select("div#chimg img").forEach { element -> document.select("div#chimg noscript img").forEach { element ->
val url = element.attr("src") val url = element.attr("src")
i++ i++
if (url.isNotEmpty()) { if (url.isNotEmpty()) {
@ -149,12 +193,20 @@ class Bacakomik : ParsedHttpSource() {
override fun imageUrlParse(document: Document) = "" override fun imageUrlParse(document: Document) = ""
override fun imageRequest(page: Page): Request { override fun imageRequest(page: Page): Request {
if (page.imageUrl!!.contains("i2.wp.com")) {
val headers = Headers.Builder()
headers.apply {
add("Accept", "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3")
}
return GET(page.imageUrl!!, headers.build())
} else {
val imgHeader = Headers.Builder().apply { val imgHeader = Headers.Builder().apply {
add("User-Agent", "Mozilla/5.0 (Linux; U; Android 4.1.1; en-gb; Build/KLP) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Safari/534.30") add("User-Agent", "Mozilla/5.0 (Linux; U; Android 4.1.1; en-gb; Build/KLP) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Safari/534.30")
add("Referer", baseUrl) add("Referer", baseUrl)
}.build() }.build()
return GET(page.imageUrl!!, imgHeader) return GET(page.imageUrl!!, imgHeader)
} }
}
private class AuthorFilter : Filter.Text("Author") private class AuthorFilter : Filter.Text("Author")