TresDaosScan: Update domain and add url editor (#9589)
Update domain and add url editor
This commit is contained in:
parent
5bdb239025
commit
603fd58fff
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 :
|
||||||
"Tres Daos Scan",
|
MangaThemesia(
|
||||||
"https://threedaos.drublood.com",
|
"Tres Daos Scan",
|
||||||
"es",
|
"https://threedaos.zdrz.xyz",
|
||||||
dateFormat = SimpleDateFormat("MMMM dd, yyyy", Locale("es")),
|
"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"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user