diff --git a/app/src/main/java/corewala/buran/ui/settings/SettingsFragment.kt b/app/src/main/java/corewala/buran/ui/settings/SettingsFragment.kt index 8b48bb7..e77e5c4 100644 --- a/app/src/main/java/corewala/buran/ui/settings/SettingsFragment.kt +++ b/app/src/main/java/corewala/buran/ui/settings/SettingsFragment.kt @@ -191,6 +191,50 @@ class SettingsFragment: PreferenceFragmentCompat(), Preference.OnPreferenceChang showInlineImages.title = getString(R.string.show_inline_images) webCategory.addPreference(showInlineImages) + val httpGeminiProxy = EditTextPreference(context) + httpGeminiProxy.title = getString(R.string.http_proxy) + httpGeminiProxy.key = "http_proxy" + httpGeminiProxy.dialogTitle = getString(R.string.http_proxy) + + val httpProxy = preferenceManager.sharedPreferences.getString( + "http_proxy", + null + )?.trim() + + httpGeminiProxy.summary = if(httpProxy.isNullOrEmpty()){ + getString(R.string.no_http_proxy_set) + }else if( + !httpProxy.startsWith("gemini://") + or httpProxy.contains(" ") + or !httpProxy.contains(".") + ){ + getString(R.string.not_valid_address) + }else{ + httpProxy + } + + httpGeminiProxy.positiveButtonText = getString(R.string.update) + httpGeminiProxy.negativeButtonText = getString(R.string.cancel) + httpGeminiProxy.setOnPreferenceChangeListener { _, newValue -> + val newHomecapsule = newValue.toString().trim() + httpGeminiProxy.summary = if(newHomecapsule.isNullOrEmpty()){ + getString(R.string.no_http_proxy_set) + }else if( + !newHomecapsule.startsWith("gemini://") + or newHomecapsule.contains(" ") + or !newHomecapsule.contains(".") + ){ + getString(R.string.not_valid_address) + }else{ + newHomecapsule + } + true + } + httpGeminiProxy.setOnBindEditTextListener{ editText -> + editText.imeOptions = EditorInfo.IME_ACTION_DONE + editText.setSelection(editText.text.toString().length)//Set caret position to end + } + webCategory.addPreference(httpGeminiProxy) } private fun buildAppearanceSection(context: Context?, appCategory: PreferenceCategory) { diff --git a/app/src/main/res/values-fr/strings.xml b/app/src/main/res/values-fr/strings.xml index 57b597f..9235283 100644 --- a/app/src/main/res/values-fr/strings.xml +++ b/app/src/main/res/values-fr/strings.xml @@ -66,6 +66,8 @@ Contenu Web Ouvrir les sites web en interne en utilisant des \'Onglets Personnalisés\', plutôt que d\'utiliser le navigateur par défaut. Cela pourrait vous aider à rester dans le Geminispace plutôt que d\'être distrait·e par le vaste web. Cela requiert un navigateur par défaut compatible. Ouvrir en interne + Mandataire HTTP + Pas de mandataire HTTP Images locales en ligne Seuls les magasins de clés client PKCS12 sont actuellement supportés. Certificat Client diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 2b6b161..24b2fb3 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -66,6 +66,8 @@ Web Content Open websites internally using \'Custom Tabs\', instead of using the default browser. This might help you stay in Geminispace instead of being distracted by the wider web. Requires compatible default browser. Open internally + HTTP proxy + No HTTP proxy set Inline local images Only PKCS12 client keystores are currently supported. Client Certificate