aboutsummaryrefslogtreecommitdiffhomepage
path: root/app/src/main
diff options
context:
space:
mode:
authorMarvin Borner2018-08-29 21:18:05 +0200
committerMarvin Borner2018-08-29 21:18:05 +0200
commit35f01b107d206f237763b10ebd6d5c25c71d5610 (patch)
tree86564a6ca64a5da447faa7f23ba37a8add521a1e /app/src/main
parent7e03dd99cb3f84f3d176ba44fcce84e551dc3c03 (diff)
Added settings activity for general and account settings
Diffstat (limited to 'app/src/main')
-rw-r--r--app/src/main/AndroidManifest.xml11
-rw-r--r--app/src/main/java/com/no_name/no_name/SettingsActivity.kt205
-rw-r--r--app/src/main/res/drawable/ic_account_circle_black_24dp.xml9
-rw-r--r--app/src/main/res/drawable/ic_settings_black_24dp.xml9
-rw-r--r--app/src/main/res/values/strings.xml27
-rw-r--r--app/src/main/res/xml/pref_general.xml11
-rw-r--r--app/src/main/res/xml/pref_headers.xml15
7 files changed, 280 insertions, 7 deletions
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 59ff422..8e1bc19 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -16,11 +16,9 @@
android:networkSecurityConfig="@xml/network_security_config"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
- android:theme="@style/AppTheme"
+ android:theme="@style/AppTheme.NoActionBar"
tools:replace="android:allowBackup">
- <activity
- android:name=".RoutingActivity"
- android:label="@string/loading">
+ <activity android:name=".RoutingActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
@@ -29,13 +27,12 @@
</activity>
<activity
android:name=".MainActivity"
- android:label="@string/app_name"
- android:theme="@style/AppTheme.NoActionBar" />
+ android:label="@string/app_name" />
<activity
android:name=".LoginActivity"
android:label="@string/title_activity_login" />
<activity
- android:name=".AppSettingsActivity"
+ android:name=".SettingsActivity"
android:label="@string/title_activity_app_settings"
android:parentActivityName=".MainActivity">
<meta-data
diff --git a/app/src/main/java/com/no_name/no_name/SettingsActivity.kt b/app/src/main/java/com/no_name/no_name/SettingsActivity.kt
new file mode 100644
index 0000000..11214d5
--- /dev/null
+++ b/app/src/main/java/com/no_name/no_name/SettingsActivity.kt
@@ -0,0 +1,205 @@
+package com.no_name.no_name
+
+import android.annotation.TargetApi
+import android.content.Context
+import android.content.Intent
+import android.content.res.Configuration
+import android.os.Build
+import android.os.Bundle
+import android.preference.*
+import android.support.v4.app.NavUtils
+import android.view.MenuItem
+import com.afollestad.aesthetic.Aesthetic
+import com.no_name.no_name.Util.ThemeUtil
+
+/**
+ * A [PreferenceActivity] that presents a set of application settings. On
+ * handset devices, settings are presented as a single list. On tablets,
+ * settings are split by category, with category headers shown to the left of
+ * the list of settings.
+ *
+ * See [Android Design: Settings](http://developer.android.com/design/patterns/settings.html)
+ * for design guidelines and the [Settings API Guide](http://developer.android.com/guide/topics/ui/settings.html)
+ * for more information on developing a Settings UI.
+ */
+class SettingsActivity : PreferenceActivity() {
+
+ override fun onCreate(savedInstanceState: Bundle?) {
+ Aesthetic.attach(this)
+ super.onCreate(savedInstanceState)
+ setupActionBar()
+ (ThemeUtil(this)::setActivityTheme)(true)
+ }
+
+ override fun onResume() {
+ super.onResume()
+ Aesthetic.resume(this)
+ }
+
+ override fun onPause() {
+ Aesthetic.pause(this)
+ super.onPause()
+ }
+
+ /**
+ * Set up the [android.app.ActionBar], if the API is available.
+ */
+ private fun setupActionBar() {
+ actionBar?.setDisplayHomeAsUpEnabled(true)
+ }
+
+ /**
+ * Listener for menu item selector
+ */
+ override fun onMenuItemSelected(featureId: Int, item: MenuItem): Boolean {
+ val id = item.itemId
+ if (id == android.R.id.home) {
+ if (!super.onMenuItemSelected(featureId, item)) {
+ NavUtils.navigateUpFromSameTask(this)
+ }
+ return true
+ }
+ return super.onMenuItemSelected(featureId, item)
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ override fun onIsMultiPane(): Boolean {
+ return isXLargeTablet(this)
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ @TargetApi(Build.VERSION_CODES.HONEYCOMB)
+ override fun onBuildHeaders(target: List<PreferenceActivity.Header>) {
+ loadHeadersFromResource(R.xml.pref_headers, target)
+ }
+
+ /**
+ * This method stops fragment injection in malicious applications.
+ * Make sure to deny any unknown fragments here.
+ */
+ override fun isValidFragment(fragmentName: String): Boolean {
+ return PreferenceFragment::class.java.name == fragmentName
+ || GeneralPreferenceFragment::class.java.name == fragmentName
+ || AccountPreferenceFragment::class.java.name == fragmentName
+ }
+
+ /**
+ * This fragment shows general preferences only. It is used when the
+ * activity is showing a two-pane settings UI.
+ */
+ @TargetApi(Build.VERSION_CODES.HONEYCOMB)
+ class GeneralPreferenceFragment : PreferenceFragment() {
+ override fun onCreate(savedInstanceState: Bundle?) {
+ super.onCreate(savedInstanceState)
+ addPreferencesFromResource(R.xml.pref_general)
+ setHasOptionsMenu(true)
+ }
+
+ /**
+ * Listener for action bar option selector
+ */
+ override fun onOptionsItemSelected(item: MenuItem): Boolean {
+ val id = item.itemId
+ if (id == android.R.id.home) {
+ startActivity(Intent(activity, SettingsActivity::class.java))
+ return true
+ }
+ return super.onOptionsItemSelected(item)
+ }
+ }
+
+ /**
+ * This fragment shows general preferences only. It is used when the
+ * activity is showing a two-pane settings UI.
+ */
+ @TargetApi(Build.VERSION_CODES.HONEYCOMB)
+ class AccountPreferenceFragment : PreferenceFragment() {
+ override fun onCreate(savedInstanceState: Bundle?) {
+ super.onCreate(savedInstanceState)
+ addPreferencesFromResource(R.xml.pref_account)
+ 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("example_list"))
+ }
+
+ /**
+ * Listener for action bar option selector
+ */
+ override fun onOptionsItemSelected(item: MenuItem): Boolean {
+ val id = item.itemId
+ if (id == android.R.id.home) {
+ startActivity(Intent(activity, SettingsActivity::class.java))
+ return true
+ }
+ return super.onOptionsItemSelected(item)
+ }
+ }
+
+ companion object {
+
+ /**
+ * A preference value change listener that updates the preference's summary
+ * to reflect its new value.
+ */
+ private val sBindPreferenceSummaryToValueListener = Preference.OnPreferenceChangeListener { preference, value ->
+ val stringValue = value.toString()
+
+ if (preference is ListPreference) {
+ // For list preferences, look up the correct display value in
+ // the preference's 'entries' list.
+ val listPreference = preference
+ val index = listPreference.findIndexOfValue(stringValue)
+
+ // Set the summary to reflect the new value.
+ preference.setSummary(
+ if (index >= 0)
+ listPreference.entries[index]
+ else
+ null)
+
+ } else {
+ // For all other preferences, set the summary to the value's
+ // simple string representation.
+ preference.summary = stringValue
+ }
+ true
+ }
+
+ /**
+ * Helper method to determine if the device has an extra-large screen. For
+ * example, 10" tablets are extra-large.
+ */
+ private fun isXLargeTablet(context: Context): Boolean {
+ return context.resources.configuration.screenLayout and 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 fun bindPreferenceSummaryToValue(preference: Preference) {
+ // Set the listener to watch for value changes.
+ preference.onPreferenceChangeListener = sBindPreferenceSummaryToValueListener
+
+ // Trigger the listener immediately with the preference's
+ // current value.
+ sBindPreferenceSummaryToValueListener.onPreferenceChange(preference,
+ PreferenceManager
+ .getDefaultSharedPreferences(preference.context)
+ .getString(preference.key, ""))
+ }
+ }
+}
diff --git a/app/src/main/res/drawable/ic_account_circle_black_24dp.xml b/app/src/main/res/drawable/ic_account_circle_black_24dp.xml
new file mode 100644
index 0000000..6e8924c
--- /dev/null
+++ b/app/src/main/res/drawable/ic_account_circle_black_24dp.xml
@@ -0,0 +1,9 @@
+<vector xmlns:android="http://schemas.android.com/apk/res/android"
+ android:width="24dp"
+ android:height="24dp"
+ android:viewportHeight="24.0"
+ android:viewportWidth="24.0">
+ <path
+ android:fillColor="#FF000000"
+ android:pathData="M12,2C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2zM12,5c1.66,0 3,1.34 3,3s-1.34,3 -3,3 -3,-1.34 -3,-3 1.34,-3 3,-3zM12,19.2c-2.5,0 -4.71,-1.28 -6,-3.22 0.03,-1.99 4,-3.08 6,-3.08 1.99,0 5.97,1.09 6,3.08 -1.29,1.94 -3.5,3.22 -6,3.22z" />
+</vector>
diff --git a/app/src/main/res/drawable/ic_settings_black_24dp.xml b/app/src/main/res/drawable/ic_settings_black_24dp.xml
new file mode 100644
index 0000000..6d0c6e6
--- /dev/null
+++ b/app/src/main/res/drawable/ic_settings_black_24dp.xml
@@ -0,0 +1,9 @@
+<vector xmlns:android="http://schemas.android.com/apk/res/android"
+ android:width="24dp"
+ android:height="24dp"
+ android:viewportHeight="24.0"
+ android:viewportWidth="24.0">
+ <path
+ android:fillColor="#FF000000"
+ android:pathData="M19.43,12.98c0.04,-0.32 0.07,-0.64 0.07,-0.98s-0.03,-0.66 -0.07,-0.98l2.11,-1.65c0.19,-0.15 0.24,-0.42 0.12,-0.64l-2,-3.46c-0.12,-0.22 -0.39,-0.3 -0.61,-0.22l-2.49,1c-0.52,-0.4 -1.08,-0.73 -1.69,-0.98l-0.38,-2.65C14.46,2.18 14.25,2 14,2h-4c-0.25,0 -0.46,0.18 -0.49,0.42l-0.38,2.65c-0.61,0.25 -1.17,0.59 -1.69,0.98l-2.49,-1c-0.23,-0.09 -0.49,0 -0.61,0.22l-2,3.46c-0.13,0.22 -0.07,0.49 0.12,0.64l2.11,1.65c-0.04,0.32 -0.07,0.65 -0.07,0.98s0.03,0.66 0.07,0.98l-2.11,1.65c-0.19,0.15 -0.24,0.42 -0.12,0.64l2,3.46c0.12,0.22 0.39,0.3 0.61,0.22l2.49,-1c0.52,0.4 1.08,0.73 1.69,0.98l0.38,2.65c0.03,0.24 0.24,0.42 0.49,0.42h4c0.25,0 0.46,-0.18 0.49,-0.42l0.38,-2.65c0.61,-0.25 1.17,-0.59 1.69,-0.98l2.49,1c0.23,0.09 0.49,0 0.61,-0.22l2,-3.46c0.12,-0.22 0.07,-0.49 -0.12,-0.64l-2.11,-1.65zM12,15.5c-1.93,0 -3.5,-1.57 -3.5,-3.5s1.57,-3.5 3.5,-3.5 3.5,1.57 3.5,3.5 -1.57,3.5 -3.5,3.5z" />
+</vector>
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index 4840b69..d79ff49 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -16,4 +16,31 @@
completions."
</string>
<string name="loading">Loading...</string>
+ <string name="title_activity_app_settings">App Settings</string>
+
+ <!-- Strings related to Settings -->
+
+ <!-- Example General settings -->
+ <string name="pref_header_general">General</string>
+ <string name="pref_header_account">Account</string>
+
+ <string name="pref_title_dark_theme">Enable Dark theme</string>
+ <string name="pref_description_dark_theme_on">Theme for nights or dark-theme lovers</string>
+ <string name="pref_description_dark_theme_off">Theme for days or light-theme lovers</string>
+
+ <string name="pref_title_username">Username</string>
+ <string name="pref_default_username">John Doe</string>
+
+ <!--<string name="pref_title_add_friends_to_messages">Add friends to messages</string>
+ <string-array name="pref_example_list_titles">
+ <item>Always</item>
+ <item>When possible</item>
+ <item>Never</item>
+ </string-array>
+ <string-array name="pref_example_list_values">
+ <item>1</item>
+ <item>0</item>
+ <item>-1</item>
+ </string-array>-->
+
</resources>
diff --git a/app/src/main/res/xml/pref_general.xml b/app/src/main/res/xml/pref_general.xml
new file mode 100644
index 0000000..9016d00
--- /dev/null
+++ b/app/src/main/res/xml/pref_general.xml
@@ -0,0 +1,11 @@
+<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
+
+ <SwitchPreference
+ android:id="@+id/dark_theme_switch_button"
+ android:defaultValue="true"
+ android:key="dark_theme_switch"
+ android:summaryOff="@string/pref_description_dark_theme_off"
+ android:summaryOn="@string/pref_description_dark_theme_on"
+ android:title="@string/pref_title_dark_theme" />
+
+</PreferenceScreen>
diff --git a/app/src/main/res/xml/pref_headers.xml b/app/src/main/res/xml/pref_headers.xml
new file mode 100644
index 0000000..e17fe58
--- /dev/null
+++ b/app/src/main/res/xml/pref_headers.xml
@@ -0,0 +1,15 @@
+<preference-headers xmlns:android="http://schemas.android.com/apk/res/android">
+
+ <!-- These settings headers are only used on tablets. -->
+
+ <header
+ android:fragment="com.no_name.no_name.SettingsActivity$GeneralPreferenceFragment"
+ android:icon="@drawable/ic_settings_black_24dp"
+ android:title="@string/pref_header_general" />
+
+ <header
+ android:fragment="com.no_name.no_name.SettingsActivity$AccountPreferenceFragment"
+ android:icon="@drawable/ic_account_circle_black_24dp"
+ android:title="@string/pref_header_account" />
+
+</preference-headers>