diff --git a/src/ru/henchan/build.gradle b/src/ru/henchan/build.gradle new file mode 100644 index 000000000..b217bebc5 --- /dev/null +++ b/src/ru/henchan/build.gradle @@ -0,0 +1,12 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +ext { + appName = 'Tachiyomi: Henchan' + pkgNameSuffix = 'ru.henchan' + extClass = '.Henchan' + extVersionCode = 1 + libVersion = '1.2' +} + +apply from: "$rootDir/common.gradle" diff --git a/src/ru/henchan/src/eu/kanade/tachiyomi/extension/ru/henchan/Henchan.kt b/src/ru/henchan/src/eu/kanade/tachiyomi/extension/ru/henchan/Henchan.kt new file mode 100644 index 000000000..e94c095f1 --- /dev/null +++ b/src/ru/henchan/src/eu/kanade/tachiyomi/extension/ru/henchan/Henchan.kt @@ -0,0 +1,141 @@ +package eu.kanade.tachiyomi.extension.ru.henchan + +import eu.kanade.tachiyomi.network.GET +import eu.kanade.tachiyomi.source.model.* +import eu.kanade.tachiyomi.source.online.ParsedHttpSource +import eu.kanade.tachiyomi.util.asJsoup +import okhttp3.Request +import okhttp3.Response +import org.jsoup.nodes.Document +import org.jsoup.nodes.Element + +class Henchan : ParsedHttpSource() { + + override val name = "Henchan" + + override val baseUrl = "http://henchan.me" + + override val lang = "ru" + + override val supportsLatest = true + + override fun popularMangaRequest(page: Int): Request = + GET("$baseUrl/mostfavorites&sort=manga?offset=${20 * (page - 1)}", headers) + + override fun latestUpdatesRequest(page: Int): Request = + GET("$baseUrl/manga/new?offset=${20 * (page - 1)}", headers) + + override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request { + val url = "$baseUrl/?do=search&subaction=search&story=$query" + return GET(url, headers) + } + + override fun popularMangaSelector() = ".content_row" + + override fun latestUpdatesSelector() = popularMangaSelector() + + override fun searchMangaSelector() = "" + + override fun searchMangaParse(response: Response): MangasPage { + val document = response.asJsoup() + + val mangas = mutableListOf() + document.select(searchMangaSelector()).forEach { element -> + val manga = searchMangaFromElement(element) + if (manga.url != "") { + mangas.add(manga) + } + } + + val hasNextPage = searchMangaNextPageSelector().let { selector -> + document.select(selector).first() + } != null + + return MangasPage(mangas, hasNextPage) + } + + + override fun popularMangaFromElement(element: Element): SManga { + val manga = SManga.create() + manga.thumbnail_url = element.select("img").first().attr("src") + element.select("h2 > a").first().let { + val url = it.attr("href") + if (url.contains("/manga/")) { + manga.setUrlWithoutDomain(url) + manga.title = it.text() + } else { + manga.url = "" + } + } + return manga + } + + override fun latestUpdatesFromElement(element: Element): SManga = + popularMangaFromElement(element) + + override fun searchMangaFromElement(element: Element): SManga = + popularMangaFromElement(element) + + override fun popularMangaNextPageSelector() = "#pagination > a:nth-child(2)" + + override fun latestUpdatesNextPageSelector() = popularMangaNextPageSelector() + + override fun searchMangaNextPageSelector() = ".navigation a#nextlink" + + + override fun mangaDetailsParse(document: Document): SManga { + val manga = SManga.create() + manga.author = document.select(".row .item2 h2")[1].text() + manga.genre = document.select(".sidetag > a:eq(2)").joinToString { it.text() } + manga.description = document.select("#description").text() + return manga + } + + override fun chapterListRequest(manga: SManga): Request { + return GET((baseUrl + manga.url).replace("/manga/", "/related/"), headers) + } + + override fun chapterListSelector() = ".related" + + override fun chapterListParse(response: Response): List { + val document = response.asJsoup() + if (document.select("#right > div:nth-child(4)").text().contains(" похожий на ")) { + val chap = SChapter.create() + chap.setUrlWithoutDomain(document.select("#left > div > a").attr("href")) + chap.name = document.select("#right > div:nth-child(4)").text().split(" похожий на ")[1] + chap.chapter_number = 0.0F + chap.date_upload = 0L + return listOf(chap) + + } + return document.select(chapterListSelector()).map { chapterFromElement(it) } + } + + override fun chapterFromElement(element: Element): SChapter { + val chapter = SChapter.create() + chapter.setUrlWithoutDomain(element.select("h2 a").attr("href")) + chapter.name = element.select("h2 a").attr("title") + chapter.chapter_number = 0.0F + chapter.date_upload = 0L + return chapter + + } + override fun pageListRequest(chapter: SChapter): Request { + return GET((baseUrl + chapter.url).replace("/manga/", "/online/"), headers) + } + + override fun pageListParse(response: Response): List { + val html = response.body()!!.string() + val imgString = html.split("\"fullimg\":[").last().split(",]").first() + val resPages = mutableListOf() + val imgs = imgString.split(",") + imgs.forEachIndexed { index, s -> + resPages.add(Page(index, imageUrl = s.removeSurrounding("\""))) + } + return resPages + } + + override fun imageUrlParse(document: Document) = throw Exception("Not Used") + + override fun pageListParse(document: Document): List = throw Exception("Not Used") +}