diff --git a/src/pt/zinnes/AndroidManifest.xml b/src/pt/zinnes/AndroidManifest.xml deleted file mode 100644 index 30deb7f79..000000000 --- a/src/pt/zinnes/AndroidManifest.xml +++ /dev/null @@ -1,2 +0,0 @@ - - diff --git a/src/pt/zinnes/build.gradle b/src/pt/zinnes/build.gradle deleted file mode 100644 index ca5da6c44..000000000 --- a/src/pt/zinnes/build.gradle +++ /dev/null @@ -1,16 +0,0 @@ -apply plugin: 'com.android.application' -apply plugin: 'kotlin-android' - -ext { - extName = 'Zinnes' - pkgNameSuffix = 'pt.zinnes' - extClass = '.Zinnes' - extVersionCode = 3 - libVersion = '1.2' -} - -dependencies { - implementation project(':lib-ratelimit') -} - -apply from: "$rootDir/common.gradle" diff --git a/src/pt/zinnes/res/mipmap-hdpi/ic_launcher.png b/src/pt/zinnes/res/mipmap-hdpi/ic_launcher.png deleted file mode 100644 index cf72d4e33..000000000 Binary files a/src/pt/zinnes/res/mipmap-hdpi/ic_launcher.png and /dev/null differ diff --git a/src/pt/zinnes/res/mipmap-mdpi/ic_launcher.png b/src/pt/zinnes/res/mipmap-mdpi/ic_launcher.png deleted file mode 100644 index afb56bbfd..000000000 Binary files a/src/pt/zinnes/res/mipmap-mdpi/ic_launcher.png and /dev/null differ diff --git a/src/pt/zinnes/res/mipmap-xhdpi/ic_launcher.png b/src/pt/zinnes/res/mipmap-xhdpi/ic_launcher.png deleted file mode 100644 index b2fdeeef2..000000000 Binary files a/src/pt/zinnes/res/mipmap-xhdpi/ic_launcher.png and /dev/null differ diff --git a/src/pt/zinnes/res/mipmap-xxhdpi/ic_launcher.png b/src/pt/zinnes/res/mipmap-xxhdpi/ic_launcher.png deleted file mode 100644 index 608b5749a..000000000 Binary files a/src/pt/zinnes/res/mipmap-xxhdpi/ic_launcher.png and /dev/null differ diff --git a/src/pt/zinnes/res/mipmap-xxxhdpi/ic_launcher.png b/src/pt/zinnes/res/mipmap-xxxhdpi/ic_launcher.png deleted file mode 100644 index d48c59da9..000000000 Binary files a/src/pt/zinnes/res/mipmap-xxxhdpi/ic_launcher.png and /dev/null differ diff --git a/src/pt/zinnes/res/web_hi_res_512.png b/src/pt/zinnes/res/web_hi_res_512.png deleted file mode 100644 index 08cfd0611..000000000 Binary files a/src/pt/zinnes/res/web_hi_res_512.png and /dev/null differ diff --git a/src/pt/zinnes/src/eu/kanade/tachiyomi/extension/pt/zinnes/Zinnes.kt b/src/pt/zinnes/src/eu/kanade/tachiyomi/extension/pt/zinnes/Zinnes.kt deleted file mode 100644 index fdc0b4318..000000000 --- a/src/pt/zinnes/src/eu/kanade/tachiyomi/extension/pt/zinnes/Zinnes.kt +++ /dev/null @@ -1,155 +0,0 @@ -package eu.kanade.tachiyomi.extension.pt.zinnes - -import eu.kanade.tachiyomi.lib.ratelimit.RateLimitInterceptor -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.Headers -import okhttp3.HttpUrl -import okhttp3.OkHttpClient -import okhttp3.Request -import okhttp3.Response -import org.jsoup.nodes.Document -import org.jsoup.nodes.Element -import java.text.ParseException -import java.text.SimpleDateFormat -import java.util.Locale -import java.util.concurrent.TimeUnit - -class Zinnes : ParsedHttpSource() { - - // Hardcode the id because the language wasn't specific. - override val id: Long = 568551799323473384 - - override val name = "Zinnes" - - override val baseUrl = "https://www.zinnes.com.br" - - override val lang = "pt-BR" - - override val supportsLatest = false - - override val client: OkHttpClient = network.client.newBuilder() - .addInterceptor(RateLimitInterceptor(1, 1, TimeUnit.SECONDS)) - .build() - - override fun headersBuilder(): Headers.Builder = Headers.Builder() - .add("User-Agent", USER_AGENT) - .add("Referer", baseUrl) - .add("Origin", baseUrl) - - override fun popularMangaRequest(page: Int): Request = GET(baseUrl, headers) - - override fun popularMangaSelector(): String = "section#top > ul > li > a" - - override fun popularMangaFromElement(element: Element): SManga = SManga.create().apply { - val label = element.select("div.label") - - title = label.select("h3.titulo").text() - thumbnail_url = baseUrl + "/" + element.select("img").first().attr("data-temp") - setUrlWithoutDomain(baseUrl + element.attr("href")) - } - - override fun popularMangaNextPageSelector(): String? = null - - override fun latestUpdatesNextPageSelector(): String? = null - - override fun searchMangaParse(response: Response): MangasPage { - val document = response.asJsoup() - - val mangas = document.select(searchMangaSelector()).map { element -> - searchMangaFromElement(element) - } - - val length = QTD_REGEX.find(document.toString())!!.groupValues[1].toInt() - val page = PAGE_REGEX.find(document.toString())!!.groupValues[1].toInt() - - // From the JavaScript of the page. - return MangasPage(mangas, length - page * 20 > 0) - } - - override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request { - val url = HttpUrl.parse("$baseUrl/pesquisa/comic/$page/")!!.newBuilder() - .addEncodedPathSegment(query) - - return GET(url.toString(), headers) - } - - override fun searchMangaSelector() = "ul#resultados > li > a" - - override fun searchMangaFromElement(element: Element): SManga = SManga.create().apply { - val div = element.select("div").first() - - title = div.select("h4").text() - - val thumb = element.select("img").first().attr("src") - val dataTemp = element.select("img").first().attr("data-temp") - thumbnail_url = baseUrl + "/" + (if (thumb != NO_THUMB) dataTemp else thumb) - - setUrlWithoutDomain(baseUrl + element.attr("href")) - } - - override fun searchMangaNextPageSelector(): String? = null - - override fun mangaDetailsParse(document: Document): SManga = SManga.create().apply { - title = document.select("#titulo > h1").text() - author = document.select("#autor").text() - artist = document.select("#autor").text() - genre = document.select("#genero").text() - status = SManga.UNKNOWN - description = document.select("#descricao > p").last().text() - - val thumbImg = document.select("#imagem-projeto > img").first() - thumbnail_url = baseUrl + "/" + (if (thumbImg != null) thumbImg.attr("src") else NO_THUMB) - } - - override fun chapterListSelector() = "div#capitulos > ul > li.capitulo > a" - - override fun chapterFromElement(element: Element): SChapter = SChapter.create().apply { - name = element.select("header > h3").text() - date_upload = parseChapterDate(element.select("div.capitulo-info > span.data").text()) - setUrlWithoutDomain(baseUrl + "/" + element.attr("href")) - } - - override fun pageListParse(document: Document): List { - val id = ID_REGEX.find(document.toString())!!.groupValues[1] - - return FILES_REGEX.find(document.toString())!!.groupValues[1] - .replace("\"", "") - .split(",") - .mapIndexed { i, img -> Page(i, "", "$baseUrl/servidor/titulos/comics/$id/$img") } - } - - override fun imageUrlParse(document: Document) = "" - - override fun latestUpdatesRequest(page: Int): Request = throw Exception("This method should not be called!") - - override fun latestUpdatesSelector() = throw Exception("This method should not be called!") - - override fun latestUpdatesFromElement(element: Element): SManga = throw Exception("This method should not be called!") - - private fun parseChapterDate(date: String): Long { - return try { - SimpleDateFormat("dd MMM, yyyy", Locale("pt", "BR")).parse(date)?.time ?: 0L - } catch (e: ParseException) { - 0L - } - } - - companion object { - private const val USER_AGENT = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) " + - "AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.128 Safari/537.36" - - private val ID_REGEX = "var titulo = \\{\"id\":\"(\\d+)\"".toRegex() - private val FILES_REGEX = "var arquivos = \\[(.*)\\];".toRegex() - private val QTD_REGEX = "var qtd = (\\d+);".toRegex() - private val PAGE_REGEX = "var pagina = '(\\d+)';".toRegex() - - private const val NO_THUMB = "img/sem-foto.png" - } -}