diff --git a/src/en/mangareader/AndroidManifest.xml b/src/en/mangareader/AndroidManifest.xml
deleted file mode 100644
index 30deb7f79..000000000
--- a/src/en/mangareader/AndroidManifest.xml
+++ /dev/null
@@ -1,2 +0,0 @@
-
-
diff --git a/src/en/mangareader/build.gradle b/src/en/mangareader/build.gradle
deleted file mode 100644
index f27b001ab..000000000
--- a/src/en/mangareader/build.gradle
+++ /dev/null
@@ -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"
diff --git a/src/en/mangareader/res/mipmap-hdpi/ic_launcher.png b/src/en/mangareader/res/mipmap-hdpi/ic_launcher.png
deleted file mode 100644
index 69ab2f53f..000000000
Binary files a/src/en/mangareader/res/mipmap-hdpi/ic_launcher.png and /dev/null differ
diff --git a/src/en/mangareader/res/mipmap-mdpi/ic_launcher.png b/src/en/mangareader/res/mipmap-mdpi/ic_launcher.png
deleted file mode 100644
index 92caec884..000000000
Binary files a/src/en/mangareader/res/mipmap-mdpi/ic_launcher.png and /dev/null differ
diff --git a/src/en/mangareader/res/mipmap-xhdpi/ic_launcher.png b/src/en/mangareader/res/mipmap-xhdpi/ic_launcher.png
deleted file mode 100644
index 0a253034b..000000000
Binary files a/src/en/mangareader/res/mipmap-xhdpi/ic_launcher.png and /dev/null differ
diff --git a/src/en/mangareader/res/mipmap-xxhdpi/ic_launcher.png b/src/en/mangareader/res/mipmap-xxhdpi/ic_launcher.png
deleted file mode 100644
index a925b50b8..000000000
Binary files a/src/en/mangareader/res/mipmap-xxhdpi/ic_launcher.png and /dev/null differ
diff --git a/src/en/mangareader/res/mipmap-xxxhdpi/ic_launcher.png b/src/en/mangareader/res/mipmap-xxxhdpi/ic_launcher.png
deleted file mode 100644
index 98bfd8127..000000000
Binary files a/src/en/mangareader/res/mipmap-xxxhdpi/ic_launcher.png and /dev/null differ
diff --git a/src/en/mangareader/res/web_hi_res_512.png b/src/en/mangareader/res/web_hi_res_512.png
deleted file mode 100644
index 070a62ca4..000000000
Binary files a/src/en/mangareader/res/web_hi_res_512.png and /dev/null differ
diff --git a/src/en/mangareader/src/eu/kanade/tachiyomi/extension/en/mangareader/MRP.kt b/src/en/mangareader/src/eu/kanade/tachiyomi/extension/en/mangareader/MRP.kt
deleted file mode 100644
index 683ae054a..000000000
--- a/src/en/mangareader/src/eu/kanade/tachiyomi/extension/en/mangareader/MRP.kt
+++ /dev/null
@@ -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 {
- 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 {
- val pages = mutableListOf()
-
- 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")
- }
-}
diff --git a/src/en/mangareader/src/eu/kanade/tachiyomi/extension/en/mangareader/MRPFactory.kt b/src/en/mangareader/src/eu/kanade/tachiyomi/extension/en/mangareader/MRPFactory.kt
deleted file mode 100644
index 7e011f738..000000000
--- a/src/en/mangareader/src/eu/kanade/tachiyomi/extension/en/mangareader/MRPFactory.kt
+++ /dev/null
@@ -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 = 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 {
- val script = document.select("script:containsData(document[)").firstOrNull()?.data() ?: throw Exception("script not found")
- return gson.fromJson(script.substringAfterLast("="))["im"].asJsonArray.mapIndexed { i, json ->
- Page(i, "", "https:" + json["u"].string)
- }
- }
-}
-class Mangapanda : MRP("Mangapanda", "http://www.mangapanda.com")