mirror of
https://github.com/syncthing/syncthing-android.git
synced 2024-11-26 06:11:19 +00:00
This commit is contained in:
parent
5c04dab7b2
commit
892fdea2ea
5 changed files with 33 additions and 7 deletions
|
@ -11,6 +11,7 @@ import android.preference.CheckBoxPreference;
|
||||||
import android.preference.EditTextPreference;
|
import android.preference.EditTextPreference;
|
||||||
import android.preference.ListPreference;
|
import android.preference.ListPreference;
|
||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
|
import android.preference.PreferenceGroup;
|
||||||
import android.preference.PreferenceFragment;
|
import android.preference.PreferenceFragment;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
import android.preference.PreferenceScreen;
|
import android.preference.PreferenceScreen;
|
||||||
|
@ -101,7 +102,8 @@ public class SettingsActivity extends SyncthingActivity {
|
||||||
@Inject NotificationHandler mNotificationHandler;
|
@Inject NotificationHandler mNotificationHandler;
|
||||||
@Inject SharedPreferences mPreferences;
|
@Inject SharedPreferences mPreferences;
|
||||||
|
|
||||||
private Preference mCategoryRunConditions;
|
private PreferenceGroup mCategoryRunConditions;
|
||||||
|
private CheckBoxPreference mRunConditions;
|
||||||
private CheckBoxPreference mStartServiceOnBoot;
|
private CheckBoxPreference mStartServiceOnBoot;
|
||||||
private ListPreference mPowerSource;
|
private ListPreference mPowerSource;
|
||||||
private CheckBoxPreference mRunOnMobileData;
|
private CheckBoxPreference mRunOnMobileData;
|
||||||
|
@ -167,6 +169,8 @@ public class SettingsActivity extends SyncthingActivity {
|
||||||
|
|
||||||
addPreferencesFromResource(R.xml.app_settings);
|
addPreferencesFromResource(R.xml.app_settings);
|
||||||
PreferenceScreen screen = getPreferenceScreen();
|
PreferenceScreen screen = getPreferenceScreen();
|
||||||
|
mRunConditions =
|
||||||
|
(CheckBoxPreference) findPreference(Constants.PREF_RUN_CONDITIONS);
|
||||||
mStartServiceOnBoot =
|
mStartServiceOnBoot =
|
||||||
(CheckBoxPreference) findPreference(Constants.PREF_START_SERVICE_ON_BOOT);
|
(CheckBoxPreference) findPreference(Constants.PREF_START_SERVICE_ON_BOOT);
|
||||||
mPowerSource =
|
mPowerSource =
|
||||||
|
@ -234,9 +238,15 @@ public class SettingsActivity extends SyncthingActivity {
|
||||||
|
|
||||||
mCategorySyncthingOptions = findPreference("category_syncthing_options");
|
mCategorySyncthingOptions = findPreference("category_syncthing_options");
|
||||||
setPreferenceCategoryChangeListener(mCategorySyncthingOptions, this::onSyncthingPreferenceChange);
|
setPreferenceCategoryChangeListener(mCategorySyncthingOptions, this::onSyncthingPreferenceChange);
|
||||||
mCategoryRunConditions = findPreference("category_run_conditions");
|
mCategoryRunConditions = (PreferenceGroup) findPreference("category_run_conditions");
|
||||||
setPreferenceCategoryChangeListener(mCategoryRunConditions, this::onRunConditionPreferenceChange);
|
setPreferenceCategoryChangeListener(mCategoryRunConditions, this::onRunConditionPreferenceChange);
|
||||||
|
|
||||||
|
if (!mRunConditions.isChecked()) {
|
||||||
|
for (int index = 1; index < mCategoryRunConditions.getPreferenceCount(); ++index) {
|
||||||
|
mCategoryRunConditions.getPreference(index).setEnabled(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
exportConfig.setOnPreferenceClickListener(this);
|
exportConfig.setOnPreferenceClickListener(this);
|
||||||
importConfig.setOnPreferenceClickListener(this);
|
importConfig.setOnPreferenceClickListener(this);
|
||||||
|
|
||||||
|
@ -363,6 +373,16 @@ public class SettingsActivity extends SyncthingActivity {
|
||||||
|
|
||||||
public boolean onRunConditionPreferenceChange(Preference preference, Object o) {
|
public boolean onRunConditionPreferenceChange(Preference preference, Object o) {
|
||||||
switch (preference.getKey()) {
|
switch (preference.getKey()) {
|
||||||
|
case Constants.PREF_RUN_CONDITIONS:
|
||||||
|
boolean enabled = (Boolean) o;
|
||||||
|
for (int index = 1; index < mCategoryRunConditions.getPreferenceCount(); ++index) {
|
||||||
|
mCategoryRunConditions.getPreference(index).setEnabled(enabled);
|
||||||
|
}
|
||||||
|
if (enabled) {
|
||||||
|
mRunOnMeteredWifi.setEnabled(mRunOnWifi.isChecked());
|
||||||
|
mWifiSsidWhitelist.setEnabled(mRunOnWifi.isChecked());
|
||||||
|
}
|
||||||
|
break;
|
||||||
case Constants.PREF_POWER_SOURCE:
|
case Constants.PREF_POWER_SOURCE:
|
||||||
mPowerSource.setValue(o.toString());
|
mPowerSource.setValue(o.toString());
|
||||||
preference.setSummary(mPowerSource.getEntry());
|
preference.setSummary(mPowerSource.getEntry());
|
||||||
|
|
|
@ -14,6 +14,7 @@ public class Constants {
|
||||||
|
|
||||||
// Preferences - Run conditions
|
// Preferences - Run conditions
|
||||||
public static final String PREF_START_SERVICE_ON_BOOT = "always_run_in_background";
|
public static final String PREF_START_SERVICE_ON_BOOT = "always_run_in_background";
|
||||||
|
public static final String PREF_RUN_CONDITIONS = "static_run_conditions";
|
||||||
public static final String PREF_RUN_ON_MOBILE_DATA = "run_on_mobile_data";
|
public static final String PREF_RUN_ON_MOBILE_DATA = "run_on_mobile_data";
|
||||||
public static final String PREF_RUN_ON_WIFI = "run_on_wifi";
|
public static final String PREF_RUN_ON_WIFI = "run_on_wifi";
|
||||||
public static final String PREF_RUN_ON_METERED_WIFI = "run_on_metered_wifi";
|
public static final String PREF_RUN_ON_METERED_WIFI = "run_on_metered_wifi";
|
||||||
|
|
|
@ -169,6 +169,7 @@ public class RunConditionMonitor {
|
||||||
*/
|
*/
|
||||||
private RunConditionCheckResult decideShouldRun() {
|
private RunConditionCheckResult decideShouldRun() {
|
||||||
// Get run conditions preferences.
|
// Get run conditions preferences.
|
||||||
|
boolean prefRunConditions= mPreferences.getBoolean(Constants.PREF_RUN_CONDITIONS, false);
|
||||||
boolean prefRunOnMobileData= mPreferences.getBoolean(Constants.PREF_RUN_ON_MOBILE_DATA, false);
|
boolean prefRunOnMobileData= mPreferences.getBoolean(Constants.PREF_RUN_ON_MOBILE_DATA, false);
|
||||||
boolean prefRunOnWifi= mPreferences.getBoolean(Constants.PREF_RUN_ON_WIFI, true);
|
boolean prefRunOnWifi= mPreferences.getBoolean(Constants.PREF_RUN_ON_WIFI, true);
|
||||||
boolean prefRunOnMeteredWifi= mPreferences.getBoolean(Constants.PREF_RUN_ON_METERED_WIFI, false);
|
boolean prefRunOnMeteredWifi= mPreferences.getBoolean(Constants.PREF_RUN_ON_METERED_WIFI, false);
|
||||||
|
@ -179,6 +180,11 @@ public class RunConditionMonitor {
|
||||||
boolean prefRespectPowerSaving = mPreferences.getBoolean(Constants.PREF_RESPECT_BATTERY_SAVING, true);
|
boolean prefRespectPowerSaving = mPreferences.getBoolean(Constants.PREF_RESPECT_BATTERY_SAVING, true);
|
||||||
boolean prefRespectMasterSync = mPreferences.getBoolean(Constants.PREF_RESPECT_MASTER_SYNC, false);
|
boolean prefRespectMasterSync = mPreferences.getBoolean(Constants.PREF_RESPECT_MASTER_SYNC, false);
|
||||||
|
|
||||||
|
if (!prefRunConditions) {
|
||||||
|
Log.v(TAG, "decideShouldRun: !runConditions");
|
||||||
|
return SHOULD_RUN;
|
||||||
|
}
|
||||||
|
|
||||||
List<BlockerReason> blockerReasons = new ArrayList<>();
|
List<BlockerReason> blockerReasons = new ArrayList<>();
|
||||||
|
|
||||||
// PREF_POWER_SOURCE
|
// PREF_POWER_SOURCE
|
||||||
|
|
|
@ -315,7 +315,7 @@ Please report any problems you encounter via Github.</string>
|
||||||
<string name="category_experimental">Experimental</string>
|
<string name="category_experimental">Experimental</string>
|
||||||
|
|
||||||
<!-- Preference screen - Run conditions -->
|
<!-- Preference screen - Run conditions -->
|
||||||
<string name="run_conditions_title">Run Conditions</string>
|
<string name="run_conditions_title">Enable run conditions</string>
|
||||||
<string name="run_conditions_summary">Use the following options to decide when Syncthing will run.</string>
|
<string name="run_conditions_summary">Use the following options to decide when Syncthing will run.</string>
|
||||||
|
|
||||||
<string name="run_on_mobile_data_title">Run on mobile data</string>
|
<string name="run_on_mobile_data_title">Run on mobile data</string>
|
||||||
|
|
|
@ -12,12 +12,11 @@
|
||||||
android:title="@string/category_run_conditions"
|
android:title="@string/category_run_conditions"
|
||||||
android:key="category_run_conditions">
|
android:key="category_run_conditions">
|
||||||
|
|
||||||
<Preference
|
<CheckBoxPreference
|
||||||
android:key="static_run_conditions"
|
android:key="static_run_conditions"
|
||||||
android:persistent="false"
|
|
||||||
android:selectable="false"
|
|
||||||
android:title="@string/run_conditions_title"
|
android:title="@string/run_conditions_title"
|
||||||
android:summary="@string/run_conditions_summary"/>
|
android:summary="@string/run_conditions_summary"
|
||||||
|
android:defaultValue="true" />
|
||||||
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:key="run_on_wifi"
|
android:key="run_on_wifi"
|
||||||
|
|
Loading…
Reference in a new issue