234 lines
8.2 KiB
Java
234 lines
8.2 KiB
Java
/*
|
|
* Copyright 2018 Stefan Schüller <sschueller@techdroid.com>
|
|
*
|
|
* License: GPL-3.0+
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
package net.schueller.peertube.activity;
|
|
|
|
import android.annotation.TargetApi;
|
|
import android.content.Context;
|
|
import android.content.Intent;
|
|
import android.content.SharedPreferences;
|
|
import android.content.res.Configuration;
|
|
import android.os.Build;
|
|
import android.os.Bundle;
|
|
import android.preference.Preference;
|
|
|
|
import androidx.appcompat.app.ActionBar;
|
|
|
|
import android.preference.PreferenceFragment;
|
|
import android.preference.PreferenceManager;
|
|
import android.preference.PreferenceScreen;
|
|
import android.view.MenuItem;
|
|
import android.widget.Toast;
|
|
|
|
import net.schueller.peertube.R;
|
|
|
|
import java.util.List;
|
|
|
|
import static net.schueller.peertube.helper.Constants.DEFAULT_THEME;
|
|
import static net.schueller.peertube.helper.Constants.THEME_PREF_KEY;
|
|
|
|
public class SettingsActivity extends AppCompatPreferenceActivity {
|
|
|
|
private static String previousThemeColorValue = "";
|
|
|
|
@Override
|
|
public boolean onOptionsItemSelected(MenuItem item) {
|
|
switch (item.getItemId()) {
|
|
case android.R.id.home:
|
|
this.finish();
|
|
return true;
|
|
}
|
|
return super.onOptionsItemSelected(item);
|
|
}
|
|
|
|
private static String getSelectedColor(Context context, String colorId) {
|
|
|
|
String res = "Color not found";
|
|
String[] themeArray = context.getResources().getStringArray(R.array.themeValues);
|
|
String[] colorArray = context.getResources().getStringArray(R.array.themeArray);
|
|
|
|
for (int i = 0; i < themeArray.length; i++) {
|
|
if (themeArray[i].equals(colorId)) {
|
|
res = colorArray[i];
|
|
break;
|
|
}
|
|
}
|
|
return res;
|
|
}
|
|
|
|
/**
|
|
* A preference value change listener that updates the preference's summary
|
|
* to reflect its new value.
|
|
*/
|
|
private static Preference.OnPreferenceChangeListener sBindPreferenceSummaryToValueListener = (preference, value) -> {
|
|
String stringValue = value.toString();
|
|
|
|
// check URL is valid
|
|
// if (preference.getKey().equals("pref_api_base") && !Patterns.WEB_URL.matcher(stringValue).matches()) {
|
|
// Toast.makeText(preference.getContext(), R.string.invalid_url, Toast.LENGTH_LONG).show();
|
|
// return false;
|
|
// }
|
|
// Check if Theme color has change & Provide selected color
|
|
if (preference.getKey().equals("pref_theme")) {
|
|
|
|
stringValue = getSelectedColor(preference.getContext(), stringValue);
|
|
|
|
if (!previousThemeColorValue.equals("") && !previousThemeColorValue.equals(stringValue)) {
|
|
Toast.makeText(preference.getContext(), R.string.pref_description_app_theme, Toast.LENGTH_LONG).show();
|
|
}
|
|
|
|
previousThemeColorValue = stringValue;
|
|
preference.setSummary(stringValue);
|
|
return true;
|
|
}
|
|
|
|
preference.setSummary(stringValue);
|
|
|
|
return true;
|
|
};
|
|
|
|
/**
|
|
* Helper method to determine if the device has an extra-large screen. For
|
|
* example, 10" tablets are extra-large.
|
|
*/
|
|
private static boolean isXLargeTablet(Context context) {
|
|
return (context.getResources().getConfiguration().screenLayout
|
|
& Configuration.SCREENLAYOUT_SIZE_MASK) >= Configuration.SCREENLAYOUT_SIZE_XLARGE;
|
|
}
|
|
|
|
/**
|
|
* Binds a preference's summary to its value. More specifically, when the
|
|
* preference's value is changed, its summary (line of text below the
|
|
* preference title) is updated to reflect the value. The summary is also
|
|
* immediately updated upon calling this method. The exact display format is
|
|
* dependent on the type of preference.
|
|
*
|
|
* @see #sBindPreferenceSummaryToValueListener
|
|
*/
|
|
private static void bindPreferenceSummaryToValue(Preference preference) {
|
|
// Set the listener to watch for value changes.
|
|
preference.setOnPreferenceChangeListener(sBindPreferenceSummaryToValueListener);
|
|
|
|
// Trigger the listener immediately with the preference's
|
|
// current value.
|
|
sBindPreferenceSummaryToValueListener.onPreferenceChange(preference,
|
|
PreferenceManager
|
|
.getDefaultSharedPreferences(preference.getContext())
|
|
.getString(preference.getKey(), ""));
|
|
}
|
|
|
|
@Override
|
|
protected void onCreate(Bundle savedInstanceState) {
|
|
|
|
|
|
super.onCreate(savedInstanceState);
|
|
|
|
setupActionBar();
|
|
getFragmentManager().beginTransaction().replace(android.R.id.content, new GeneralPreferenceFragment()).commit();
|
|
}
|
|
|
|
/**
|
|
* Set up the {@link android.app.ActionBar}, if the API is available.
|
|
*/
|
|
private void setupActionBar() {
|
|
ActionBar actionBar = getSupportActionBar();
|
|
if (actionBar != null) {
|
|
// Show the Up button in the action bar.
|
|
actionBar.setDisplayHomeAsUpEnabled(true);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
@Override
|
|
public boolean onIsMultiPane() {
|
|
return isXLargeTablet(this);
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
@Override
|
|
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
|
|
public void onBuildHeaders(List<Header> target) {
|
|
//loadHeadersFromResource(R.xml.pref_headers, target);
|
|
}
|
|
|
|
/**
|
|
* This method stops fragment injection in malicious applications.
|
|
* Make sure to deny any unknown fragments here.
|
|
*/
|
|
protected boolean isValidFragment(String fragmentName) {
|
|
return PreferenceFragment.class.getName().equals(fragmentName)
|
|
|| GeneralPreferenceFragment.class.getName().equals(fragmentName);
|
|
}
|
|
|
|
/**
|
|
* This fragment shows general preferences only. It is used when the
|
|
* activity is showing a two-pane mainmenu UI.
|
|
*/
|
|
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
|
|
public static class GeneralPreferenceFragment extends PreferenceFragment {
|
|
@Override
|
|
public void onCreate(Bundle savedInstanceState) {
|
|
super.onCreate(savedInstanceState);
|
|
addPreferencesFromResource(R.xml.pref_general);
|
|
setHasOptionsMenu(true);
|
|
|
|
// Bind the summaries of EditText/List/Dialog/Ringtone preferences
|
|
// to their values. When their values change, their summaries are
|
|
// updated to reflect the new value, per the Android Design
|
|
// guidelines.
|
|
//bindPreferenceSummaryToValue(findPreference("pref_api_base"));
|
|
bindPreferenceSummaryToValue(findPreference("pref_theme"));
|
|
}
|
|
|
|
@Override
|
|
public boolean onOptionsItemSelected(MenuItem item) {
|
|
int id = item.getItemId();
|
|
if (id == android.R.id.home) {
|
|
startActivity(new Intent(getActivity(), SettingsActivity.class));
|
|
return true;
|
|
}
|
|
return super.onOptionsItemSelected(item);
|
|
}
|
|
|
|
@Override
|
|
public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen,
|
|
Preference preference) {
|
|
// String key = preference.getKey();
|
|
// if ("pref_api_base".equals(key)) {
|
|
// Intent intentServer = new Intent(preference.getContext(), SelectServerActivity.class);
|
|
// startActivity(intentServer);
|
|
// return true;
|
|
// }
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public void onResume() {
|
|
setPreferenceScreen(null);
|
|
addPreferencesFromResource(R.xml.pref_general);
|
|
//bindPreferenceSummaryToValue(findPreference("pref_api_base"));
|
|
|
|
super.onResume();
|
|
}
|
|
}
|
|
|
|
} |