2023-01-19 14:52:20 +00:00
|
|
|
package eu.kanade.tachiyomi.extension.ar.mangaswat
|
|
|
|
|
2023-04-16 15:01:03 +00:00
|
|
|
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
|
2023-07-24 20:51:43 +00:00
|
|
|
import eu.kanade.tachiyomi.source.model.FilterList
|
2023-01-19 14:52:20 +00:00
|
|
|
import eu.kanade.tachiyomi.source.model.Page
|
2023-07-22 13:46:25 +00:00
|
|
|
import eu.kanade.tachiyomi.source.model.SChapter
|
2023-01-19 14:52:20 +00:00
|
|
|
import kotlinx.serialization.Serializable
|
|
|
|
import kotlinx.serialization.decodeFromString
|
|
|
|
import okhttp3.Headers
|
|
|
|
import okhttp3.OkHttpClient
|
2023-07-24 20:51:43 +00:00
|
|
|
import okhttp3.Request
|
2023-01-19 14:52:20 +00:00
|
|
|
import org.jsoup.nodes.Document
|
2023-07-22 13:46:25 +00:00
|
|
|
import org.jsoup.nodes.Element
|
2023-04-16 15:01:03 +00:00
|
|
|
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-08-27 18:16:27 +00:00
|
|
|
"https://stmgs.com",
|
2023-01-19 14:52:20 +00:00
|
|
|
"ar",
|
2023-07-22 13:46:25 +00:00
|
|
|
dateFormat = SimpleDateFormat("MMMM dd, yyyy", Locale("ar")),
|
2023-01-19 14:52:20 +00:00
|
|
|
) {
|
2023-09-10 18:44:41 +00:00
|
|
|
private val defaultBaseUrl = "https://swatmanga.co"
|
2023-04-16 15:01:03 +00:00
|
|
|
|
|
|
|
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/")
|
|
|
|
|
2023-07-24 20:51:43 +00:00
|
|
|
override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request {
|
|
|
|
val request = super.searchMangaRequest(page, query, filters)
|
|
|
|
if (query.isBlank()) return request
|
|
|
|
|
|
|
|
val url = request.url.newBuilder()
|
|
|
|
.removePathSegment(0)
|
|
|
|
.removeAllQueryParameters("title")
|
|
|
|
.addQueryParameter("s", query)
|
|
|
|
.build()
|
|
|
|
|
|
|
|
return request.newBuilder()
|
|
|
|
.url(url)
|
|
|
|
.build()
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun searchMangaNextPageSelector() = "a[rel=next]"
|
|
|
|
|
2023-01-19 14:52:20 +00:00
|
|
|
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) }
|
|
|
|
}
|
|
|
|
|
2023-06-17 14:00:23 +00:00
|
|
|
override fun chapterListSelector() = "div.bxcl li, ul div:has(span.lchx)"
|
|
|
|
|
2023-07-22 13:46:25 +00:00
|
|
|
override fun chapterFromElement(element: Element) = SChapter.create().apply {
|
|
|
|
val urlElements = element.select("a")
|
|
|
|
setUrlWithoutDomain(urlElements.attr("href"))
|
|
|
|
name = element.select(".lch a, .chapternum").text().ifBlank { urlElements.last()!!.text() }
|
|
|
|
date_upload = element.selectFirst(".chapter-date")?.text().parseChapterDate()
|
|
|
|
}
|
|
|
|
|
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>,
|
|
|
|
)
|
2023-04-16 15:01:03 +00:00
|
|
|
|
|
|
|
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
|
|
|
}
|