diff --git a/src/en/honkaiimpact3/build.gradle b/src/en/honkaiimpact3/build.gradle new file mode 100644 index 000000000..eb57a70e2 --- /dev/null +++ b/src/en/honkaiimpact3/build.gradle @@ -0,0 +1,17 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +ext { + appName = 'Tachiyomi: HonkaiImpact3' + pkgNameSuffix = 'en.honkaiimpact' + extClass = '.Honkaiimpact' + extVersionCode = 1 + libVersion = '1.2' +} + +dependencies { + compileOnly 'com.google.code.gson:gson:2.8.2' + compileOnly 'com.github.salomonbrys.kotson:kotson:2.5.0' +} + +apply from: "$rootDir/common.gradle" diff --git a/src/en/honkaiimpact3/res/mipmap-hdpi/ic_launcher.png b/src/en/honkaiimpact3/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 000000000..dc9187779 Binary files /dev/null and b/src/en/honkaiimpact3/res/mipmap-hdpi/ic_launcher.png differ diff --git a/src/en/honkaiimpact3/res/mipmap-mdpi/ic_launcher.png b/src/en/honkaiimpact3/res/mipmap-mdpi/ic_launcher.png new file mode 100644 index 000000000..0f31bc0c8 Binary files /dev/null and b/src/en/honkaiimpact3/res/mipmap-mdpi/ic_launcher.png differ diff --git a/src/en/honkaiimpact3/res/mipmap-xhdpi/ic_launcher.png b/src/en/honkaiimpact3/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 000000000..850d770de Binary files /dev/null and b/src/en/honkaiimpact3/res/mipmap-xhdpi/ic_launcher.png differ diff --git a/src/en/honkaiimpact3/res/mipmap-xxhdpi/ic_launcher.png b/src/en/honkaiimpact3/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 000000000..8d9005961 Binary files /dev/null and b/src/en/honkaiimpact3/res/mipmap-xxhdpi/ic_launcher.png differ diff --git a/src/en/honkaiimpact3/res/mipmap-xxxhdpi/ic_launcher.png b/src/en/honkaiimpact3/res/mipmap-xxxhdpi/ic_launcher.png new file mode 100644 index 000000000..2a38eb48c Binary files /dev/null and b/src/en/honkaiimpact3/res/mipmap-xxxhdpi/ic_launcher.png differ diff --git a/src/en/honkaiimpact3/res/web_hi_res_512.png b/src/en/honkaiimpact3/res/web_hi_res_512.png new file mode 100644 index 000000000..f460a939b Binary files /dev/null and b/src/en/honkaiimpact3/res/web_hi_res_512.png differ diff --git a/src/en/honkaiimpact3/src/eu/kanade/tachiyomi/extension/en/honkaiimpact/Honkaiimpact.kt b/src/en/honkaiimpact3/src/eu/kanade/tachiyomi/extension/en/honkaiimpact/Honkaiimpact.kt new file mode 100644 index 000000000..54694f8ee --- /dev/null +++ b/src/en/honkaiimpact3/src/eu/kanade/tachiyomi/extension/en/honkaiimpact/Honkaiimpact.kt @@ -0,0 +1,117 @@ +package eu.kanade.tachiyomi.extension.en.honkaiimpact + +import com.github.salomonbrys.kotson.float +import com.github.salomonbrys.kotson.get +import com.github.salomonbrys.kotson.int +import com.github.salomonbrys.kotson.string +import com.google.gson.JsonElement +import com.google.gson.JsonParser +import eu.kanade.tachiyomi.network.GET +import eu.kanade.tachiyomi.source.model.FilterList +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.Response +import org.jsoup.nodes.Document +import org.jsoup.nodes.Element +import java.text.SimpleDateFormat +import java.util.* +import java.util.concurrent.TimeUnit + +class Honkaiimpact : ParsedHttpSource() { + + //Info - Based of BH3 + //This is the english version of the site + override val name = "Honkai Impact 3rd" + override val baseUrl = "https://manga.honkaiimpact3.com" + override val lang = "en" + override val supportsLatest = false + override val client: OkHttpClient = network.cloudflareClient.newBuilder() + .connectTimeout(1, TimeUnit.MINUTES) + .readTimeout(1, TimeUnit.MINUTES) + .retryOnConnectionFailure(true) + .followRedirects(true) + .build()!! + + //Popular + override fun popularMangaSelector() = "a[href*=book]" + + override fun popularMangaNextPageSelector(): String? = null + override fun popularMangaRequest(page: Int) = GET("$baseUrl/book", headers) + override fun popularMangaFromElement(element: Element) = mangaFromElement(element) + + + //Latest + override fun latestUpdatesSelector() = throw Exception("Not Used") + + override fun latestUpdatesNextPageSelector(): String? = null + override fun latestUpdatesRequest(page: Int) = throw Exception("Not Used") + override fun latestUpdatesFromElement(element: Element) = mangaFromElement(element) + + + //Search + override fun searchMangaSelector() = throw Exception("Not Used") + + override fun searchMangaNextPageSelector(): String? = null + override fun searchMangaRequest(page: Int, query: String, filters: FilterList) = throw Exception("No search") + override fun searchMangaFromElement(element: Element) = mangaFromElement(element) + + private fun mangaFromElement(element: Element): SManga { + val manga = SManga.create() + manga.setUrlWithoutDomain(element.select("a").attr("abs:href")) + manga.title = element.select("div.container-title").text().trim() + manga.thumbnail_url = element.select("img").attr("abs:src") + return manga + } + + //Manga Details + override fun mangaDetailsParse(document: Document): SManga { + val manga = SManga.create() + manga.thumbnail_url = document.select("img.cover").attr("abs:src") + manga.description = document.select("div.detail_info1").text().trim() + manga.title = document.select("div.title").text().trim() + return manga + } + + //Chapters + override fun chapterListSelector() = throw Exception("Not Used") + + override fun chapterFromElement(element: Element) = throw Exception("Not Used") + override fun chapterListRequest(manga: SManga) = GET(baseUrl + manga.url + "/get_chapter", headers) + override fun chapterListParse(response: Response): List { + val jsondata = response.body()!!.string() + val json = JsonParser().parse(jsondata).asJsonArray + val chapters = mutableListOf() + json.forEach { + chapters.add(createChapter(it)) + } + return chapters + } + + private fun createChapter(json: JsonElement) = SChapter.create().apply { + name = json["title"].string + url = "/book/${json["bookid"].int}/${json["chapterid"].int}" + date_upload = parseDate(json["timestamp"].string) + chapter_number = json["chapterid"].float + } + + private fun parseDate(date: String): Long { + return SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.US).parse(date)?.time ?: 0 + } + + //Manga Pages + override fun pageListParse(response: Response): List = mutableListOf().apply { + val body = response.asJsoup() + body.select("img.lazy.comic_img")?.forEach { + add(Page(size, "", it.attr("data-original"))) + } + } + + override fun pageListParse(document: Document) = throw Exception("Not Used") + override fun imageUrlParse(document: Document) = throw Exception("Not Used") + +} +