TresDaosScan: Update domain and add url editor (#9589)

Update domain and add url editor
This commit is contained in:
Chopper 2025-07-08 14:30:42 -03:00 committed by Draff
parent 5bdb239025
commit 603fd58fff
Signed by: Draff
GPG Key ID: E8A89F3211677653
2 changed files with 64 additions and 8 deletions

View File

@ -2,8 +2,8 @@ ext {
extName = 'Tres Daos Scan' extName = 'Tres Daos Scan'
extClass = '.TresDaosScan' extClass = '.TresDaosScan'
themePkg = 'mangathemesia' themePkg = 'mangathemesia'
baseUrl = 'https://threedaos.drublood.com' baseUrl = 'https://threedaos.zdrz.xyz'
overrideVersionCode = 10 overrideVersionCode = 11
isNsfw = false isNsfw = false
} }

View File

@ -1,19 +1,75 @@
package eu.kanade.tachiyomi.extension.es.tresdaosscan package eu.kanade.tachiyomi.extension.es.tresdaosscan
import android.content.SharedPreferences
import android.widget.Toast
import androidx.preference.EditTextPreference
import androidx.preference.PreferenceScreen
import eu.kanade.tachiyomi.multisrc.mangathemesia.MangaThemesia import eu.kanade.tachiyomi.multisrc.mangathemesia.MangaThemesia
import eu.kanade.tachiyomi.network.interceptor.rateLimit import eu.kanade.tachiyomi.network.interceptor.rateLimit
import eu.kanade.tachiyomi.source.ConfigurableSource
import keiyoushi.utils.getPreferences
import java.text.SimpleDateFormat import java.text.SimpleDateFormat
import java.util.Locale import java.util.Locale
class TresDaosScan : MangaThemesia( class TresDaosScan :
MangaThemesia(
"Tres Daos Scan", "Tres Daos Scan",
"https://threedaos.drublood.com", "https://threedaos.zdrz.xyz",
"es", "es",
dateFormat = SimpleDateFormat("MMMM dd, yyyy", Locale("es")), dateFormat = SimpleDateFormat("MMMM dd, yyyy", Locale("es")),
) { ),
ConfigurableSource {
override val versionId = 4 override val versionId = 4
override val client = super.client.newBuilder() override val client = super.client.newBuilder()
.rateLimit(2) .rateLimit(2)
.build() .build()
private val defaultBaseUrl: String = super.baseUrl
private val preferences = getPreferences {
getString(DEFAULT_BASE_URL_PREF, defaultBaseUrl).let { domain ->
if (domain != defaultBaseUrl) {
edit()
.putString(BASE_URL_PREF, defaultBaseUrl)
.putString(DEFAULT_BASE_URL_PREF, defaultBaseUrl)
.apply()
}
}
}
override val baseUrl: String get() = preferences.prefBaseUrl
private var _cachedBaseUrl: String? = null
private var SharedPreferences.prefBaseUrl: String
get() {
if (_cachedBaseUrl == null) {
_cachedBaseUrl = getString(BASE_URL_PREF, defaultBaseUrl)!!
}
return _cachedBaseUrl!!
}
set(value) {
_cachedBaseUrl = value
edit().putString(BASE_URL_PREF, value).apply()
}
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 = title
dialogMessage = "URL por defecto:\n$defaultBaseUrl"
setDefaultValue(defaultBaseUrl)
setOnPreferenceChangeListener { _, _ ->
Toast.makeText(screen.context, "Reinicie la aplicación para aplicar los cambios", Toast.LENGTH_LONG).show()
true
}
}.also { screen.addPreference(it) }
}
companion object {
private const val BASE_URL_PREF = "overrideBaseUrl"
private const val DEFAULT_BASE_URL_PREF = "defaultBaseUrl"
}
} }