diff --git a/src/es/templescanesp/build.gradle b/src/es/templescanesp/build.gradle index 9fe41aac0..27d13082d 100644 --- a/src/es/templescanesp/build.gradle +++ b/src/es/templescanesp/build.gradle @@ -2,8 +2,8 @@ ext { extName = 'Temple Scan' extClass = '.TempleScanEsp' themePkg = 'madara' - baseUrl = 'https://templescanesp.kawi.lat' - overrideVersionCode = 1 + baseUrl = 'https://templescanesp.vxviral.xyz' + overrideVersionCode = 2 isNsfw = true } diff --git a/src/es/templescanesp/src/eu/kanade/tachiyomi/extension/es/templescanesp/TempleScanEsp.kt b/src/es/templescanesp/src/eu/kanade/tachiyomi/extension/es/templescanesp/TempleScanEsp.kt index cc1ce6816..2835f7c9e 100644 --- a/src/es/templescanesp/src/eu/kanade/tachiyomi/extension/es/templescanesp/TempleScanEsp.kt +++ b/src/es/templescanesp/src/eu/kanade/tachiyomi/extension/es/templescanesp/TempleScanEsp.kt @@ -1,29 +1,58 @@ package eu.kanade.tachiyomi.extension.es.templescanesp +import android.content.SharedPreferences +import android.widget.Toast +import androidx.preference.EditTextPreference +import androidx.preference.PreferenceScreen import eu.kanade.tachiyomi.multisrc.madara.Madara import eu.kanade.tachiyomi.network.interceptor.rateLimitHost +import eu.kanade.tachiyomi.source.ConfigurableSource import eu.kanade.tachiyomi.source.model.SChapter import eu.kanade.tachiyomi.source.model.SManga +import keiyoushi.utils.getPreferences import okhttp3.HttpUrl.Companion.toHttpUrl import org.jsoup.nodes.Element import java.text.SimpleDateFormat import java.util.Locale -class TempleScanEsp : Madara( - "Temple Scan", - "https://templescanesp.kawi.lat", - "es", - dateFormat = SimpleDateFormat("MMMM dd, yyyy", Locale("es")), -) { +class TempleScanEsp : + Madara( + "Temple Scan", + "https://templescanesp.vxviral.xyz", + "es", + dateFormat = SimpleDateFormat("MMMM dd, yyyy", Locale("es")), + ), + ConfigurableSource { + + private val isCi = System.getenv("CI") == "true" + + override val baseUrl get() = when { + isCi -> super.baseUrl + else -> preferences.prefBaseUrl + } + override val versionId = 4 override val mangaSubString = "serie" override val useLoadMoreRequest = LoadMoreStrategy.Always - override val client = super.client.newBuilder() - .rateLimitHost(baseUrl.toHttpUrl(), 3, 1) - .build() + override val client by lazy { + super.client.newBuilder() + .rateLimitHost(baseUrl.toHttpUrl(), 3, 1) + .build() + } + + private val preferences = getPreferences { + this.getString(DEFAULT_BASE_URL_PREF, null).let { domain -> + if (domain != super.baseUrl) { + this.edit() + .putString(BASE_URL_PREF, super.baseUrl) + .putString(DEFAULT_BASE_URL_PREF, super.baseUrl) + .apply() + } + } + } override fun popularMangaSelector() = "div.latest-poster" @@ -57,4 +86,37 @@ class TempleScanEsp : Madara( private fun Element.imageFromStyle(): String { return this.attr("style").substringAfter("url(").substringBefore(")") } + + override fun setupPreferenceScreen(screen: PreferenceScreen) { + EditTextPreference(screen.context).apply { + key = BASE_URL_PREF + title = "Editar URL de la fuente" + summary = "Para uso temporal, si la extensión se actualiza se perderá el cambio." + dialogTitle = "Editar URL de la fuente" + dialogMessage = "URL por defecto:\n${super.baseUrl}" + setDefaultValue(super.baseUrl) + setOnPreferenceChangeListener { _, _ -> + Toast.makeText(screen.context, "Reinicie la aplicación para aplicar los cambios", Toast.LENGTH_LONG).show() + true + } + }.also { screen.addPreference(it) } + } + + private var _cachedBaseUrl: String? = null + private var SharedPreferences.prefBaseUrl: String + get() { + if (_cachedBaseUrl == null) { + _cachedBaseUrl = getString(BASE_URL_PREF, super.baseUrl)!! + } + return _cachedBaseUrl!! + } + set(value) { + _cachedBaseUrl = value + edit().putString(BASE_URL_PREF, value).apply() + } + + companion object { + private const val BASE_URL_PREF = "overrideBaseUrl" + private const val DEFAULT_BASE_URL_PREF = "defaultBaseUrl" + } }