Deleting MangaReader and MangaPanda (#6391)

This commit is contained in:
Johannes Joens 2021-04-03 01:47:18 +13:00 committed by GitHub
parent be56320d79
commit 8c07a08a9f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 0 additions and 225 deletions

View File

@ -1,2 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest package="eu.kanade.tachiyomi.extension" />

View File

@ -1,12 +0,0 @@
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
ext {
extName = 'Mangareader & Mangapanda'
pkgNameSuffix = 'en.mangareader'
extClass = '.MRPFactory'
extVersionCode = 7
libVersion = '1.2'
}
apply from: "$rootDir/common.gradle"

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 13 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 62 KiB

View File

@ -1,151 +0,0 @@
package eu.kanade.tachiyomi.extension.en.mangareader
import eu.kanade.tachiyomi.network.GET
import eu.kanade.tachiyomi.source.model.FilterList
import eu.kanade.tachiyomi.source.model.MangasPage
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 eu.kanade.tachiyomi.util.asJsoup
import okhttp3.OkHttpClient
import okhttp3.Request
import okhttp3.Response
import org.jsoup.nodes.Document
import org.jsoup.nodes.Element
import java.text.SimpleDateFormat
import java.util.Locale
abstract class MRP(
override val name: String,
override val baseUrl: String
) : ParsedHttpSource() {
override val lang = "en"
override val supportsLatest = true
override val client: OkHttpClient = network.cloudflareClient
override fun popularMangaRequest(page: Int): Request {
return GET("$baseUrl/popular" + if (page > 1) "/${(page - 1) * 30}" else "", headers)
}
override fun popularMangaSelector() = "div.mangaresultitem"
override fun popularMangaFromElement(element: Element): SManga {
val manga = SManga.create()
element.select("h3 a").first().let {
manga.url = it.attr("href")
manga.title = it.ownText()
}
manga.thumbnail_url = element.select("div.imgsearchresults").first().toString().substringAfter("url('").substringBefore("')\">")
return manga
}
override fun popularMangaNextPageSelector() = "div#sp strong + a"
private var nextLatestPage: String? = null
override fun latestUpdatesRequest(page: Int): Request {
return if (page == 1) {
nextLatestPage = null
GET("$baseUrl/latest", headers)
} else {
GET(nextLatestPage!!, headers)
}
}
override fun latestUpdatesParse(response: Response): MangasPage {
val document = response.asJsoup()
val mangas = document.select(latestUpdatesSelector()).map { latestUpdatesFromElement(it) }
nextLatestPage = document.select(latestUpdatesNextPageSelector()).firstOrNull()?.attr("abs:href")
return MangasPage(mangas, nextLatestPage != null)
}
override fun latestUpdatesSelector() = "tr.c3"
override fun latestUpdatesFromElement(element: Element): SManga {
val manga = SManga.create()
element.select("a.chapter").first().let {
manga.url = it.attr("href")
manga.title = it.text()
}
return manga
}
override fun latestUpdatesNextPageSelector() = popularMangaNextPageSelector()
override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request {
return GET("$baseUrl/search/?w=$query" + if (page > 1) "&p=${(page - 1) * 30}" else "", headers)
}
override fun searchMangaSelector() = popularMangaSelector()
override fun searchMangaFromElement(element: Element) = popularMangaFromElement(element)
override fun searchMangaNextPageSelector() = popularMangaNextPageSelector()
override fun mangaDetailsParse(document: Document): SManga {
val infoElement = document.select("div#mangaproperties")
val manga = SManga.create()
manga.title = infoElement.select("h1").text()
manga.author = infoElement.select("td.propertytitle:containsOwn(author) + td").text()
manga.artist = infoElement.select("td.propertytitle:containsOwn(artist) + td").text()
val status = infoElement.select("td.propertytitle:containsOwn(status) + td").text()
manga.status = parseStatus(status)
manga.genre = infoElement.select("td.propertytitle:containsOwn(genre) + td a").joinToString { it.text() }
manga.description = document.select("div#readmangasum p").text()
manga.thumbnail_url = document.select("img").attr("src")
return manga
}
protected fun parseStatus(status: String?) = when {
status == null -> SManga.UNKNOWN
status.contains("Ongoing") -> SManga.ONGOING
status.contains("Completed") -> SManga.COMPLETED
else -> SManga.UNKNOWN
}
// Site orders chapters oldest to newest, reverse that to be in line with most other sources
override fun chapterListParse(response: Response): List<SChapter> {
return super.chapterListParse(response).reversed()
}
override fun chapterListSelector() = "table#listing tr:not(.table_head)"
override fun chapterFromElement(element: Element): SChapter {
val chapter = SChapter.create()
element.select("a").let {
chapter.setUrlWithoutDomain(it.attr("href"))
chapter.name = it.text()
}
chapter.date_upload = parseDate(element.select("td + td").text())
return chapter
}
private fun parseDate(date: String): Long {
return SimpleDateFormat("MM/dd/yyyy", Locale.US).parse(date)?.time ?: 0
}
override fun pageListParse(document: Document): List<Page> {
val pages = mutableListOf<Page>()
val chapterUrl = document.select("select#pageMenu option").attr("value") + "/"
document.select("select#pageMenu").text().split(" ").forEach {
pages.add(Page(pages.size, "$chapterUrl$it"))
}
return pages
}
// Get the page
override fun imageUrlRequest(page: Page) = GET(baseUrl + page.url)
// Get the image from the requested page
override fun imageUrlParse(document: Document): String {
return document.select("a img").attr("abs:src")
}
}

View File

@ -1,60 +0,0 @@
package eu.kanade.tachiyomi.extension.en.mangareader
import com.github.salomonbrys.kotson.fromJson
import com.github.salomonbrys.kotson.get
import com.github.salomonbrys.kotson.string
import com.google.gson.Gson
import com.google.gson.JsonObject
import eu.kanade.tachiyomi.source.Source
import eu.kanade.tachiyomi.source.SourceFactory
import eu.kanade.tachiyomi.source.model.Page
import eu.kanade.tachiyomi.source.model.SManga
import org.jsoup.nodes.Document
import org.jsoup.nodes.Element
class MRPFactory : SourceFactory {
override fun createSources(): List<Source> = listOf(
Mangareader(),
Mangapanda()
)
}
class Mangareader : MRP("Mangareader", "https://www.mangareader.net") {
override fun popularMangaSelector() = "div > div > table"
override fun popularMangaFromElement(element: Element): SManga {
return SManga.create().apply {
element.select("a").let {
setUrlWithoutDomain(it.attr("href"))
title = it.text()
}
thumbnail_url = element.select("div[data-src]").attr("abs:data-src")
}
}
override fun popularMangaNextPageSelector() = "li:has(.pcur) + li a"
override fun latestUpdatesSelector() = "div:has(i) + div div > a"
override fun latestUpdatesFromElement(element: Element): SManga {
return SManga.create().apply {
setUrlWithoutDomain(element.attr("href"))
title = element.text()
}
}
override fun mangaDetailsParse(document: Document): SManga {
return SManga.create().apply {
thumbnail_url = document.select("div > img[alt]").attr("abs:src")
status = parseStatus(document.select("div > table tr td:contains(Status:) + td").text())
author = document.select("div > table tr td:contains(Author:) + td").text()
artist = document.select("div > table tr td:contains(Artist:) + td").text()
genre = document.select("div > table tr td:contains(Genre:) + td").joinToString { it.text() }
description = document.select("div > div + p").text()
}
}
override fun chapterListSelector() = "tr:has(i)"
private val gson by lazy { Gson() }
override fun pageListParse(document: Document): List<Page> {
val script = document.select("script:containsData(document[)").firstOrNull()?.data() ?: throw Exception("script not found")
return gson.fromJson<JsonObject>(script.substringAfterLast("="))["im"].asJsonArray.mapIndexed { i, json ->
Page(i, "", "https:" + json["u"].string)
}
}
}
class Mangapanda : MRP("Mangapanda", "http://www.mangapanda.com")