|
|
@ -14,16 +14,17 @@ import org.mozilla.fenix.BuildConfig
|
|
|
|
import org.mozilla.fenix.Config
|
|
|
|
import org.mozilla.fenix.Config
|
|
|
|
import org.mozilla.fenix.R
|
|
|
|
import org.mozilla.fenix.R
|
|
|
|
import org.mozilla.fenix.ext.getPreferenceKey
|
|
|
|
import org.mozilla.fenix.ext.getPreferenceKey
|
|
|
|
import java.security.InvalidParameterException
|
|
|
|
import org.mozilla.fenix.settings.sharedpreferences.PreferencesHolder
|
|
|
|
|
|
|
|
import org.mozilla.fenix.settings.sharedpreferences.booleanPreference
|
|
|
|
|
|
|
|
import org.mozilla.fenix.settings.sharedpreferences.sitePermissionsRulesActionPreference
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* A simple wrapper for SharedPreferences that makes reading preference a little bit easier.
|
|
|
|
* A simple wrapper for SharedPreferences that makes reading preference a little bit easier.
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
@SuppressWarnings("TooManyFunctions")
|
|
|
|
|
|
|
|
class Settings private constructor(
|
|
|
|
class Settings private constructor(
|
|
|
|
context: Context,
|
|
|
|
context: Context,
|
|
|
|
private val isCrashReportEnabledInBuild: Boolean
|
|
|
|
private val isCrashReportEnabledInBuild: Boolean
|
|
|
|
) {
|
|
|
|
) : PreferencesHolder {
|
|
|
|
|
|
|
|
|
|
|
|
companion object {
|
|
|
|
companion object {
|
|
|
|
const val autoBounceMaximumCount = 2
|
|
|
|
const val autoBounceMaximumCount = 2
|
|
|
@ -46,110 +47,80 @@ class Settings private constructor(
|
|
|
|
|
|
|
|
|
|
|
|
private val appContext = context.applicationContext
|
|
|
|
private val appContext = context.applicationContext
|
|
|
|
|
|
|
|
|
|
|
|
val preferences: SharedPreferences =
|
|
|
|
override val preferences: SharedPreferences =
|
|
|
|
appContext.getSharedPreferences(FENIX_PREFERENCES, MODE_PRIVATE)
|
|
|
|
appContext.getSharedPreferences(FENIX_PREFERENCES, MODE_PRIVATE)
|
|
|
|
|
|
|
|
|
|
|
|
val usePrivateMode: Boolean
|
|
|
|
var usePrivateMode by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(appContext.getPreferenceKey(R.string.pref_key_private_mode), false)
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_private_mode),
|
|
|
|
|
|
|
|
default = false
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
fun setPrivateMode(newValue: Boolean) {
|
|
|
|
var defaultSearchEngineName: String
|
|
|
|
preferences.edit().putBoolean(appContext.getPreferenceKey(R.string.pref_key_private_mode), newValue).apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val defaultSearchEngineName: String
|
|
|
|
|
|
|
|
get() = preferences.getString(appContext.getPreferenceKey(R.string.pref_key_search_engine), "") ?: ""
|
|
|
|
get() = preferences.getString(appContext.getPreferenceKey(R.string.pref_key_search_engine), "") ?: ""
|
|
|
|
|
|
|
|
set(name) = preferences.edit()
|
|
|
|
|
|
|
|
.putString(appContext.getPreferenceKey(R.string.pref_key_search_engine), name)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
|
|
|
|
val isCrashReportingEnabled: Boolean
|
|
|
|
val isCrashReportingEnabled: Boolean
|
|
|
|
get() = isCrashReportEnabledInBuild &&
|
|
|
|
get() = isCrashReportEnabledInBuild &&
|
|
|
|
preferences.getBoolean(appContext.getPreferenceKey(R.string.pref_key_crash_reporter), true)
|
|
|
|
preferences.getBoolean(appContext.getPreferenceKey(R.string.pref_key_crash_reporter), true)
|
|
|
|
|
|
|
|
|
|
|
|
val isRemoteDebuggingEnabled: Boolean
|
|
|
|
val isRemoteDebuggingEnabled by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(appContext.getPreferenceKey(R.string.pref_key_remote_debugging), false)
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_remote_debugging),
|
|
|
|
|
|
|
|
default = false
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
val isTelemetryEnabled: Boolean
|
|
|
|
val isTelemetryEnabled by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(appContext.getPreferenceKey(R.string.pref_key_telemetry), true)
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_telemetry),
|
|
|
|
|
|
|
|
default = true
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
val shouldAutoBounceQuickActionSheet: Boolean
|
|
|
|
val shouldAutoBounceQuickActionSheet: Boolean
|
|
|
|
get() = autoBounceQuickActionSheetCount < autoBounceMaximumCount
|
|
|
|
get() = autoBounceQuickActionSheetCount < autoBounceMaximumCount
|
|
|
|
|
|
|
|
|
|
|
|
val shouldUseLightTheme: Boolean
|
|
|
|
var shouldUseLightTheme by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_light_theme),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_light_theme),
|
|
|
|
default = false
|
|
|
|
false
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setLightTheme(newValue: Boolean) {
|
|
|
|
|
|
|
|
preferences.edit().putBoolean(
|
|
|
|
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_light_theme),
|
|
|
|
|
|
|
|
newValue
|
|
|
|
|
|
|
|
).apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setAutoSize(newValue: Boolean) {
|
|
|
|
|
|
|
|
preferences.edit().putBoolean(appContext.getPreferenceKey(R.string.pref_key_accessibility_auto_size), newValue)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val shouldUseAutoSize: Boolean
|
|
|
|
var shouldUseAutoSize by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_accessibility_auto_size),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_accessibility_auto_size),
|
|
|
|
default = true
|
|
|
|
true
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setFontSizeFactor(newValue: Float) {
|
|
|
|
var fontSizeFactor: Float
|
|
|
|
preferences.edit().putFloat(appContext.getPreferenceKey(R.string.pref_key_accessibility_font_scale), newValue)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val fontSizeFactor: Float
|
|
|
|
|
|
|
|
get() = preferences.getFloat(
|
|
|
|
get() = preferences.getFloat(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_accessibility_font_scale),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_accessibility_font_scale),
|
|
|
|
1f
|
|
|
|
1f
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
set(value) = preferences.edit()
|
|
|
|
|
|
|
|
.putFloat(appContext.getPreferenceKey(R.string.pref_key_accessibility_font_scale), value)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
|
|
|
|
val shouldShowVisitedSitesBookmarks: Boolean
|
|
|
|
val shouldShowVisitedSitesBookmarks by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_show_visited_sites_bookmarks),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_show_visited_sites_bookmarks),
|
|
|
|
default = true
|
|
|
|
true
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val shouldUseDarkTheme: Boolean
|
|
|
|
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_dark_theme),
|
|
|
|
|
|
|
|
false
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val shouldFollowDeviceTheme: Boolean
|
|
|
|
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_follow_device_theme),
|
|
|
|
|
|
|
|
false
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setFollowDeviceTheme(newValue: Boolean) {
|
|
|
|
val shouldUseDarkTheme by booleanPreference(
|
|
|
|
preferences.edit().putBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_dark_theme),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_follow_device_theme),
|
|
|
|
default = false
|
|
|
|
newValue
|
|
|
|
)
|
|
|
|
).apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val shouldUseTrackingProtection: Boolean
|
|
|
|
var shouldFollowDeviceTheme by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_follow_device_theme),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_tracking_protection),
|
|
|
|
default = false
|
|
|
|
true
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setTrackingProtection(newValue: Boolean) {
|
|
|
|
var shouldUseTrackingProtection by booleanPreference(
|
|
|
|
preferences.edit().putBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_tracking_protection),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_tracking_protection),
|
|
|
|
default = true
|
|
|
|
newValue
|
|
|
|
)
|
|
|
|
).apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val shouldUseAutoBatteryTheme: Boolean
|
|
|
|
val shouldUseAutoBatteryTheme by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_auto_battery_theme),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_auto_battery_theme),
|
|
|
|
default = false
|
|
|
|
false
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val themeSettingString: String
|
|
|
|
val themeSettingString: String
|
|
|
|
get() = when {
|
|
|
|
get() = when {
|
|
|
@ -162,7 +133,7 @@ class Settings private constructor(
|
|
|
|
|
|
|
|
|
|
|
|
@VisibleForTesting(otherwise = PRIVATE)
|
|
|
|
@VisibleForTesting(otherwise = PRIVATE)
|
|
|
|
internal val autoBounceQuickActionSheetCount: Int
|
|
|
|
internal val autoBounceQuickActionSheetCount: Int
|
|
|
|
get() = (preferences.getInt(appContext.getPreferenceKey(R.string.pref_key_bounce_quick_action), 0))
|
|
|
|
get() = preferences.getInt(appContext.getPreferenceKey(R.string.pref_key_bounce_quick_action), 0)
|
|
|
|
|
|
|
|
|
|
|
|
fun incrementAutomaticBounceQuickActionSheetCount() {
|
|
|
|
fun incrementAutomaticBounceQuickActionSheetCount() {
|
|
|
|
preferences.edit().putInt(
|
|
|
|
preferences.edit().putInt(
|
|
|
@ -171,91 +142,42 @@ class Settings private constructor(
|
|
|
|
).apply()
|
|
|
|
).apply()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fun setDefaultSearchEngineByName(name: String) {
|
|
|
|
val showSearchSuggestions by booleanPreference(
|
|
|
|
preferences.edit()
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_show_search_suggestions),
|
|
|
|
.putString(appContext.getPreferenceKey(R.string.pref_key_search_engine), name)
|
|
|
|
default = true
|
|
|
|
.apply()
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val showSearchSuggestions: Boolean
|
|
|
|
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_show_search_suggestions), true
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setSitePermissionsPhoneFeatureCameraAction(action: SitePermissionsRules.Action) {
|
|
|
|
|
|
|
|
preferences.edit()
|
|
|
|
|
|
|
|
.putInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_camera), action.id)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun getSitePermissionsPhoneFeatureCameraAction(): SitePermissionsRules.Action {
|
|
|
|
|
|
|
|
return preferences.getInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_camera), 1)
|
|
|
|
|
|
|
|
.toSitePermissionsRulesAction()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setSitePermissionsPhoneFeatureMicrophoneAction(action: SitePermissionsRules.Action) {
|
|
|
|
|
|
|
|
preferences.edit()
|
|
|
|
|
|
|
|
.putInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_microphone), action.id)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun getSitePermissionsPhoneFeatureMicrophoneAction(): SitePermissionsRules.Action {
|
|
|
|
|
|
|
|
return preferences.getInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_microphone), 1)
|
|
|
|
|
|
|
|
.toSitePermissionsRulesAction()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setSitePermissionsPhoneFeatureNotificationAction(action: SitePermissionsRules.Action) {
|
|
|
|
var sitePermissionsPhoneFeatureCameraAction by sitePermissionsRulesActionPreference(
|
|
|
|
preferences.edit()
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_phone_feature_camera)
|
|
|
|
.putInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_notification), action.id)
|
|
|
|
)
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun getSitePermissionsPhoneFeatureNotificationAction(): SitePermissionsRules.Action {
|
|
|
|
var sitePermissionsPhoneFeatureMicrophoneAction by sitePermissionsRulesActionPreference(
|
|
|
|
return preferences.getInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_notification), 1)
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_phone_feature_microphone)
|
|
|
|
.toSitePermissionsRulesAction()
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun setSitePermissionsPhoneFeatureLocation(action: SitePermissionsRules.Action) {
|
|
|
|
var sitePermissionsPhoneFeatureNotificationAction by sitePermissionsRulesActionPreference(
|
|
|
|
preferences.edit()
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_phone_feature_notification)
|
|
|
|
.putInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_location), action.id)
|
|
|
|
)
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun getSitePermissionsPhoneFeatureLocation(): SitePermissionsRules.Action {
|
|
|
|
var sitePermissionsPhoneFeatureLocation by sitePermissionsRulesActionPreference(
|
|
|
|
return preferences.getInt(appContext.getPreferenceKey(R.string.pref_key_phone_feature_location), 1)
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_phone_feature_location)
|
|
|
|
.toSitePermissionsRulesAction()
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun getSitePermissionsCustomSettingsRules(): SitePermissionsRules {
|
|
|
|
fun getSitePermissionsCustomSettingsRules(): SitePermissionsRules {
|
|
|
|
return SitePermissionsRules(
|
|
|
|
return SitePermissionsRules(
|
|
|
|
notification = getSitePermissionsPhoneFeatureNotificationAction(),
|
|
|
|
notification = sitePermissionsPhoneFeatureNotificationAction,
|
|
|
|
microphone = getSitePermissionsPhoneFeatureMicrophoneAction(),
|
|
|
|
microphone = sitePermissionsPhoneFeatureMicrophoneAction,
|
|
|
|
location = getSitePermissionsPhoneFeatureLocation(),
|
|
|
|
location = sitePermissionsPhoneFeatureLocation,
|
|
|
|
camera = getSitePermissionsPhoneFeatureCameraAction()
|
|
|
|
camera = sitePermissionsPhoneFeatureCameraAction
|
|
|
|
)
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fun setFxaSignedIn(isSignedIn: Boolean) {
|
|
|
|
var fxaSignedIn by booleanPreference(appContext.getPreferenceKey(R.string.pref_key_fxa_signed_in), default = true)
|
|
|
|
preferences.edit()
|
|
|
|
|
|
|
|
.putBoolean(appContext.getPreferenceKey(R.string.pref_key_fxa_signed_in), isSignedIn)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val fxaSignedIn: Boolean
|
|
|
|
var fxaHasSyncedItems by booleanPreference(
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_fxa_has_synced_items),
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_fxa_signed_in), true
|
|
|
|
default = true
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
fun setFxaHasSyncedItems(hasSyncedItems: Boolean) {
|
|
|
|
|
|
|
|
preferences.edit()
|
|
|
|
|
|
|
|
.putBoolean(appContext.getPreferenceKey(R.string.pref_key_fxa_has_synced_items), hasSyncedItems)
|
|
|
|
|
|
|
|
.apply()
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val fxaHasSyncedItems: Boolean
|
|
|
|
|
|
|
|
get() = preferences.getBoolean(
|
|
|
|
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_fxa_has_synced_items), true
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun addSearchWidgetInstalled(count: Int) {
|
|
|
|
fun addSearchWidgetInstalled(count: Int) {
|
|
|
|
val key = appContext.getPreferenceKey(R.string.pref_key_search_widget_installed)
|
|
|
|
val key = appContext.getPreferenceKey(R.string.pref_key_search_widget_installed)
|
|
|
@ -266,23 +188,5 @@ class Settings private constructor(
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
val searchWidgetInstalled: Boolean
|
|
|
|
val searchWidgetInstalled: Boolean
|
|
|
|
get() = 0 < preferences.getInt(
|
|
|
|
get() = 0 < preferences.getInt(appContext.getPreferenceKey(R.string.pref_key_search_widget_installed), 0)
|
|
|
|
appContext.getPreferenceKey(R.string.pref_key_search_widget_installed), 0
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private val SitePermissionsRules.Action.id: Int
|
|
|
|
|
|
|
|
get() {
|
|
|
|
|
|
|
|
return when (this) {
|
|
|
|
|
|
|
|
SitePermissionsRules.Action.BLOCKED -> 0
|
|
|
|
|
|
|
|
SitePermissionsRules.Action.ASK_TO_ALLOW -> 1
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private fun Int.toSitePermissionsRulesAction(): SitePermissionsRules.Action {
|
|
|
|
|
|
|
|
return when (this) {
|
|
|
|
|
|
|
|
0 -> SitePermissionsRules.Action.BLOCKED
|
|
|
|
|
|
|
|
1 -> SitePermissionsRules.Action.ASK_TO_ALLOW
|
|
|
|
|
|
|
|
else -> throw InvalidParameterException("$this is not a valid SitePermissionsRules.Action")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|