Tachiyomi-Extensions/multisrc/overrides/mangathemesia/mangaswat/src/MangaSwat.kt

96 lines
3.6 KiB
Kotlin
Raw Normal View History

2023-01-19 14:52:20 +00:00
package eu.kanade.tachiyomi.extension.ar.mangaswat
import android.app.Application
import android.content.SharedPreferences
import android.widget.Toast
import androidx.preference.PreferenceScreen
import eu.kanade.tachiyomi.extension.BuildConfig
2023-01-19 14:52:20 +00:00
import eu.kanade.tachiyomi.multisrc.mangathemesia.MangaThemesia
import eu.kanade.tachiyomi.network.interceptor.rateLimit
import eu.kanade.tachiyomi.source.model.Page
import kotlinx.serialization.Serializable
import kotlinx.serialization.decodeFromString
import okhttp3.Headers
import okhttp3.OkHttpClient
import org.jsoup.nodes.Document
import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get
2023-01-19 14:52:20 +00:00
import java.text.SimpleDateFormat
import java.util.Locale
class MangaSwat : MangaThemesia(
"MangaSwat",
2023-04-13 01:10:24 +00:00
"https://swatmanga.me",
2023-01-19 14:52:20 +00:00
"ar",
2023-02-11 19:21:03 +00:00
dateFormat = SimpleDateFormat("yyyy-MM-dd", Locale.US),
2023-01-19 14:52:20 +00:00
) {
private val defaultBaseUrl = "https://swatmanga.me"
override val baseUrl by lazy { getPrefBaseUrl() }
private val preferences: SharedPreferences by lazy {
Injekt.get<Application>().getSharedPreferences("source_$id", 0x0000)
}
2023-01-19 14:52:20 +00:00
override val client: OkHttpClient = super.client.newBuilder()
.rateLimit(1)
.build()
override fun headersBuilder(): Headers.Builder = super.headersBuilder()
.add("Referer", "$baseUrl/")
override val seriesArtistSelector = "span:contains(الناشر) i"
override val seriesAuthorSelector = "span:contains(المؤلف) i"
override val seriesGenreSelector = "span:contains(التصنيف) a, .mgen a"
override val seriesTypeSelector = "span:contains(النوع) a"
override val seriesStatusSelector = "span:contains(الحالة)"
override fun pageListParse(document: Document): List<Page> {
2023-02-12 03:22:32 +00:00
val scriptContent = document.selectFirst("script:containsData(ts_reader)")!!.data()
2023-01-19 14:52:20 +00:00
val jsonString = scriptContent.substringAfter("ts_reader.run(").substringBefore(");")
val tsReader = json.decodeFromString<TSReader>(jsonString)
val imageUrls = tsReader.sources.firstOrNull()?.images ?: return emptyList()
return imageUrls.mapIndexed { index, imageUrl -> Page(index, imageUrl = imageUrl) }
}
override fun chapterListSelector() = "div.bxcl li, ul div:has(span.lchx)"
2023-01-19 14:52:20 +00:00
@Serializable
data class TSReader(
val sources: List<ReaderImageSource>,
)
@Serializable
data class ReaderImageSource(
val source: String,
val images: List<String>,
)
companion object {
private const val RESTART_TACHIYOMI = "Restart Tachiyomi to apply new setting."
private const val BASE_URL_PREF_TITLE = "Override BaseUrl"
private const val BASE_URL_PREF = "overrideBaseUrl_v${BuildConfig.VERSION_CODE}"
private const val BASE_URL_PREF_SUMMARY = "For temporary uses. Updating the extension will erase this setting."
}
override fun setupPreferenceScreen(screen: PreferenceScreen) {
val baseUrlPref = androidx.preference.EditTextPreference(screen.context).apply {
key = BASE_URL_PREF
title = BASE_URL_PREF_TITLE
summary = BASE_URL_PREF_SUMMARY
this.setDefaultValue(defaultBaseUrl)
dialogTitle = BASE_URL_PREF_TITLE
setOnPreferenceChangeListener { _, _ ->
Toast.makeText(screen.context, RESTART_TACHIYOMI, Toast.LENGTH_LONG).show()
true
}
}
screen.addPreference(baseUrlPref)
super.setupPreferenceScreen(screen)
}
private fun getPrefBaseUrl(): String = preferences.getString(BASE_URL_PREF, defaultBaseUrl)!!
2023-01-19 14:52:20 +00:00
}