Compare commits
	
		
			23 Commits
		
	
	
		
			v172110299
			...
			v172202040
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| f0b073e74d | |||
| ca5186d20a | |||
| 78d5744139 | |||
| b2609554e6 | |||
| 5db312bbb8 | |||
| 7592ab512b | |||
| 000b346529 | |||
| 1bb975c584 | |||
| 69aaa323e2 | |||
| cedb207eca | |||
|  | b9e91f30ef | ||
| 6a8c2d7fcd | |||
| 60a908a44a | |||
| 6b887ff74b | |||
| 721a15ec21 | |||
| a2933ac763 | |||
| e1efe9643c | |||
| 90242ae801 | |||
| 0c88f33981 | |||
|  | 5e13a8f20f | ||
| ca4b7ada97 | |||
|  | 62a82b01b8 | ||
| 1994fa2f7d | 
| @@ -44,6 +44,8 @@ | |||||||
|  |  | ||||||
| - Closing #236. New sources can be added in Selfoss 2.19. | - Closing #236. New sources can be added in Selfoss 2.19. | ||||||
|  |  | ||||||
|  | - Dropped support for android 4, the last version supporting it is v1721030811 | ||||||
|  |  | ||||||
| **1.6.x** | **1.6.x** | ||||||
|  |  | ||||||
| - Handling hidden tags. | - Handling hidden tags. | ||||||
|   | |||||||
| @@ -32,6 +32,9 @@ apply plugin: 'kotlin-kapt' | |||||||
|  |  | ||||||
| android { | android { | ||||||
|     compileOptions { |     compileOptions { | ||||||
|  |         // Flag to enable support for the new language APIs | ||||||
|  |         coreLibraryDesugaringEnabled true | ||||||
|  |  | ||||||
|         sourceCompatibility JavaVersion.VERSION_1_8 |         sourceCompatibility JavaVersion.VERSION_1_8 | ||||||
|         targetCompatibility JavaVersion.VERSION_1_8 |         targetCompatibility JavaVersion.VERSION_1_8 | ||||||
|     } |     } | ||||||
| @@ -42,7 +45,7 @@ android { | |||||||
|     } |     } | ||||||
|     defaultConfig { |     defaultConfig { | ||||||
|         applicationId "apps.amine.bou.readerforselfoss" |         applicationId "apps.amine.bou.readerforselfoss" | ||||||
|         minSdkVersion 16 |         minSdkVersion 21 | ||||||
|         targetSdkVersion 31 |         targetSdkVersion 31 | ||||||
|         versionCode versionCodeFromGit() |         versionCode versionCodeFromGit() | ||||||
|         versionName versionNameFromGit() |         versionName versionNameFromGit() | ||||||
| @@ -91,6 +94,8 @@ android { | |||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|  |     implementation 'androidx.preference:preference-ktx:1.1.1' | ||||||
|  |  | ||||||
|     // Testing |     // Testing | ||||||
|     androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0-alpha02' |     androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0-alpha02' | ||||||
|     androidTestImplementation 'androidx.test:runner:1.3.1-alpha02' |     androidTestImplementation 'androidx.test:runner:1.3.1-alpha02' | ||||||
| @@ -99,39 +104,41 @@ dependencies { | |||||||
|     // Espresso-intents for validation and stubbing of Intents |     // Espresso-intents for validation and stubbing of Intents | ||||||
|     androidTestImplementation 'androidx.test.espresso:espresso-intents:3.4.0-alpha02' |     androidTestImplementation 'androidx.test.espresso:espresso-intents:3.4.0-alpha02' | ||||||
|     implementation fileTree(include: ['*.jar'], dir: 'libs') |     implementation fileTree(include: ['*.jar'], dir: 'libs') | ||||||
|     implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" |  | ||||||
|     // Android Support |     // Android Support | ||||||
|     implementation "androidx.appcompat:appcompat:1.4.0-beta01" |     implementation 'androidx.appcompat:appcompat:1.4.1' | ||||||
|     implementation 'com.google.android.material:material:1.5.0-alpha04' |     implementation 'com.google.android.material:material:1.5.0' | ||||||
|     implementation 'androidx.recyclerview:recyclerview:1.3.0-alpha01' |     implementation 'androidx.recyclerview:recyclerview:1.3.0-alpha01' | ||||||
|     implementation "androidx.legacy:legacy-support-v4:$android_version" |     implementation "androidx.legacy:legacy-support-v4:$android_version" | ||||||
|     implementation 'androidx.vectordrawable:vectordrawable:1.2.0-alpha02' |     implementation 'androidx.vectordrawable:vectordrawable:1.2.0-alpha02' | ||||||
|     implementation "androidx.browser:browser:1.3.0" |     implementation 'androidx.browser:browser:1.4.0' | ||||||
|     implementation "androidx.cardview:cardview:$android_version" |     implementation "androidx.cardview:cardview:$android_version" | ||||||
|     implementation "androidx.annotation:annotation:1.2.0" |     implementation 'androidx.annotation:annotation:1.3.0' | ||||||
|     implementation 'androidx.work:work-runtime-ktx:2.7.0' |     implementation 'androidx.work:work-runtime-ktx:2.7.1' | ||||||
|     implementation 'androidx.constraintlayout:constraintlayout:2.1.1' |     implementation 'androidx.constraintlayout:constraintlayout:2.1.3' | ||||||
|     implementation 'org.jsoup:jsoup:1.13.1' |     implementation 'org.jsoup:jsoup:1.14.3' | ||||||
|  |  | ||||||
|  |     coreLibraryDesugaring("com.android.tools:desugar_jdk_libs:1.1.5") | ||||||
|  |  | ||||||
|     //multidex |     //multidex | ||||||
|     implementation 'androidx.multidex:multidex:2.0.1' |     implementation 'androidx.multidex:multidex:2.0.1' | ||||||
|  |  | ||||||
|     // About |     // About | ||||||
|     implementation('com.mikepenz:aboutlibraries:6.2.0@aar') { |     implementation 'com.mikepenz:aboutlibraries-core:8.9.4' | ||||||
|         transitive = true |     implementation 'com.mikepenz:aboutlibraries:8.9.4' | ||||||
|     } |     implementation "com.mikepenz:aboutlibraries-definitions:8.9.4" | ||||||
|  |  | ||||||
|     // Async |     // Async | ||||||
|     implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:1.5.2' |     implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:1.6.0' | ||||||
|  |  | ||||||
|     // Retrofit + http logging + okhttp |     // Retrofit + http logging + okhttp | ||||||
|     implementation 'com.squareup.retrofit2:retrofit:2.9.0' |     implementation 'com.squareup.retrofit2:retrofit:2.9.0' | ||||||
|     implementation 'com.squareup.okhttp3:logging-interceptor:4.9.1' |     implementation 'com.squareup.okhttp3:logging-interceptor:5.0.0-alpha.3' | ||||||
|     implementation 'com.squareup.retrofit2:converter-gson:2.9.0' |     implementation 'com.squareup.retrofit2:converter-gson:2.9.0' | ||||||
|     implementation 'com.burgstaller:okhttp-digest:2.5' |     implementation 'com.burgstaller:okhttp-digest:2.5' | ||||||
|  |  | ||||||
|     // Material-ish things |     // Material-ish things | ||||||
|     implementation 'com.ashokvarma.android:bottom-navigation-bar:2.1.0' |     implementation 'com.ashokvarma.android:bottom-navigation-bar:2.2.0' | ||||||
|     implementation 'com.amulyakhare:com.amulyakhare.textdrawable:1.0.1' |     implementation 'com.amulyakhare:com.amulyakhare.textdrawable:1.0.1' | ||||||
|  |  | ||||||
|     // glide |     // glide | ||||||
| @@ -139,23 +146,24 @@ dependencies { | |||||||
|     implementation 'com.github.bumptech.glide:okhttp3-integration:4.1.1' |     implementation 'com.github.bumptech.glide:okhttp3-integration:4.1.1' | ||||||
|  |  | ||||||
|     // Drawer |     // Drawer | ||||||
|     implementation 'com.mikepenz:materialdrawer:8.4.4' |     implementation 'com.mikepenz:materialdrawer:8.4.5' | ||||||
|  |  | ||||||
|     // Themes |     // Themes | ||||||
|     implementation 'com.52inc:scoops:1.0.0' |     implementation 'com.52inc:scoops:1.0.0' | ||||||
|     implementation 'com.jaredrummler:colorpicker:1.0.2' |     implementation 'com.jaredrummler:colorpicker:1.1.0' | ||||||
|     implementation 'com.github.rubensousa:floatingtoolbar:1.5.1' |     implementation 'com.github.rubensousa:floatingtoolbar:1.5.1' | ||||||
|  |  | ||||||
|     // Pager |     // Pager | ||||||
|     implementation 'me.relex:circleindicator:2.0.0@aar' |     implementation 'me.relex:circleindicator:2.1.6' | ||||||
|  |     implementation "androidx.viewpager2:viewpager2:1.1.0-beta01" | ||||||
|  |  | ||||||
|     //PhotoView |     //PhotoView | ||||||
|     implementation 'com.github.chrisbanes:PhotoView:2.0.0' |     implementation 'com.github.chrisbanes:PhotoView:2.3.0' | ||||||
|  |  | ||||||
|     implementation 'androidx.core:core-ktx:1.7.0-rc01' |     implementation 'androidx.core:core-ktx:1.7.0' | ||||||
|  |  | ||||||
|     implementation "androidx.lifecycle:lifecycle-livedata-ktx:2.4.0-rc01" |     implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.4.0' | ||||||
|     implementation "androidx.lifecycle:lifecycle-common-java8:2.4.0-rc01" |     implementation 'androidx.lifecycle:lifecycle-common-java8:2.4.0' | ||||||
|  |  | ||||||
|     implementation "androidx.room:room-ktx:2.4.0-beta01" |     implementation "androidx.room:room-ktx:2.4.0-beta01" | ||||||
|     kapt "androidx.room:room-compiler:2.4.0-beta01" |     kapt "androidx.room:room-compiler:2.4.0-beta01" | ||||||
|   | |||||||
| @@ -0,0 +1,31 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss | ||||||
|  |  | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.parseDate | ||||||
|  | import org.junit.Test | ||||||
|  |  | ||||||
|  | class DateUtilsTest { | ||||||
|  |  | ||||||
|  |     @Test | ||||||
|  |     fun parseDateV4() { | ||||||
|  |  | ||||||
|  |         Config.apiVersion = 4 | ||||||
|  |         val dateString = "2013-04-07T13:43:00+01:00" | ||||||
|  |  | ||||||
|  |         val milliseconds = parseDate(dateString).toEpochMilli() | ||||||
|  |         val correctMilliseconds : Long = 1365338580000 | ||||||
|  |  | ||||||
|  |         assert(milliseconds == correctMilliseconds) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Test | ||||||
|  |     fun parseDateV1() { | ||||||
|  |         Config.apiVersion = 0 | ||||||
|  |         val dateString = "2013-04-07 13:43:00" | ||||||
|  |  | ||||||
|  |         val milliseconds = parseDate(dateString).toEpochMilli() | ||||||
|  |         val correctMilliseconds = 1365342180000 | ||||||
|  |  | ||||||
|  |         assert(milliseconds == correctMilliseconds) | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -2,9 +2,8 @@ package apps.amine.bou.readerforselfoss | |||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.os.Build |  | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import androidx.preference.PreferenceManager | ||||||
| import androidx.constraintlayout.widget.ConstraintLayout | import androidx.constraintlayout.widget.ConstraintLayout | ||||||
| import androidx.appcompat.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import android.view.View | import android.view.View | ||||||
| @@ -50,38 +49,24 @@ class AddSourceActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|         val scoop = Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|         scoop.bind(this, Toppings.PRIMARY.value, binding.toolbar) |         scoop.bind(this, Toppings.PRIMARY.value, binding.toolbar) | ||||||
|         if  (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { |         scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         val drawable = binding.nameInput.background |         val drawable = binding.nameInput.background | ||||||
|         drawable.setColorFilter(appColors.colorAccent, PorterDuff.Mode.SRC_ATOP) |         drawable.setTint(appColors.colorAccent) | ||||||
|  |  | ||||||
|  |  | ||||||
|         // TODO: clean |         // TODO: clean | ||||||
|         if(Build.VERSION.SDK_INT > 16) { |         binding.nameInput.background = drawable | ||||||
|             binding.nameInput.background = drawable |  | ||||||
|         } else{ |  | ||||||
|             binding.nameInput.setBackgroundDrawable(drawable) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         val drawable1 = binding.sourceUri.background |         val drawable1 = binding.sourceUri.background | ||||||
|         drawable1.setColorFilter(appColors.colorAccent, PorterDuff.Mode.SRC_ATOP) |         drawable1.setTint(appColors.colorAccent) | ||||||
|  |  | ||||||
|         if(Build.VERSION.SDK_INT > 16) { |         binding.sourceUri.background = drawable1 | ||||||
|             binding.sourceUri.background = drawable1 |  | ||||||
|         } else{ |  | ||||||
|             binding.sourceUri.setBackgroundDrawable(drawable1) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         val drawable2 = binding.tags.background |         val drawable2 = binding.tags.background | ||||||
|         drawable2.setColorFilter(appColors.colorAccent, PorterDuff.Mode.SRC_ATOP) |         drawable2.setTint(appColors.colorAccent) | ||||||
|  |  | ||||||
|         if(Build.VERSION.SDK_INT > 16) { |         binding.tags.background = drawable2 | ||||||
|             binding.tags.background = drawable2 |  | ||||||
|         } else{ |  | ||||||
|             binding.tags.setBackgroundDrawable(drawable2) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         setSupportActionBar(binding.toolbar) |         setSupportActionBar(binding.toolbar) | ||||||
|         supportActionBar?.setDisplayHomeAsUpEnabled(true) |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
|   | |||||||
| @@ -7,9 +7,8 @@ import android.graphics.Color | |||||||
| import android.graphics.drawable.Drawable | import android.graphics.drawable.Drawable | ||||||
| import android.graphics.drawable.GradientDrawable | import android.graphics.drawable.GradientDrawable | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import android.os.Build |  | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import androidx.preference.PreferenceManager | ||||||
| import android.view.Menu | import android.view.Menu | ||||||
| import android.view.MenuItem | import android.view.MenuItem | ||||||
| import android.view.View | import android.view.View | ||||||
| @@ -101,7 +100,7 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private var displayAllCount = false |     private var displayAllCount = false | ||||||
|     private var fullHeightCards: Boolean = false |     private var fullHeightCards: Boolean = false | ||||||
|     private var itemsNumber: Int = 200 |     private var itemsNumber: Int = 200 | ||||||
|     private var elementsShown: Int = 0 |     private var elementsShown: Int = 1 | ||||||
|     private var maybeTagFilter: Tag? = null |     private var maybeTagFilter: Tag? = null | ||||||
|     private var maybeSourceFilter: Source? = null |     private var maybeSourceFilter: Source? = null | ||||||
|     private var maybeSearchFilter: String? = null |     private var maybeSearchFilter: String? = null | ||||||
| @@ -171,8 +170,8 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         handleThemeBinding() |         handleThemeBinding() | ||||||
|  |  | ||||||
|         setSupportActionBar(binding.toolBar) |         setSupportActionBar(binding.toolBar) | ||||||
|         supportActionBar!!.setDisplayHomeAsUpEnabled(true) |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
|         supportActionBar!!.setHomeButtonEnabled(true) |         supportActionBar?.setHomeButtonEnabled(true) | ||||||
|         val mDrawerToggle = ActionBarDrawerToggle(this, binding.drawerContainer, binding.toolBar, R.string.material_drawer_open, R.string.material_drawer_close) |         val mDrawerToggle = ActionBarDrawerToggle(this, binding.drawerContainer, binding.toolBar, R.string.material_drawer_open, R.string.material_drawer_close) | ||||||
|         binding.drawerContainer.addDrawerListener(mDrawerToggle) |         binding.drawerContainer.addDrawerListener(mDrawerToggle) | ||||||
|         mDrawerToggle.syncState() |         mDrawerToggle.syncState() | ||||||
| @@ -340,20 +339,16 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private fun getApiMajorVersion() { |     private fun getApiMajorVersion() { | ||||||
|         api.apiVersion.enqueue(object : Callback<ApiVersion> { |         api.apiVersion.enqueue(object : Callback<ApiVersion> { | ||||||
|             override fun onFailure(call: Call<ApiVersion>, t: Throwable) { |             override fun onFailure(call: Call<ApiVersion>, t: Throwable) { | ||||||
|                 if (apiVersionMajor >= 4) { |                 Config.apiVersion = apiVersionMajor | ||||||
|                     Config.dateTimeFormatter = "yyyy-MM-dd'T'HH:mm:ssXXX" |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             override fun onResponse(call: Call<ApiVersion>, response: Response<ApiVersion>) { |             override fun onResponse(call: Call<ApiVersion>, response: Response<ApiVersion>) { | ||||||
|                 if(response.body() != null) { |                 if(response.body() != null) { | ||||||
|                     val version = response.body() as ApiVersion |                     val version = response.body() as ApiVersion | ||||||
|                     apiVersionMajor = version.getApiMajorVersion() |                     apiVersionMajor = version.getApiMajorVersion() | ||||||
|                     sharedPref.edit().putInt("apiVersionMajor", apiVersionMajor).commit() |                     sharedPref.edit().putInt("apiVersionMajor", apiVersionMajor).apply() | ||||||
|  |  | ||||||
|                     if (apiVersionMajor >= 4) { |                     Config.apiVersion = apiVersionMajor | ||||||
|                         Config.dateTimeFormatter = "yyyy-MM-dd'T'HH:mm:ssXXX" |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }) |         }) | ||||||
| @@ -440,9 +435,7 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private fun handleThemeBinding() { |     private fun handleThemeBinding() { | ||||||
|         val scoop = Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|         scoop.bind(this, Toppings.PRIMARY.value, binding.toolBar) |         scoop.bind(this, Toppings.PRIMARY.value, binding.toolBar) | ||||||
|         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { |         scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleThemeUpdate() { |     private fun handleThemeUpdate() { | ||||||
| @@ -450,9 +443,7 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         val scoop = Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|         scoop.update(Toppings.PRIMARY.value, appColors.colorPrimary) |         scoop.update(Toppings.PRIMARY.value, appColors.colorPrimary) | ||||||
|  |  | ||||||
|         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { |         scoop.update(Toppings.PRIMARY_DARK.value, appColors.colorPrimaryDark) | ||||||
|             scoop.update(Toppings.PRIMARY_DARK.value, appColors.colorPrimaryDark) |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleDrawer() { |     private fun handleDrawer() { | ||||||
| @@ -514,13 +505,7 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                 iconRes = R.drawable.ic_settings_black_24dp |                 iconRes = R.drawable.ic_settings_black_24dp | ||||||
|                 isIconTinted = true |                 isIconTinted = true | ||||||
|                 onDrawerItemClickListener = { _, _, _ -> |                 onDrawerItemClickListener = { _, _, _ -> | ||||||
|                     startActivityForResult( |                     startActivity(Intent(this@HomeActivity, SettingsActivity::class.java)) | ||||||
|                         Intent( |  | ||||||
|                             this@HomeActivity, |  | ||||||
|                             SettingsActivity::class.java |  | ||||||
|                         ), |  | ||||||
|                         MENU_PREFERENCES |  | ||||||
|                     ) |  | ||||||
|                     false |                     false | ||||||
|                 } |                 } | ||||||
|             }) |             }) | ||||||
|   | |||||||
| @@ -3,8 +3,9 @@ package apps.amine.bou.readerforselfoss | |||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.view.MenuItem | import android.view.MenuItem | ||||||
| import androidx.appcompat.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import androidx.fragment.app.FragmentManager | import androidx.fragment.app.Fragment | ||||||
| import androidx.fragment.app.FragmentStatePagerAdapter | import androidx.fragment.app.FragmentActivity | ||||||
|  | import androidx.viewpager2.adapter.FragmentStateAdapter | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ActivityImageBinding | import apps.amine.bou.readerforselfoss.databinding.ActivityImageBinding | ||||||
| import apps.amine.bou.readerforselfoss.fragments.ImageFragment | import apps.amine.bou.readerforselfoss.fragments.ImageFragment | ||||||
|  |  | ||||||
| @@ -28,8 +29,8 @@ class ImageActivity : AppCompatActivity() { | |||||||
|         allImages = intent.getStringArrayListExtra("allImages") as ArrayList<String> |         allImages = intent.getStringArrayListExtra("allImages") as ArrayList<String> | ||||||
|         position = intent.getIntExtra("position", 0) |         position = intent.getIntExtra("position", 0) | ||||||
|  |  | ||||||
|         binding.pager.adapter = ScreenSlidePagerAdapter(supportFragmentManager) |         binding.pager.adapter = ScreenSlidePagerAdapter(this) | ||||||
|         binding.pager.currentItem = position |         binding.pager.setCurrentItem(position, false) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun onOptionsItemSelected(item: MenuItem): Boolean { |     override fun onOptionsItemSelected(item: MenuItem): Boolean { | ||||||
| @@ -43,14 +44,10 @@ class ImageActivity : AppCompatActivity() { | |||||||
|         return super.onOptionsItemSelected(item) |         return super.onOptionsItemSelected(item) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private inner class ScreenSlidePagerAdapter(fm: FragmentManager) : FragmentStatePagerAdapter(fm, FragmentStatePagerAdapter.BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT) { |     private inner class ScreenSlidePagerAdapter(fa: FragmentActivity) : FragmentStateAdapter(fa) { | ||||||
|  |  | ||||||
|         override fun getCount(): Int { |         override fun getItemCount(): Int = allImages.size | ||||||
|             return allImages.size |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         override fun getItem(position: Int): ImageFragment { |         override fun createFragment(position: Int): Fragment = ImageFragment.newInstance(allImages[position]) | ||||||
|             return ImageFragment.newInstance(allImages[position]) |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -14,15 +14,13 @@ import android.view.MenuItem | |||||||
| import android.view.View | import android.view.View | ||||||
| import android.view.inputmethod.EditorInfo | import android.view.inputmethod.EditorInfo | ||||||
| import android.widget.TextView | import android.widget.TextView | ||||||
| import android.widget.Toast | import androidx.preference.PreferenceManager | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ActivityLoginBinding | import apps.amine.bou.readerforselfoss.databinding.ActivityLoginBinding | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config |  | ||||||
| import apps.amine.bou.readerforselfoss.utils.isBaseUrlValid | import apps.amine.bou.readerforselfoss.utils.isBaseUrlValid | ||||||
| import apps.amine.bou.readerforselfoss.utils.network.isNetworkAccessible | import apps.amine.bou.readerforselfoss.utils.network.isNetworkAccessible | ||||||
| import com.mikepenz.aboutlibraries.Libs |  | ||||||
| import com.mikepenz.aboutlibraries.LibsBuilder | import com.mikepenz.aboutlibraries.LibsBuilder | ||||||
| import retrofit2.Call | import retrofit2.Call | ||||||
| import retrofit2.Callback | import retrofit2.Callback | ||||||
| @@ -54,7 +52,7 @@ class LoginActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|         handleBaseUrlFail() |         handleBaseUrlFail() | ||||||
|  |  | ||||||
|         settings = getSharedPreferences(Config.settingsName, Context.MODE_PRIVATE) |         settings = PreferenceManager.getDefaultSharedPreferences(applicationContext) | ||||||
|         userIdentifier = settings.getString("unique_id", "")!! |         userIdentifier = settings.getString("unique_id", "")!! | ||||||
|  |  | ||||||
|         editor = settings.edit() |         editor = settings.edit() | ||||||
| @@ -91,16 +89,16 @@ class LoginActivity : AppCompatActivity() { | |||||||
|             isWithLogin = !isWithLogin |             isWithLogin = !isWithLogin | ||||||
|             val visi: Int = if (b) View.VISIBLE else View.GONE |             val visi: Int = if (b) View.VISIBLE else View.GONE | ||||||
|  |  | ||||||
|             binding.loginLayout.visibility = visi |             binding.loginView.visibility = visi | ||||||
|             binding.passwordLayout.visibility = visi |             binding.passwordView.visibility = visi | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         binding.withHttpLogin.setOnCheckedChangeListener { _, b -> |         binding.withHttpLogin.setOnCheckedChangeListener { _, b -> | ||||||
|             isWithHTTPLogin = !isWithHTTPLogin |             isWithHTTPLogin = !isWithHTTPLogin | ||||||
|             val visi: Int = if (b) View.VISIBLE else View.GONE |             val visi: Int = if (b) View.VISIBLE else View.GONE | ||||||
|  |  | ||||||
|             binding.httpLoginInput.visibility = visi |             binding.httpLoginView.visibility = visi | ||||||
|             binding.httpPasswordInput.visibility = visi |             binding.httpPasswordView.visibility = visi | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -111,9 +109,8 @@ class LoginActivity : AppCompatActivity() { | |||||||
|             alertDialog.setMessage(getString(R.string.base_url_error)) |             alertDialog.setMessage(getString(R.string.base_url_error)) | ||||||
|             alertDialog.setButton( |             alertDialog.setButton( | ||||||
|                 AlertDialog.BUTTON_NEUTRAL, |                 AlertDialog.BUTTON_NEUTRAL, | ||||||
|                 "OK", |                 "OK" | ||||||
|                 { dialog, _ -> dialog.dismiss() } |             ) { dialog, _ -> dialog.dismiss() } | ||||||
|             ) |  | ||||||
|             alertDialog.show() |             alertDialog.show() | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -154,9 +151,8 @@ class LoginActivity : AppCompatActivity() { | |||||||
|                 alertDialog.setMessage(getString(R.string.text_wrong_url)) |                 alertDialog.setMessage(getString(R.string.text_wrong_url)) | ||||||
|                 alertDialog.setButton( |                 alertDialog.setButton( | ||||||
|                     AlertDialog.BUTTON_NEUTRAL, |                     AlertDialog.BUTTON_NEUTRAL, | ||||||
|                     "OK", |                     "OK" | ||||||
|                     { dialog, _ -> dialog.dismiss() } |                 ) { dialog, _ -> dialog.dismiss() } | ||||||
|                 ) |  | ||||||
|                 alertDialog.show() |                 alertDialog.show() | ||||||
|                 inValidCount = 0 |                 inValidCount = 0 | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -2,9 +2,7 @@ package apps.amine.bou.readerforselfoss | |||||||
|  |  | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager |  | ||||||
| import androidx.appcompat.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ActivityAddSourceBinding |  | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ActivityMainBinding | import apps.amine.bou.readerforselfoss.databinding.ActivityMainBinding | ||||||
|  |  | ||||||
| class MainActivity : AppCompatActivity() { | class MainActivity : AppCompatActivity() { | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import android.content.Context | |||||||
| import android.graphics.drawable.Drawable | import android.graphics.drawable.Drawable | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import android.os.Build | import android.os.Build | ||||||
| import android.preference.PreferenceManager | import androidx.preference.PreferenceManager | ||||||
| import android.widget.ImageView | import android.widget.ImageView | ||||||
| import androidx.multidex.MultiDexApplication | import androidx.multidex.MultiDexApplication | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| @@ -61,14 +61,14 @@ class MyApp : MultiDexApplication() { | |||||||
|     private fun initDrawerImageLoader() { |     private fun initDrawerImageLoader() { | ||||||
|         DrawerImageLoader.init(object : AbstractDrawerImageLoader() { |         DrawerImageLoader.init(object : AbstractDrawerImageLoader() { | ||||||
|             override fun set(imageView: ImageView, uri: Uri, placeholder: Drawable, tag: String?) { |             override fun set(imageView: ImageView, uri: Uri, placeholder: Drawable, tag: String?) { | ||||||
|                 Glide.with(imageView?.context) |                 Glide.with(imageView.context) | ||||||
|                     .loadMaybeBasicAuth(config, uri.toString()) |                     .loadMaybeBasicAuth(config, uri.toString()) | ||||||
|                     .apply(RequestOptions.fitCenterTransform().placeholder(placeholder)) |                     .apply(RequestOptions.fitCenterTransform().placeholder(placeholder)) | ||||||
|                     .into(imageView) |                     .into(imageView) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             override fun cancel(imageView: ImageView) { |             override fun cancel(imageView: ImageView) { | ||||||
|                 Glide.with(imageView?.context).clear(imageView) |                 Glide.with(imageView.context).clear(imageView) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             override fun placeholder(ctx: Context, tag: String?): Drawable { |             override fun placeholder(ctx: Context, tag: String?): Drawable { | ||||||
|   | |||||||
| @@ -3,21 +3,16 @@ package apps.amine.bou.readerforselfoss | |||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.SharedPreferences | import android.content.SharedPreferences | ||||||
| import android.graphics.Color | import android.graphics.Color | ||||||
| import android.graphics.PorterDuff |  | ||||||
| import android.graphics.PorterDuffColorFilter |  | ||||||
| import android.graphics.drawable.ColorDrawable |  | ||||||
| import android.os.Build |  | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import androidx.preference.PreferenceManager | ||||||
| import androidx.fragment.app.FragmentManager |  | ||||||
| import androidx.fragment.app.FragmentStatePagerAdapter |  | ||||||
| import androidx.core.content.ContextCompat |  | ||||||
| import androidx.viewpager.widget.ViewPager |  | ||||||
| import androidx.appcompat.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import android.view.Menu | import android.view.Menu | ||||||
| import android.view.MenuItem | import android.view.MenuItem | ||||||
| import android.view.ViewGroup | import androidx.fragment.app.Fragment | ||||||
|  | import androidx.fragment.app.FragmentActivity | ||||||
| import androidx.room.Room | import androidx.room.Room | ||||||
|  | import androidx.viewpager2.adapter.FragmentStateAdapter | ||||||
|  | import androidx.viewpager2.widget.ViewPager2 | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ActivityReaderBinding | import apps.amine.bou.readerforselfoss.databinding.ActivityReaderBinding | ||||||
| @@ -28,18 +23,17 @@ import apps.amine.bou.readerforselfoss.persistence.migrations.MIGRATION_2_3 | |||||||
| import apps.amine.bou.readerforselfoss.persistence.migrations.MIGRATION_3_4 | import apps.amine.bou.readerforselfoss.persistence.migrations.MIGRATION_3_4 | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
| import apps.amine.bou.readerforselfoss.themes.Toppings | import apps.amine.bou.readerforselfoss.themes.Toppings | ||||||
| import apps.amine.bou.readerforselfoss.transformers.DepthPageTransformer |  | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| import apps.amine.bou.readerforselfoss.utils.SharedItems | import apps.amine.bou.readerforselfoss.utils.SharedItems | ||||||
| import apps.amine.bou.readerforselfoss.utils.toggleStar | import apps.amine.bou.readerforselfoss.utils.toggleStar | ||||||
| import com.ftinc.scoop.Scoop | import com.ftinc.scoop.Scoop | ||||||
| import me.relex.circleindicator.CircleIndicator |  | ||||||
|  |  | ||||||
| class ReaderActivity : AppCompatActivity() { | class ReaderActivity : AppCompatActivity() { | ||||||
|  |  | ||||||
|     private var markOnScroll: Boolean = false |     private var markOnScroll: Boolean = false | ||||||
|     private var currentItem: Int = 0 |     private var currentItem: Int = 0 | ||||||
|     private lateinit var userIdentifier: String |     private lateinit var userIdentifier: String | ||||||
|  |     private lateinit var appColors: AppColors | ||||||
|  |  | ||||||
|     private lateinit var api: SelfossApi |     private lateinit var api: SelfossApi | ||||||
|  |  | ||||||
| @@ -50,14 +44,14 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|     private lateinit var binding: ActivityReaderBinding |     private lateinit var binding: ActivityReaderBinding | ||||||
|  |  | ||||||
|     private var activeAlignment: Int = 1 |     private var activeAlignment: Int = 1 | ||||||
|     val JUSTIFY = 1 |     private val JUSTIFY = 1 | ||||||
|     val ALIGN_LEFT = 2 |     private val ALIGN_LEFT = 2 | ||||||
|  |  | ||||||
|     private fun showMenuItem(willAddToFavorite: Boolean) { |     private fun showMenuItem(willAddToFavorite: Boolean) { | ||||||
|         if (willAddToFavorite) { |         if (willAddToFavorite) { | ||||||
|             toolbarMenu.findItem(R.id.star).icon.colorFilter = PorterDuffColorFilter(Color.WHITE, PorterDuff.Mode.SRC_ATOP) |             toolbarMenu.findItem(R.id.star).icon.setTint(Color.WHITE) | ||||||
|         } else { |         } else { | ||||||
|             toolbarMenu.findItem(R.id.star).icon.colorFilter = PorterDuffColorFilter(Color.RED, PorterDuff.Mode.SRC_ATOP) |             toolbarMenu.findItem(R.id.star).icon.setTint(Color.RED) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -73,6 +67,7 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|     override fun onCreate(savedInstanceState: Bundle?) { |     override fun onCreate(savedInstanceState: Bundle?) { | ||||||
|         super.onCreate(savedInstanceState) |         super.onCreate(savedInstanceState) | ||||||
|  |         appColors = AppColors(this) | ||||||
|         binding = ActivityReaderBinding.inflate(layoutInflater) |         binding = ActivityReaderBinding.inflate(layoutInflater) | ||||||
|         val view = binding.root |         val view = binding.root | ||||||
|  |  | ||||||
| @@ -85,9 +80,7 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|         val scoop = Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|         scoop.bind(this, Toppings.PRIMARY.value, binding.toolBar) |         scoop.bind(this, Toppings.PRIMARY.value, binding.toolBar) | ||||||
|         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { |         scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         setSupportActionBar(binding.toolBar) |         setSupportActionBar(binding.toolBar) | ||||||
|         supportActionBar?.setDisplayHomeAsUpEnabled(true) |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
| @@ -118,33 +111,14 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|         readItem(allItems[currentItem]) |         readItem(allItems[currentItem]) | ||||||
|  |  | ||||||
|         binding.pager.adapter = |         binding.pager.adapter = ScreenSlidePagerAdapter(this) | ||||||
|                 ScreenSlidePagerAdapter(supportFragmentManager, AppColors(this@ReaderActivity)) |         binding.pager.setCurrentItem(currentItem, false) | ||||||
|         binding.pager.currentItem = currentItem |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun onResume() { |     override fun onResume() { | ||||||
|         super.onResume() |         super.onResume() | ||||||
|  |  | ||||||
|         notifyAdapter() |         binding.indicator.setViewPager(binding.pager) | ||||||
|  |  | ||||||
|         binding.pager.setPageTransformer(true, DepthPageTransformer()) |  | ||||||
|         (binding.indicator as CircleIndicator).setViewPager(binding.pager) |  | ||||||
|  |  | ||||||
|         binding.pager.addOnPageChangeListener( |  | ||||||
|             object : ViewPager.SimpleOnPageChangeListener() { |  | ||||||
|  |  | ||||||
|                 override fun onPageSelected(position: Int) { |  | ||||||
|  |  | ||||||
|                     if (allItems[position].starred) { |  | ||||||
|                         canRemoveFromFavorite() |  | ||||||
|                     } else { |  | ||||||
|                         canFavorite() |  | ||||||
|                     } |  | ||||||
|                     readItem(allItems[position]) |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         ) |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun readItem(item: Item) { |     private fun readItem(item: Item) { | ||||||
| @@ -153,46 +127,22 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|             } |             } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun notifyAdapter() { |  | ||||||
|         (binding.pager.adapter as ScreenSlidePagerAdapter).notifyDataSetChanged() |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     override fun onPause() { |  | ||||||
|         super.onPause() |  | ||||||
|         if (markOnScroll) { |  | ||||||
|             binding.pager.clearOnPageChangeListeners() |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     override fun onSaveInstanceState(oldInstanceState: Bundle) { |     override fun onSaveInstanceState(oldInstanceState: Bundle) { | ||||||
|         super.onSaveInstanceState(oldInstanceState) |         super.onSaveInstanceState(oldInstanceState) | ||||||
|         oldInstanceState.clear() |         oldInstanceState.clear() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private inner class ScreenSlidePagerAdapter(fm: FragmentManager, val appColors: AppColors) : |     private inner class ScreenSlidePagerAdapter(fa: FragmentActivity) : | ||||||
|         FragmentStatePagerAdapter(fm) { |         FragmentStateAdapter(fa) { | ||||||
|  |  | ||||||
|         override fun getCount(): Int { |  | ||||||
|             return allItems.size |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         override fun getItem(position: Int): ArticleFragment { |         override fun getItemCount(): Int = allItems.size | ||||||
|             return ArticleFragment.newInstance(position, allItems) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         override fun startUpdate(container: ViewGroup) { |         override fun createFragment(position: Int): Fragment = ArticleFragment.newInstance(allItems[position]) | ||||||
|             super.startUpdate(container) |  | ||||||
|  |  | ||||||
|             container.background = ColorDrawable( |  | ||||||
|                 ContextCompat.getColor( |  | ||||||
|                     this@ReaderActivity, |  | ||||||
|                     appColors.colorBackground |  | ||||||
|                 ) |  | ||||||
|             ) |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     fun alignmentMenu(showJustify: Boolean) { |     private fun alignmentMenu(showJustify: Boolean) { | ||||||
|         toolbarMenu.findItem(R.id.align_left).isVisible = !showJustify |         toolbarMenu.findItem(R.id.align_left).isVisible = !showJustify | ||||||
|         toolbarMenu.findItem(R.id.align_justify).isVisible = showJustify |         toolbarMenu.findItem(R.id.align_justify).isVisible = showJustify | ||||||
|     } |     } | ||||||
| @@ -202,7 +152,7 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|         inflater.inflate(R.menu.reader_menu, menu) |         inflater.inflate(R.menu.reader_menu, menu) | ||||||
|         toolbarMenu = menu |         toolbarMenu = menu | ||||||
|  |  | ||||||
|         if (!allItems.isEmpty() && allItems[currentItem].starred) { |         if (allItems.isNotEmpty() && allItems[currentItem].starred) { | ||||||
|             canRemoveFromFavorite() |             canRemoveFromFavorite() | ||||||
|         } else { |         } else { | ||||||
|             canFavorite() |             canFavorite() | ||||||
| @@ -213,6 +163,22 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|             alignmentMenu(true) |             alignmentMenu(true) | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         binding.pager.registerOnPageChangeCallback( | ||||||
|  |                 object : ViewPager2.OnPageChangeCallback() { | ||||||
|  |  | ||||||
|  |                     override fun onPageSelected(position: Int) { | ||||||
|  |                         super.onPageSelected(position) | ||||||
|  |  | ||||||
|  |                         if (allItems[position].starred) { | ||||||
|  |                             canRemoveFromFavorite() | ||||||
|  |                         } else { | ||||||
|  |                             canFavorite() | ||||||
|  |                         } | ||||||
|  |                         readItem(allItems[position]) | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |         ) | ||||||
|  |  | ||||||
|         return true |         return true | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -220,13 +186,11 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|         fun afterSave() { |         fun afterSave() { | ||||||
|             allItems[binding.pager.currentItem] = |             allItems[binding.pager.currentItem] = | ||||||
|                     allItems[binding.pager.currentItem].toggleStar() |                     allItems[binding.pager.currentItem].toggleStar() | ||||||
|             notifyAdapter() |  | ||||||
|             canRemoveFromFavorite() |             canRemoveFromFavorite() | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         fun afterUnsave() { |         fun afterUnsave() { | ||||||
|             allItems[binding.pager.currentItem] = allItems[binding.pager.currentItem].toggleStar() |             allItems[binding.pager.currentItem] = allItems[binding.pager.currentItem].toggleStar() | ||||||
|             notifyAdapter() |  | ||||||
|             canFavorite() |             canFavorite() | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,16 +3,14 @@ package apps.amine.bou.readerforselfoss | |||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.content.res.ColorStateList | import android.content.res.ColorStateList | ||||||
| import android.os.Build |  | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import androidx.preference.PreferenceManager | ||||||
| import androidx.appcompat.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import androidx.recyclerview.widget.LinearLayoutManager | import androidx.recyclerview.widget.LinearLayoutManager | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import apps.amine.bou.readerforselfoss.adapters.SourcesListAdapter | import apps.amine.bou.readerforselfoss.adapters.SourcesListAdapter | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Source | import apps.amine.bou.readerforselfoss.api.selfoss.Source | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ActivityImageBinding |  | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ActivitySourcesBinding | import apps.amine.bou.readerforselfoss.databinding.ActivitySourcesBinding | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
| import apps.amine.bou.readerforselfoss.themes.Toppings | import apps.amine.bou.readerforselfoss.themes.Toppings | ||||||
| @@ -30,18 +28,16 @@ class SourcesActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|     override fun onCreate(savedInstanceState: Bundle?) { |     override fun onCreate(savedInstanceState: Bundle?) { | ||||||
|         appColors = AppColors(this@SourcesActivity) |         appColors = AppColors(this@SourcesActivity) | ||||||
|  |  | ||||||
|         super.onCreate(savedInstanceState) |  | ||||||
|         binding = ActivitySourcesBinding.inflate(layoutInflater) |         binding = ActivitySourcesBinding.inflate(layoutInflater) | ||||||
|         val view = binding.root |         val view = binding.root | ||||||
|  |  | ||||||
|         setContentView(view) |  | ||||||
|  |  | ||||||
|         val scoop = Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|         scoop.bind(this, Toppings.PRIMARY.value, binding.toolbar) |         scoop.bind(this, Toppings.PRIMARY.value, binding.toolbar) | ||||||
|         if  (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { |         scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) |  | ||||||
|         } |         super.onCreate(savedInstanceState) | ||||||
|  |  | ||||||
|  |         setContentView(view) | ||||||
|  |  | ||||||
|         setSupportActionBar(binding.toolbar) |         setSupportActionBar(binding.toolbar) | ||||||
|         supportActionBar?.setDisplayHomeAsUpEnabled(true) |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
| @@ -75,7 +71,7 @@ class SourcesActivity : AppCompatActivity() { | |||||||
|         binding.recyclerView.setHasFixedSize(true) |         binding.recyclerView.setHasFixedSize(true) | ||||||
|         binding.recyclerView.layoutManager = mLayoutManager |         binding.recyclerView.layoutManager = mLayoutManager | ||||||
|  |  | ||||||
|         if (this@SourcesActivity.isNetworkAccessible(this@SourcesActivity.findViewById(R.id.recyclerView))) { |         if (this@SourcesActivity.isNetworkAccessible(binding.recyclerView)) { | ||||||
|             api.sources.enqueue(object : Callback<List<Source>> { |             api.sources.enqueue(object : Callback<List<Source>> { | ||||||
|                 override fun onResponse( |                 override fun onResponse( | ||||||
|                     call: Call<List<Source>>, |                     call: Call<List<Source>>, | ||||||
|   | |||||||
| @@ -7,7 +7,6 @@ import android.view.LayoutInflater | |||||||
| import android.view.View | import android.view.View | ||||||
| import android.view.ViewGroup | import android.view.ViewGroup | ||||||
| import android.widget.ImageView.ScaleType | import android.widget.ImageView.ScaleType | ||||||
| import androidx.core.content.ContextCompat |  | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| @@ -61,10 +60,6 @@ class ItemCardAdapter( | |||||||
|  |  | ||||||
|             binding.favButton.isSelected = itm.starred |             binding.favButton.isSelected = itm.starred | ||||||
|             binding.title.text = itm.getTitleDecoded() |             binding.title.text = itm.getTitleDecoded() | ||||||
|             binding.title.setTextColor(ContextCompat.getColor( |  | ||||||
|                     c, |  | ||||||
|                     appColors.textColor |  | ||||||
|             )) |  | ||||||
|  |  | ||||||
|             binding.title.setOnTouchListener(LinkOnTouchListener()) |             binding.title.setOnTouchListener(LinkOnTouchListener()) | ||||||
|  |  | ||||||
| @@ -72,11 +67,6 @@ class ItemCardAdapter( | |||||||
|  |  | ||||||
|             binding.sourceTitleAndDate.text = itm.sourceAndDateText() |             binding.sourceTitleAndDate.text = itm.sourceAndDateText() | ||||||
|  |  | ||||||
|             binding.sourceTitleAndDate.setTextColor(ContextCompat.getColor( |  | ||||||
|                     c, |  | ||||||
|                     appColors.textColor |  | ||||||
|             )) |  | ||||||
|  |  | ||||||
|             if (!fullHeightCards) { |             if (!fullHeightCards) { | ||||||
|                 binding.itemImage.maxHeight = imageMaxHeight |                 binding.itemImage.maxHeight = imageMaxHeight | ||||||
|                 binding.itemImage.scaleType = ScaleType.CENTER_CROP |                 binding.itemImage.scaleType = ScaleType.CENTER_CROP | ||||||
| @@ -112,7 +102,6 @@ class ItemCardAdapter( | |||||||
|  |  | ||||||
|     inner class ViewHolder(val binding: CardItemBinding) : RecyclerView.ViewHolder(binding.root) { |     inner class ViewHolder(val binding: CardItemBinding) : RecyclerView.ViewHolder(binding.root) { | ||||||
|         init { |         init { | ||||||
|             binding.root.setCardBackgroundColor(appColors.cardBackgroundColor) |  | ||||||
|             handleClickListeners() |             handleClickListeners() | ||||||
|             handleCustomTabActions() |             handleCustomTabActions() | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -5,7 +5,6 @@ import android.content.Context | |||||||
| import androidx.recyclerview.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
| import android.view.LayoutInflater | import android.view.LayoutInflater | ||||||
| import android.view.ViewGroup | import android.view.ViewGroup | ||||||
| import androidx.core.content.ContextCompat |  | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.databinding.ListItemBinding | import apps.amine.bou.readerforselfoss.databinding.ListItemBinding | ||||||
| @@ -49,25 +48,14 @@ class ItemListAdapter( | |||||||
|         with(holder) { |         with(holder) { | ||||||
|             val itm = items[position] |             val itm = items[position] | ||||||
|  |  | ||||||
|  |  | ||||||
|             binding.title.text = itm.getTitleDecoded() |             binding.title.text = itm.getTitleDecoded() | ||||||
|  |  | ||||||
|             binding.title.setTextColor(ContextCompat.getColor( |  | ||||||
|                     c, |  | ||||||
|                     appColors.textColor |  | ||||||
|             )) |  | ||||||
|  |  | ||||||
|             binding.title.setOnTouchListener(LinkOnTouchListener()) |             binding.title.setOnTouchListener(LinkOnTouchListener()) | ||||||
|  |  | ||||||
|             binding.title.setLinkTextColor(appColors.colorAccent) |             binding.title.setLinkTextColor(appColors.colorAccent) | ||||||
|  |  | ||||||
|             binding.sourceTitleAndDate.text = itm.sourceAndDateText() |             binding.sourceTitleAndDate.text = itm.sourceAndDateText() | ||||||
|  |  | ||||||
|             binding.sourceTitleAndDate.setTextColor(ContextCompat.getColor( |  | ||||||
|                     c, |  | ||||||
|                     appColors.textColor |  | ||||||
|             )) |  | ||||||
|  |  | ||||||
|             if (itm.getThumbnail(c).isEmpty()) { |             if (itm.getThumbnail(c).isEmpty()) { | ||||||
|  |  | ||||||
|                 if (itm.getIcon(c).isEmpty()) { |                 if (itm.getIcon(c).isEmpty()) { | ||||||
|   | |||||||
| @@ -14,6 +14,8 @@ import com.bumptech.glide.Glide | |||||||
| import com.bumptech.glide.load.engine.DiskCacheStrategy | import com.bumptech.glide.load.engine.DiskCacheStrategy | ||||||
| import com.bumptech.glide.request.RequestOptions | import com.bumptech.glide.request.RequestOptions | ||||||
| import com.google.gson.annotations.SerializedName | import com.google.gson.annotations.SerializedName | ||||||
|  | import java.util.* | ||||||
|  | import kotlin.collections.ArrayList | ||||||
|  |  | ||||||
| private fun constructUrl(config: Config?, path: String, file: String?): String { | private fun constructUrl(config: Config?, path: String, file: String?): String { | ||||||
|     return if (file.isEmptyOrNullOrNullString()) { |     return if (file.isEmptyOrNullOrNullString()) { | ||||||
| @@ -155,14 +157,14 @@ data class Item( | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     fun getImages() : ArrayList<String> { |     fun getImages() : ArrayList<String> { | ||||||
|         var allImages = ArrayList<String>() |         val allImages = ArrayList<String>() | ||||||
|  |  | ||||||
|         for ( image in Jsoup.parse(content).getElementsByTag("img")) { |         for ( image in Jsoup.parse(content).getElementsByTag("img")) { | ||||||
|             val url = image.attr("src") |             val url = image.attr("src") | ||||||
|             if (url.toLowerCase().contains(".jpg") || |             if (url.lowercase(Locale.US).contains(".jpg") || | ||||||
|                     url.toLowerCase().contains(".jpeg") || |                     url.lowercase(Locale.US).contains(".jpeg") || | ||||||
|                     url.toLowerCase().contains(".png") || |                     url.lowercase(Locale.US).contains(".png") || | ||||||
|                     url.toLowerCase().contains(".webp")) |                     url.lowercase(Locale.US).contains(".webp")) | ||||||
|             { |             { | ||||||
|                 allImages.add(url) |                 allImages.add(url) | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import android.app.PendingIntent | |||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.os.Build | import android.os.Build | ||||||
| import android.preference.PreferenceManager | import androidx.preference.PreferenceManager | ||||||
| import androidx.core.app.NotificationCompat | import androidx.core.app.NotificationCompat | ||||||
| import androidx.core.app.NotificationCompat.PRIORITY_DEFAULT | import androidx.core.app.NotificationCompat.PRIORITY_DEFAULT | ||||||
| import androidx.core.app.NotificationCompat.PRIORITY_LOW | import androidx.core.app.NotificationCompat.PRIORITY_LOW | ||||||
|   | |||||||
| @@ -9,18 +9,16 @@ import android.graphics.Bitmap | |||||||
| import android.graphics.Typeface | import android.graphics.Typeface | ||||||
| import android.graphics.drawable.ColorDrawable | import android.graphics.drawable.ColorDrawable | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import android.os.Build |  | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import androidx.preference.PreferenceManager | ||||||
| import android.view.* | import android.view.* | ||||||
| import android.webkit.* | import android.webkit.* | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import androidx.browser.customtabs.CustomTabsIntent |  | ||||||
| import com.google.android.material.floatingactionbutton.FloatingActionButton | import com.google.android.material.floatingactionbutton.FloatingActionButton | ||||||
| import androidx.fragment.app.Fragment | import androidx.fragment.app.Fragment | ||||||
| import androidx.core.content.ContextCompat |  | ||||||
| import androidx.core.widget.NestedScrollView | import androidx.core.widget.NestedScrollView | ||||||
| import androidx.appcompat.app.AlertDialog | import androidx.appcompat.app.AlertDialog | ||||||
|  | import androidx.browser.customtabs.CustomTabsIntent | ||||||
| import androidx.core.content.res.ResourcesCompat | import androidx.core.content.res.ResourcesCompat | ||||||
| import androidx.room.Room | import androidx.room.Room | ||||||
| import apps.amine.bou.readerforselfoss.ImageActivity | import apps.amine.bou.readerforselfoss.ImageActivity | ||||||
| @@ -49,14 +47,14 @@ import retrofit2.Callback | |||||||
| import retrofit2.Response | import retrofit2.Response | ||||||
| import java.net.MalformedURLException | import java.net.MalformedURLException | ||||||
| import java.net.URL | import java.net.URL | ||||||
|  | import java.util.* | ||||||
| import java.util.concurrent.ExecutionException | import java.util.concurrent.ExecutionException | ||||||
| import kotlin.collections.ArrayList | import kotlin.collections.ArrayList | ||||||
|  |  | ||||||
| class ArticleFragment : Fragment() { | class ArticleFragment : Fragment() { | ||||||
|     private lateinit var pageNumber: Number |  | ||||||
|     private var fontSize: Int = 16 |     private var fontSize: Int = 16 | ||||||
|     private lateinit var allItems: ArrayList<Item> |     private lateinit var item: Item | ||||||
|     private var mCustomTabActivityHelper: CustomTabActivityHelper? = null; |     private var mCustomTabActivityHelper: CustomTabActivityHelper? = null | ||||||
|     private lateinit var url: String |     private lateinit var url: String | ||||||
|     private lateinit var contentText: String |     private lateinit var contentText: String | ||||||
|     private lateinit var contentSource: String |     private lateinit var contentSource: String | ||||||
| @@ -77,6 +75,7 @@ class ArticleFragment : Fragment() { | |||||||
|     private var typeface: Typeface? = null |     private var typeface: Typeface? = null | ||||||
|     private var resId: Int = 0 |     private var resId: Int = 0 | ||||||
|     private var font = "" |     private var font = "" | ||||||
|  |     private var staticBar = false | ||||||
|  |  | ||||||
|     override fun onStop() { |     override fun onStop() { | ||||||
|         super.onStop() |         super.onStop() | ||||||
| @@ -91,8 +90,7 @@ class ArticleFragment : Fragment() { | |||||||
|  |  | ||||||
|         super.onCreate(savedInstanceState) |         super.onCreate(savedInstanceState) | ||||||
|  |  | ||||||
|         pageNumber = requireArguments().getInt(ARG_POSITION) |         item = requireArguments().getParcelable(ARG_ITEMS)!! | ||||||
|         allItems = requireArguments().getParcelableArrayList<Item>(ARG_ITEMS) as ArrayList<Item> |  | ||||||
|  |  | ||||||
|         db = Room.databaseBuilder( |         db = Room.databaseBuilder( | ||||||
|             requireContext(), |             requireContext(), | ||||||
| @@ -104,20 +102,21 @@ class ArticleFragment : Fragment() { | |||||||
|         inflater: LayoutInflater, |         inflater: LayoutInflater, | ||||||
|         container: ViewGroup?, |         container: ViewGroup?, | ||||||
|         savedInstanceState: Bundle? |         savedInstanceState: Bundle? | ||||||
|     ): View? { |     ): View { | ||||||
|         try { |         try { | ||||||
|             _binding = FragmentArticleBinding.inflate(inflater, container, false) |             _binding = FragmentArticleBinding.inflate(inflater, container, false) | ||||||
|  |  | ||||||
|             url = allItems[pageNumber.toInt()].getLinkDecoded() |             url = item.getLinkDecoded() | ||||||
|             contentText = allItems[pageNumber.toInt()].content |             contentText = item.content | ||||||
|             contentTitle = allItems[pageNumber.toInt()].getTitleDecoded() |             contentTitle = item.getTitleDecoded() | ||||||
|             contentImage = allItems[pageNumber.toInt()].getThumbnail(requireActivity()) |             contentImage = item.getThumbnail(requireActivity()) | ||||||
|             contentSource = allItems[pageNumber.toInt()].sourceAndDateText() |             contentSource = item.sourceAndDateText() | ||||||
|             allImages = allItems[pageNumber.toInt()].getImages() |             allImages = item.getImages() | ||||||
|  |  | ||||||
|             prefs = PreferenceManager.getDefaultSharedPreferences(activity) |             prefs = PreferenceManager.getDefaultSharedPreferences(activity) | ||||||
|             editor = prefs.edit() |             editor = prefs.edit() | ||||||
|             fontSize = prefs.getString("reader_font_size", "16")!!.toInt() |             fontSize = prefs.getString("reader_font_size", "16")!!.toInt() | ||||||
|  |             staticBar = prefs.getBoolean("reader_static_bar", false) | ||||||
|  |  | ||||||
|             font = prefs.getString("reader_font", "")!! |             font = prefs.getString("reader_font", "")!! | ||||||
|             if (font.isNotEmpty()) { |             if (font.isNotEmpty()) { | ||||||
| @@ -162,26 +161,18 @@ class ArticleFragment : Fragment() { | |||||||
|                 object : FloatingToolbar.ItemClickListener { |                 object : FloatingToolbar.ItemClickListener { | ||||||
|                     override fun onItemClick(item: MenuItem) { |                     override fun onItemClick(item: MenuItem) { | ||||||
|                         when (item.itemId) { |                         when (item.itemId) { | ||||||
|                             R.id.more_action -> getContentFromMercury(customTabsIntent, prefs) |                             R.id.more_action -> getContentFromMercury(customTabsIntent) | ||||||
|                             R.id.share_action -> requireActivity().shareLink(url, contentTitle) |                             R.id.share_action -> requireActivity().shareLink(url, contentTitle) | ||||||
|                             R.id.open_action -> requireActivity().openItemUrl( |                             R.id.open_action -> requireActivity().openInBrowserAsNewTask(this@ArticleFragment.item) | ||||||
|                                 allItems, |  | ||||||
|                                 pageNumber.toInt(), |  | ||||||
|                                 url, |  | ||||||
|                                 customTabsIntent, |  | ||||||
|                                 false, |  | ||||||
|                                 false, |  | ||||||
|                                 requireActivity() |  | ||||||
|                             ) |  | ||||||
|                             R.id.unread_action -> if (context != null) { |                             R.id.unread_action -> if (context != null) { | ||||||
|                                 if (allItems[pageNumber.toInt()].unread) { |                                 if (this@ArticleFragment.item.unread) { | ||||||
|                                     SharedItems.readItem( |                                     SharedItems.readItem( | ||||||
|                                         context!!, |                                         context!!, | ||||||
|                                         api, |                                         api, | ||||||
|                                         db, |                                         db, | ||||||
|                                         allItems[pageNumber.toInt()] |                                             this@ArticleFragment.item | ||||||
|                                     ) |                                     ) | ||||||
|                                     allItems[pageNumber.toInt()].unread = false |                                     this@ArticleFragment.item.unread = false | ||||||
|                                     Toast.makeText( |                                     Toast.makeText( | ||||||
|                                         context, |                                         context, | ||||||
|                                         R.string.marked_as_read, |                                         R.string.marked_as_read, | ||||||
| @@ -192,9 +183,9 @@ class ArticleFragment : Fragment() { | |||||||
|                                         context!!, |                                         context!!, | ||||||
|                                         api, |                                         api, | ||||||
|                                         db, |                                         db, | ||||||
|                                         allItems[pageNumber.toInt()] |                                             this@ArticleFragment.item | ||||||
|                                     ) |                                     ) | ||||||
|                                     allItems[pageNumber.toInt()].unread = true |                                     this@ArticleFragment.item.unread = true | ||||||
|                                     Toast.makeText( |                                     Toast.makeText( | ||||||
|                                         context, |                                         context, | ||||||
|                                         R.string.marked_as_unread, |                                         R.string.marked_as_unread, | ||||||
| @@ -211,13 +202,18 @@ class ArticleFragment : Fragment() { | |||||||
|                 } |                 } | ||||||
|             ) |             ) | ||||||
|  |  | ||||||
|  |             if (staticBar) { | ||||||
|  |                 fab.hide() | ||||||
|  |                 floatingToolbar.show() | ||||||
|  |             } | ||||||
|  |  | ||||||
|             binding.source.text = contentSource |             binding.source.text = contentSource | ||||||
|             if (typeface != null) { |             if (typeface != null) { | ||||||
|                 binding.source.typeface = typeface |                 binding.source.typeface = typeface | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if (contentText.isEmptyOrNullOrNullString()) { |             if (contentText.isEmptyOrNullOrNullString()) { | ||||||
|                 getContentFromMercury(customTabsIntent, prefs) |                 getContentFromMercury(customTabsIntent) | ||||||
|             } else { |             } else { | ||||||
|                 binding.titleView.text = contentTitle |                 binding.titleView.text = contentTitle | ||||||
|                 if (typeface != null) { |                 if (typeface != null) { | ||||||
| @@ -242,9 +238,14 @@ class ArticleFragment : Fragment() { | |||||||
|             binding.nestedScrollView.setOnScrollChangeListener( |             binding.nestedScrollView.setOnScrollChangeListener( | ||||||
|                 NestedScrollView.OnScrollChangeListener { _, _, scrollY, _, oldScrollY -> |                 NestedScrollView.OnScrollChangeListener { _, _, scrollY, _, oldScrollY -> | ||||||
|                     if (scrollY > oldScrollY) { |                     if (scrollY > oldScrollY) { | ||||||
|  |                         floatingToolbar.hide() | ||||||
|                         fab.hide() |                         fab.hide() | ||||||
|                     } else { |                     } else { | ||||||
|                         if (floatingToolbar.isShowing) floatingToolbar.hide() else fab.show() |                         if (staticBar) { | ||||||
|  |                             floatingToolbar.show() | ||||||
|  |                         } else { | ||||||
|  |                             if (floatingToolbar.isShowing) floatingToolbar.hide() else fab.show() | ||||||
|  |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             ) |             ) | ||||||
| @@ -254,11 +255,11 @@ class ArticleFragment : Fragment() { | |||||||
|                 .setMessage(requireContext().getString(R.string.webview_dialog_issue_message)) |                 .setMessage(requireContext().getString(R.string.webview_dialog_issue_message)) | ||||||
|                 .setTitle(requireContext().getString(R.string.webview_dialog_issue_title)) |                 .setTitle(requireContext().getString(R.string.webview_dialog_issue_title)) | ||||||
|                 .setPositiveButton(android.R.string.ok |                 .setPositiveButton(android.R.string.ok | ||||||
|                 ) { dialog, which -> |                 ) { _, _ -> | ||||||
|                     val sharedPref = PreferenceManager.getDefaultSharedPreferences(requireContext()) |                     val sharedPref = PreferenceManager.getDefaultSharedPreferences(requireContext()) | ||||||
|                     val editor = sharedPref.edit() |                     val editor = sharedPref.edit() | ||||||
|                     editor.putBoolean("prefer_article_viewer", false) |                     editor.putBoolean("prefer_article_viewer", false) | ||||||
|                     editor.commit() |                     editor.apply() | ||||||
|                     requireActivity().finish() |                     requireActivity().finish() | ||||||
|                 } |                 } | ||||||
|                 .create() |                 .create() | ||||||
| @@ -281,10 +282,7 @@ class ArticleFragment : Fragment() { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun getContentFromMercury( |     private fun getContentFromMercury(customTabsIntent: CustomTabsIntent) { | ||||||
|         customTabsIntent: CustomTabsIntent, |  | ||||||
|         prefs: SharedPreferences |  | ||||||
|     ) { |  | ||||||
|         if ((context != null && requireContext().isNetworkAccessible(null)) || context == null) { |         if ((context != null && requireContext().isNetworkAccessible(null)) || context == null) { | ||||||
|             binding.progressBar.visibility = View.VISIBLE |             binding.progressBar.visibility = View.VISIBLE | ||||||
|             val parser = MercuryApi() |             val parser = MercuryApi() | ||||||
| @@ -379,42 +377,12 @@ class ArticleFragment : Fragment() { | |||||||
|  |  | ||||||
|         binding.webcontent.settings.standardFontFamily = a.getString(0) |         binding.webcontent.settings.standardFontFamily = a.getString(0) | ||||||
|         binding.webcontent.visibility = View.VISIBLE |         binding.webcontent.visibility = View.VISIBLE | ||||||
|         val (textColor, backgroundColor) = if (appColors.isDarkTheme) { |  | ||||||
|             if (context != null) { |  | ||||||
|                 binding.webcontent.setBackgroundColor( |  | ||||||
|                     ContextCompat.getColor( |  | ||||||
|                         requireContext(), |  | ||||||
|                         R.color.dark_webview |  | ||||||
|                     ) |  | ||||||
|                 ) |  | ||||||
|                 Pair(ContextCompat.getColor(requireContext(), R.color.dark_webview_text), ContextCompat.getColor(requireContext(), R.color.dark_webview)) |  | ||||||
|             } else { |  | ||||||
|                 Pair(null, null) |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             if (context != null) { |  | ||||||
|                 binding.webcontent.setBackgroundColor( |  | ||||||
|                     ContextCompat.getColor( |  | ||||||
|                         requireContext(), |  | ||||||
|                         R.color.light_webview |  | ||||||
|                     ) |  | ||||||
|                 ) |  | ||||||
|                 Pair(ContextCompat.getColor(requireContext(), R.color.light_webview_text), ContextCompat.getColor(requireContext(), R.color.light_webview)) |  | ||||||
|             } else { |  | ||||||
|                 Pair(null, null) |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         val stringTextColor: String = if (textColor != null) { |         // TODO: Set the color strings programmatically | ||||||
|             String.format("#%06X", 0xFFFFFF and textColor) |         val (stringTextColor, stringBackgroundColor) = if (appColors.isDarkTheme) { | ||||||
|  |             Pair("#FFFFFF", "#303030") | ||||||
|         } else { |         } else { | ||||||
|             "#000000" |             Pair("#212121", "#FAFAFA") | ||||||
|         } |  | ||||||
|  |  | ||||||
|         val stringBackgroundColor = if (backgroundColor != null) { |  | ||||||
|             String.format("#%06X", 0xFFFFFF and backgroundColor) |  | ||||||
|         } else { |  | ||||||
|             "#FFFFFF" |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         binding.webcontent.settings.useWideViewPort = true |         binding.webcontent.settings.useWideViewPort = true | ||||||
| @@ -431,19 +399,19 @@ class ArticleFragment : Fragment() { | |||||||
|  |  | ||||||
|             override fun shouldInterceptRequest(view: WebView?, url: String): WebResourceResponse? { |             override fun shouldInterceptRequest(view: WebView?, url: String): WebResourceResponse? { | ||||||
|                 val glideOptions = RequestOptions.diskCacheStrategyOf(DiskCacheStrategy.ALL) |                 val glideOptions = RequestOptions.diskCacheStrategyOf(DiskCacheStrategy.ALL) | ||||||
|                 if (url.toLowerCase().contains(".jpg") || url.toLowerCase().contains(".jpeg")) { |                 if (url.lowercase(Locale.US).contains(".jpg") || url.lowercase(Locale.US).contains(".jpeg")) { | ||||||
|                     try { |                     try { | ||||||
|                         val image = Glide.with(view).asBitmap().apply(glideOptions).load(url).submit().get() |                         val image = Glide.with(view).asBitmap().apply(glideOptions).load(url).submit().get() | ||||||
|                         return WebResourceResponse("image/jpg", "UTF-8", getBitmapInputStream(image, Bitmap.CompressFormat.JPEG)) |                         return WebResourceResponse("image/jpg", "UTF-8", getBitmapInputStream(image, Bitmap.CompressFormat.JPEG)) | ||||||
|                     }catch ( e : ExecutionException) {} |                     }catch ( e : ExecutionException) {} | ||||||
|                 } |                 } | ||||||
|                 else if (url.toLowerCase().contains(".png")) { |                 else if (url.lowercase(Locale.US).contains(".png")) { | ||||||
|                     try { |                     try { | ||||||
|                         val image = Glide.with(view).asBitmap().apply(glideOptions).load(url).submit().get() |                         val image = Glide.with(view).asBitmap().apply(glideOptions).load(url).submit().get() | ||||||
|                         return WebResourceResponse("image/jpg", "UTF-8", getBitmapInputStream(image, Bitmap.CompressFormat.PNG)) |                         return WebResourceResponse("image/jpg", "UTF-8", getBitmapInputStream(image, Bitmap.CompressFormat.PNG)) | ||||||
|                     }catch ( e : ExecutionException) {} |                     }catch ( e : ExecutionException) {} | ||||||
|                 } |                 } | ||||||
|                 else if (url.toLowerCase().contains(".webp")) { |                 else if (url.lowercase(Locale.US).contains(".webp")) { | ||||||
|                     try { |                     try { | ||||||
|                         val image = Glide.with(view).asBitmap().apply(glideOptions).load(url).submit().get() |                         val image = Glide.with(view).asBitmap().apply(glideOptions).load(url).submit().get() | ||||||
|                         return WebResourceResponse("image/jpg", "UTF-8", getBitmapInputStream(image, Bitmap.CompressFormat.WEBP)) |                         return WebResourceResponse("image/jpg", "UTF-8", getBitmapInputStream(image, Bitmap.CompressFormat.WEBP)) | ||||||
| @@ -462,12 +430,8 @@ class ArticleFragment : Fragment() { | |||||||
|  |  | ||||||
|         binding.webcontent.setOnTouchListener { _, event -> gestureDetector.onTouchEvent(event)} |         binding.webcontent.setOnTouchListener { _, event -> gestureDetector.onTouchEvent(event)} | ||||||
|  |  | ||||||
|         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { |         binding.webcontent.settings.layoutAlgorithm = | ||||||
|             binding.webcontent.settings.layoutAlgorithm = |                 WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING | ||||||
|                     WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING |  | ||||||
|         } else { |  | ||||||
|             binding.webcontent.settings.layoutAlgorithm = WebSettings.LayoutAlgorithm.SINGLE_COLUMN |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         var baseUrl: String? = null |         var baseUrl: String? = null | ||||||
|  |  | ||||||
| @@ -549,29 +513,22 @@ class ArticleFragment : Fragment() { | |||||||
|  |  | ||||||
|     private fun openInBrowserAfterFailing(customTabsIntent: CustomTabsIntent) { |     private fun openInBrowserAfterFailing(customTabsIntent: CustomTabsIntent) { | ||||||
|         binding.progressBar.visibility = View.GONE |         binding.progressBar.visibility = View.GONE | ||||||
|         requireActivity().openItemUrl( |         requireActivity().openItemUrlInternalBrowser( | ||||||
|             allItems, |                 url, | ||||||
|             pageNumber.toInt(), |                 customTabsIntent, | ||||||
|             url, |                 requireActivity() | ||||||
|             customTabsIntent, |  | ||||||
|             true, |  | ||||||
|             false, |  | ||||||
|             requireActivity() |  | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     companion object { |     companion object { | ||||||
|         private const val ARG_POSITION = "position" |  | ||||||
|         private const val ARG_ITEMS = "items" |         private const val ARG_ITEMS = "items" | ||||||
|  |  | ||||||
|         fun newInstance( |         fun newInstance( | ||||||
|             position: Int, |                 item: Item | ||||||
|             allItems: ArrayList<Item> |  | ||||||
|         ): ArticleFragment { |         ): ArticleFragment { | ||||||
|             val fragment = ArticleFragment() |             val fragment = ArticleFragment() | ||||||
|             val args = Bundle() |             val args = Bundle() | ||||||
|             args.putInt(ARG_POSITION, position) |             args.putParcelable(ARG_ITEMS, item) | ||||||
|             args.putParcelableArrayList(ARG_ITEMS, allItems) |  | ||||||
|             fragment.arguments = args |             fragment.arguments = args | ||||||
|             return fragment |             return fragment | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -1,142 +0,0 @@ | |||||||
| package apps.amine.bou.readerforselfoss.settings; |  | ||||||
|  |  | ||||||
| import android.content.res.Configuration; |  | ||||||
| import android.os.Build; |  | ||||||
| import android.os.Bundle; |  | ||||||
| import android.preference.PreferenceActivity; |  | ||||||
| import androidx.annotation.LayoutRes; |  | ||||||
| import androidx.annotation.NonNull; |  | ||||||
| import androidx.annotation.Nullable; |  | ||||||
| import com.google.android.material.appbar.AppBarLayout; |  | ||||||
| import androidx.appcompat.app.ActionBar; |  | ||||||
| import androidx.appcompat.app.AppCompatDelegate; |  | ||||||
| import androidx.appcompat.widget.Toolbar; |  | ||||||
| import android.view.LayoutInflater; |  | ||||||
| import android.view.MenuInflater; |  | ||||||
| import android.view.View; |  | ||||||
| import android.view.ViewGroup; |  | ||||||
| import android.widget.LinearLayout; |  | ||||||
|  |  | ||||||
| import com.ftinc.scoop.Scoop; |  | ||||||
|  |  | ||||||
| import apps.amine.bou.readerforselfoss.R; |  | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors; |  | ||||||
| import apps.amine.bou.readerforselfoss.themes.Toppings; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * A {@link PreferenceActivity} which implements and proxies the necessary calls |  | ||||||
|  * to be used with AppCompat. |  | ||||||
|  */ |  | ||||||
| public abstract class AppCompatPreferenceActivity extends PreferenceActivity { |  | ||||||
|  |  | ||||||
|     private AppCompatDelegate mDelegate; |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected void onCreate(Bundle savedInstanceState) { |  | ||||||
|         new AppColors(this); |  | ||||||
|  |  | ||||||
|         getDelegate().installViewFactory(); |  | ||||||
|         getDelegate().onCreate(savedInstanceState); |  | ||||||
|         super.onCreate(savedInstanceState); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected void onPostCreate(Bundle savedInstanceState) { |  | ||||||
|         super.onPostCreate(savedInstanceState); |  | ||||||
|  |  | ||||||
|         LinearLayout root = (LinearLayout) findViewById(android.R.id.list).getParent().getParent().getParent(); |  | ||||||
|         AppBarLayout bar = (AppBarLayout) LayoutInflater.from(this).inflate(R.layout.settings_toolbar, root, false); |  | ||||||
|         Toolbar toolbar = bar.findViewById(R.id.toolbar); |  | ||||||
|  |  | ||||||
|         Scoop scoop = Scoop.getInstance(); |  | ||||||
|         scoop.bind(this, Toppings.PRIMARY.getValue(), toolbar); |  | ||||||
|         if  (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { |  | ||||||
|             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.getValue()); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         setSupportActionBar(toolbar); |  | ||||||
|         getSupportActionBar().setDisplayHomeAsUpEnabled(true); |  | ||||||
|         getSupportActionBar().setDisplayShowHomeEnabled(true); |  | ||||||
|  |  | ||||||
|         root.addView(bar, 0); |  | ||||||
|  |  | ||||||
|         getDelegate().onPostCreate(savedInstanceState); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     ActionBar getSupportActionBar() { |  | ||||||
|         return getDelegate().getSupportActionBar(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public void setSupportActionBar(@Nullable Toolbar toolbar) { |  | ||||||
|         getDelegate().setSupportActionBar(toolbar); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @NonNull |  | ||||||
|     @Override |  | ||||||
|     public MenuInflater getMenuInflater() { |  | ||||||
|         return getDelegate().getMenuInflater(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void setContentView(@LayoutRes int layoutResID) { |  | ||||||
|         getDelegate().setContentView(layoutResID); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void setContentView(View view) { |  | ||||||
|         getDelegate().setContentView(view); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void setContentView(View view, ViewGroup.LayoutParams params) { |  | ||||||
|         getDelegate().setContentView(view, params); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void addContentView(View view, ViewGroup.LayoutParams params) { |  | ||||||
|         getDelegate().addContentView(view, params); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected void onPostResume() { |  | ||||||
|         super.onPostResume(); |  | ||||||
|         getDelegate().onPostResume(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected void onTitleChanged(CharSequence title, int color) { |  | ||||||
|         super.onTitleChanged(title, color); |  | ||||||
|         getDelegate().setTitle(title); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void onConfigurationChanged(Configuration newConfig) { |  | ||||||
|         super.onConfigurationChanged(newConfig); |  | ||||||
|         getDelegate().onConfigurationChanged(newConfig); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected void onStop() { |  | ||||||
|         super.onStop(); |  | ||||||
|         getDelegate().onStop(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected void onDestroy() { |  | ||||||
|         super.onDestroy(); |  | ||||||
|         getDelegate().onDestroy(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void invalidateOptionsMenu() { |  | ||||||
|         getDelegate().invalidateOptionsMenu(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private AppCompatDelegate getDelegate() { |  | ||||||
|         if (mDelegate == null) { |  | ||||||
|             mDelegate = AppCompatDelegate.create(this, null); |  | ||||||
|         } |  | ||||||
|         return mDelegate; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,345 +0,0 @@ | |||||||
| package apps.amine.bou.readerforselfoss.settings; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| import android.annotation.TargetApi; |  | ||||||
| import android.content.ClipData; |  | ||||||
| import android.content.ClipboardManager; |  | ||||||
| import android.content.Context; |  | ||||||
| import android.content.Intent; |  | ||||||
| import android.content.SharedPreferences; |  | ||||||
| import android.content.res.Configuration; |  | ||||||
| import android.content.res.Resources; |  | ||||||
| import android.net.Uri; |  | ||||||
| import android.os.Build; |  | ||||||
| import android.os.Bundle; |  | ||||||
| import android.preference.EditTextPreference; |  | ||||||
| import android.preference.Preference; |  | ||||||
| import android.preference.Preference.OnPreferenceChangeListener; |  | ||||||
| import android.preference.Preference.OnPreferenceClickListener; |  | ||||||
| import android.preference.PreferenceActivity; |  | ||||||
| import android.preference.PreferenceFragment; |  | ||||||
| import android.preference.PreferenceManager; |  | ||||||
| import android.preference.SwitchPreference; |  | ||||||
| import androidx.appcompat.app.ActionBar; |  | ||||||
| import android.text.Editable; |  | ||||||
| import android.text.InputFilter; |  | ||||||
| import android.text.Spanned; |  | ||||||
| import android.text.TextWatcher; |  | ||||||
| import android.util.Log; |  | ||||||
| import android.view.Menu; |  | ||||||
| import android.view.MenuInflater; |  | ||||||
| import android.view.MenuItem; |  | ||||||
| import android.widget.Toast; |  | ||||||
|  |  | ||||||
| import java.util.List; |  | ||||||
|  |  | ||||||
| import apps.amine.bou.readerforselfoss.R; |  | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors; |  | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * A {@link 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. |  | ||||||
|  * <p> |  | ||||||
|  * See <a href="http://developer.android.com/design/patterns/settings.html"> |  | ||||||
|  * Android Design: Settings</a> for design guidelines and the <a |  | ||||||
|  * href="http://developer.android.com/guide/topics/ui/settings.html">Settings |  | ||||||
|  * API Guide</a> for more information on developing a Settings UI. |  | ||||||
|  */ |  | ||||||
| public class SettingsActivity extends AppCompatPreferenceActivity { |  | ||||||
|     /** |  | ||||||
|      * A preference value change listener that updates the preference's summary |  | ||||||
|      * to reflect its new value. |  | ||||||
|      */ |  | ||||||
|     private static Preference.OnPreferenceChangeListener sBindPreferenceSummaryToValueListener = new Preference.OnPreferenceChangeListener() { |  | ||||||
|         @Override |  | ||||||
|         public boolean onPreferenceChange(Preference preference, Object value) { |  | ||||||
|             String stringValue = value.toString(); |  | ||||||
|             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) { |  | ||||||
|         new AppColors(this); |  | ||||||
|         super.onCreate(savedInstanceState); |  | ||||||
|         setupActionBar(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 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); |  | ||||||
|  |  | ||||||
|         AppColors appColors = new AppColors(this); |  | ||||||
|         if (appColors != null && appColors.isDarkTheme()) { |  | ||||||
|             for (Header header : target) { |  | ||||||
|                 tryLoadIconDark(header); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void tryLoadIconDark(Header header){ |  | ||||||
|         try{ |  | ||||||
|             if (header.fragmentArguments != null) { |  | ||||||
|                 String iconDark = header.fragmentArguments.getString("iconDark"); |  | ||||||
|                 int iconDarkId = getResources().getIdentifier(iconDark, "drawable", getPackageName()); |  | ||||||
|                 if (iconDarkId != 0) { |  | ||||||
|                     header.iconRes = iconDarkId; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } catch (Exception e) { |  | ||||||
|             Log.e("SettingsActivity", "Can not load dark icon", e); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * This method stops fragment injection in malicious applications. |  | ||||||
|      * Make sure to deny any unknown fragments here. |  | ||||||
|      */ |  | ||||||
|     @Override |  | ||||||
|     protected boolean isValidFragment(String fragmentName) { |  | ||||||
|         return PreferenceFragment.class.getName().equals(fragmentName) |  | ||||||
|                 || GeneralPreferenceFragment.class.getName().equals(fragmentName) |  | ||||||
|                 || ArticleViewerPreferenceFragment.class.getName().equals(fragmentName) |  | ||||||
|                 || OfflinePreferenceFragment.class.getName().equals(fragmentName) |  | ||||||
|                 || ExperimentalPreferenceFragment.class.getName().equals(fragmentName) |  | ||||||
|                 || LinksPreferenceFragment.class.getName().equals(fragmentName) |  | ||||||
|                 || ThemePreferenceFragment.class.getName().equals(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) |  | ||||||
|     public static class GeneralPreferenceFragment extends PreferenceFragment { |  | ||||||
|         @Override |  | ||||||
|         public void onCreate(Bundle savedInstanceState) { |  | ||||||
|             super.onCreate(savedInstanceState); |  | ||||||
|             addPreferencesFromResource(R.xml.pref_general); |  | ||||||
|             setHasOptionsMenu(true); |  | ||||||
|  |  | ||||||
|             EditTextPreference itemsNumber = (EditTextPreference) findPreference("prefer_api_items_number"); |  | ||||||
|             itemsNumber.getEditText().setFilters(new InputFilter[]{ |  | ||||||
|                     new InputFilter() { |  | ||||||
|  |  | ||||||
|                         @Override |  | ||||||
|                         public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) { |  | ||||||
|                             try { |  | ||||||
|                                 int input = Integer.parseInt(dest.toString() + source.toString()); |  | ||||||
|                                 if (input <= 200 && input > 0) |  | ||||||
|                                     return null; |  | ||||||
|                             } catch (NumberFormatException nfe) { |  | ||||||
|                                 Toast.makeText(getActivity(), R.string.items_number_should_be_number, Toast.LENGTH_LONG).show(); |  | ||||||
|                             } |  | ||||||
|                             return ""; |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|             }); |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @TargetApi(Build.VERSION_CODES.HONEYCOMB) |  | ||||||
|     public static class ArticleViewerPreferenceFragment extends PreferenceFragment { |  | ||||||
|         @Override |  | ||||||
|         public void onCreate(Bundle savedInstanceState) { |  | ||||||
|             super.onCreate(savedInstanceState); |  | ||||||
|             addPreferencesFromResource(R.xml.pref_viewer); |  | ||||||
|             setHasOptionsMenu(true); |  | ||||||
|  |  | ||||||
|             final EditTextPreference fontSize = (EditTextPreference) findPreference("reader_font_size"); |  | ||||||
|             fontSize.getEditText().addTextChangedListener(new TextWatcher() { |  | ||||||
|                 @Override |  | ||||||
|                 public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {} |  | ||||||
|  |  | ||||||
|                 @Override |  | ||||||
|                 public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {} |  | ||||||
|  |  | ||||||
|                 @Override |  | ||||||
|                 public void afterTextChanged(Editable editable) { |  | ||||||
|                     try { |  | ||||||
|                         fontSize.getEditText().setTextSize(Integer.parseInt(editable.toString())); |  | ||||||
|                     } catch (NumberFormatException e) {} |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|             fontSize.getEditText().setFilters(new InputFilter[]{ |  | ||||||
|                     new InputFilter() { |  | ||||||
|  |  | ||||||
|                         @Override |  | ||||||
|                         public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) { |  | ||||||
|                             try { |  | ||||||
|                                 int input = Integer.parseInt(dest.toString() + source.toString()); |  | ||||||
|                                 if (input > 0) |  | ||||||
|                                     return null; |  | ||||||
|                             } catch (NumberFormatException nfe) {} |  | ||||||
|                             return ""; |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * This fragment shows general preferences only. It is used when the |  | ||||||
|      * activity is showing a two-pane settings UI. |  | ||||||
|      */ |  | ||||||
|     @TargetApi(Build.VERSION_CODES.HONEYCOMB) |  | ||||||
|     public static class LinksPreferenceFragment extends PreferenceFragment { |  | ||||||
|         public void openUrl(Uri uri) { |  | ||||||
|             Intent browserIntent = new Intent(Intent.ACTION_VIEW, uri); |  | ||||||
|             startActivity(browserIntent); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |  | ||||||
|         public void onCreate(Bundle savedInstanceState) { |  | ||||||
|             super.onCreate(savedInstanceState); |  | ||||||
|             addPreferencesFromResource(R.xml.pref_links); |  | ||||||
|             setHasOptionsMenu(true); |  | ||||||
|  |  | ||||||
|             findPreference("trackerLink").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { |  | ||||||
|                 @Override |  | ||||||
|                 public boolean onPreferenceClick(Preference preference) { |  | ||||||
|                     openUrl(Uri.parse(Config.trackerUrl)); |  | ||||||
|                     return true; |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|  |  | ||||||
|             findPreference("sourceLink").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { |  | ||||||
|                 @Override |  | ||||||
|                 public boolean onPreferenceClick(Preference preference) { |  | ||||||
|                     openUrl(Uri.parse(Config.sourceUrl)); |  | ||||||
|                     return false; |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|  |  | ||||||
|             findPreference("translation").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { |  | ||||||
|                 @Override |  | ||||||
|                 public boolean onPreferenceClick(Preference preference) { |  | ||||||
|                     openUrl(Uri.parse(Config.translationUrl)); |  | ||||||
|                     return false; |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @TargetApi(Build.VERSION_CODES.HONEYCOMB) |  | ||||||
|     public static class ThemePreferenceFragment extends PreferenceFragment { |  | ||||||
|         @Override |  | ||||||
|         public void onCreate(Bundle savedInstanceState) { |  | ||||||
|             super.onCreate(savedInstanceState); |  | ||||||
|             addPreferencesFromResource(R.xml.pref_theme); |  | ||||||
|             setHasOptionsMenu(true); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |  | ||||||
|         public boolean onOptionsItemSelected(MenuItem item) { |  | ||||||
|             int id = item.getItemId(); |  | ||||||
|             if (id == R.id.clear) { |  | ||||||
|                 SharedPreferences pref = PreferenceManager.getDefaultSharedPreferences(getActivity()); |  | ||||||
|                 SharedPreferences.Editor editor = pref.edit(); |  | ||||||
|                 editor.remove("color_primary"); |  | ||||||
|                 editor.remove("color_primary_dark"); |  | ||||||
|                 editor.remove("color_accent"); |  | ||||||
|                 editor.remove("color_accent_dark"); |  | ||||||
|                 editor.remove("dark_theme"); |  | ||||||
|                 editor.apply(); |  | ||||||
|                 getActivity().recreate(); |  | ||||||
|             } |  | ||||||
|             return super.onOptionsItemSelected(item); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |  | ||||||
|         public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { |  | ||||||
|             inflater.inflate(R.menu.settings_theme, menu); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @TargetApi(Build.VERSION_CODES.HONEYCOMB) |  | ||||||
|     public static class OfflinePreferenceFragment extends PreferenceFragment { |  | ||||||
|         @Override |  | ||||||
|         public void onCreate(Bundle savedInstanceState) { |  | ||||||
|             super.onCreate(savedInstanceState); |  | ||||||
|             addPreferencesFromResource(R.xml.pref_offline); |  | ||||||
|             setHasOptionsMenu(true); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @TargetApi(Build.VERSION_CODES.HONEYCOMB) |  | ||||||
|     public static class ExperimentalPreferenceFragment extends PreferenceFragment { |  | ||||||
|         @Override |  | ||||||
|         public void onCreate(Bundle savedInstanceState) { |  | ||||||
|             super.onCreate(savedInstanceState); |  | ||||||
|             addPreferencesFromResource(R.xml.pref_experimental); |  | ||||||
|             setHasOptionsMenu(true); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean onOptionsItemSelected(MenuItem item) { |  | ||||||
|         int id = item.getItemId(); |  | ||||||
|         if (id == android.R.id.home) { |  | ||||||
|             super.onBackPressed(); |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|         return super.onOptionsItemSelected(item); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -0,0 +1,221 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.settings | ||||||
|  |  | ||||||
|  | import android.content.Intent | ||||||
|  | import android.net.Uri | ||||||
|  | import android.os.Bundle | ||||||
|  | import android.text.* | ||||||
|  | import androidx.preference.EditTextPreference | ||||||
|  | import androidx.preference.PreferenceManager | ||||||
|  | import android.view.* | ||||||
|  | import android.widget.Toast | ||||||
|  | import androidx.appcompat.app.AppCompatActivity | ||||||
|  | import androidx.core.widget.addTextChangedListener | ||||||
|  | import androidx.preference.Preference | ||||||
|  | import androidx.preference.PreferenceFragmentCompat | ||||||
|  | import apps.amine.bou.readerforselfoss.R | ||||||
|  | import apps.amine.bou.readerforselfoss.databinding.ActivitySettingsBinding | ||||||
|  | import apps.amine.bou.readerforselfoss.themes.Toppings | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
|  | import com.ftinc.scoop.Scoop | ||||||
|  | import java.lang.NumberFormatException | ||||||
|  |  | ||||||
|  | private const val TITLE_TAG = "settingsActivityTitle" | ||||||
|  |  | ||||||
|  | class SettingsActivity : AppCompatActivity(), | ||||||
|  |         PreferenceFragmentCompat.OnPreferenceStartFragmentCallback { | ||||||
|  |  | ||||||
|  |     override fun onCreate(savedInstanceState: Bundle?) { | ||||||
|  |         super.onCreate(savedInstanceState) | ||||||
|  |         if (PreferenceManager.getDefaultSharedPreferences(this).getBoolean("dark_theme", false)) { | ||||||
|  |             setTheme(R.style.NoBarDark) | ||||||
|  |         } | ||||||
|  |         val binding = ActivitySettingsBinding.inflate(layoutInflater) | ||||||
|  |  | ||||||
|  |         val scoop = Scoop.getInstance() | ||||||
|  |         scoop.bind(this, Toppings.PRIMARY.value, binding.toolbar) | ||||||
|  |         scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|  |  | ||||||
|  |         setContentView(binding.root) | ||||||
|  |         if (savedInstanceState == null) { | ||||||
|  |             supportFragmentManager | ||||||
|  |                     .beginTransaction() | ||||||
|  |                     .replace(R.id.settings, MainPreferenceFragment()) | ||||||
|  |                     .commit() | ||||||
|  |         } else { | ||||||
|  |             title = savedInstanceState.getCharSequence(TITLE_TAG) | ||||||
|  |         } | ||||||
|  |         supportFragmentManager.addOnBackStackChangedListener { | ||||||
|  |             if (supportFragmentManager.backStackEntryCount == 0) { | ||||||
|  |                 setTitle(R.string.title_activity_settings) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         setSupportActionBar(binding.toolbar) | ||||||
|  |  | ||||||
|  |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
|  |         supportActionBar?.setDisplayShowHomeEnabled(true) | ||||||
|  |         supportActionBar?.title = title | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     override fun onSaveInstanceState(outState: Bundle) { | ||||||
|  |         super.onSaveInstanceState(outState) | ||||||
|  |         // Save current activity title so we can set it again after a configuration change | ||||||
|  |         outState.putCharSequence(TITLE_TAG, title) | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     override fun onSupportNavigateUp(): Boolean { | ||||||
|  |         if (supportFragmentManager.popBackStackImmediate()) { | ||||||
|  |             supportActionBar?.title = getText(R.string.title_activity_settings) | ||||||
|  |             return true | ||||||
|  |         } | ||||||
|  |         return super.onSupportNavigateUp() | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     override fun onPreferenceStartFragment( | ||||||
|  |             caller: PreferenceFragmentCompat, | ||||||
|  |             pref: Preference | ||||||
|  |     ): Boolean { | ||||||
|  |         // Instantiate the new Fragment | ||||||
|  |         val args = pref.extras | ||||||
|  |         val fragment = supportFragmentManager.fragmentFactory.instantiate( | ||||||
|  |                 classLoader, | ||||||
|  |                 pref.fragment | ||||||
|  |         ).apply { | ||||||
|  |             arguments = args | ||||||
|  |             setTargetFragment(caller, 0) | ||||||
|  |         } | ||||||
|  |         // Replace the existing Fragment with the new Fragment | ||||||
|  |         supportFragmentManager.beginTransaction() | ||||||
|  |                 .replace(R.id.settings, fragment) | ||||||
|  |                 .addToBackStack(null) | ||||||
|  |                 .commit() | ||||||
|  |         title = pref.title | ||||||
|  |         supportActionBar?.title = title | ||||||
|  |         return true | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     class MainPreferenceFragment : PreferenceFragmentCompat() { | ||||||
|  |         override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||||
|  |             setPreferencesFromResource(R.xml.pref_main, rootKey) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     class GeneralPreferenceFragment : PreferenceFragmentCompat() { | ||||||
|  |         override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||||
|  |             setPreferencesFromResource(R.xml.pref_general, rootKey) | ||||||
|  |  | ||||||
|  |             val editTextPreference = preferenceManager.findPreference<EditTextPreference>("prefer_api_items_number") | ||||||
|  |             editTextPreference?.setOnBindEditTextListener { editText -> | ||||||
|  |                 editText.inputType = InputType.TYPE_CLASS_NUMBER | ||||||
|  |                 editText.filters = arrayOf( | ||||||
|  |                         InputFilter { source, _, _, dest, _, _ -> | ||||||
|  |                             try { | ||||||
|  |                                 val input: Int = (dest.toString() + source.toString()).toInt() | ||||||
|  |                                 if (input in 1..200) return@InputFilter null | ||||||
|  |                             } catch (nfe: NumberFormatException) { | ||||||
|  |                                 Toast.makeText(activity, R.string.items_number_should_be_number, Toast.LENGTH_LONG).show() | ||||||
|  |                             } | ||||||
|  |                             "" | ||||||
|  |                         } | ||||||
|  |                 ) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     class ArticleViewerPreferenceFragment : PreferenceFragmentCompat() { | ||||||
|  |         override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||||
|  |             setPreferencesFromResource(R.xml.pref_viewer, rootKey) | ||||||
|  |  | ||||||
|  |             val fontSize = preferenceManager.findPreference<EditTextPreference>("reader_font_size") | ||||||
|  |             fontSize?.setOnBindEditTextListener { editText -> | ||||||
|  |                 editText.inputType = InputType.TYPE_CLASS_NUMBER | ||||||
|  |                 editText.addTextChangedListener { object : TextWatcher { | ||||||
|  |                     override fun beforeTextChanged(charSequence: CharSequence, i: Int, i1: Int, i2: Int) {} | ||||||
|  |                     override fun onTextChanged(charSequence: CharSequence, i: Int, i1: Int, i2: Int) {} | ||||||
|  |                     override fun afterTextChanged(editable: Editable) { | ||||||
|  |                         try { | ||||||
|  |                             editText.textSize = editable.toString().toInt().toFloat() | ||||||
|  |                         } catch (e: NumberFormatException) { | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } } | ||||||
|  |                 editText.filters = arrayOf( | ||||||
|  |                         InputFilter { source, _, _, dest, _, _ -> | ||||||
|  |                             try { | ||||||
|  |                                 val input = (dest.toString() + source.toString()).toInt() | ||||||
|  |                                 if (input > 0) return@InputFilter null | ||||||
|  |                             } catch (nfe: NumberFormatException) { | ||||||
|  |                             } | ||||||
|  |                             "" | ||||||
|  |                         } | ||||||
|  |                 ) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     class OfflinePreferenceFragment : PreferenceFragmentCompat() { | ||||||
|  |         override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||||
|  |             setPreferencesFromResource(R.xml.pref_offline, rootKey) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     class ThemePreferenceFragment : PreferenceFragmentCompat() { | ||||||
|  |         override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||||
|  |             setPreferencesFromResource(R.xml.pref_theme, rootKey) | ||||||
|  |             setHasOptionsMenu(true) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) { | ||||||
|  |             super.onCreateOptionsMenu(menu, inflater) | ||||||
|  |             inflater.inflate(R.menu.settings_theme, menu) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         override fun onOptionsItemSelected(item: MenuItem): Boolean { | ||||||
|  |             val id = item.itemId | ||||||
|  |             if (id == R.id.clear) { | ||||||
|  |                 val pref = PreferenceManager.getDefaultSharedPreferences(activity) | ||||||
|  |                 val editor = pref.edit() | ||||||
|  |                 editor.remove("color_primary") | ||||||
|  |                 editor.remove("color_primary_dark") | ||||||
|  |                 editor.remove("color_accent") | ||||||
|  |                 editor.remove("color_accent_dark") | ||||||
|  |                 editor.remove("dark_theme") | ||||||
|  |                 editor.apply() | ||||||
|  |                 requireActivity().recreate() | ||||||
|  |             } | ||||||
|  |             return super.onOptionsItemSelected(item) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     class LinksPreferenceFragment : PreferenceFragmentCompat() { | ||||||
|  |         private fun openUrl(uri: Uri?) { | ||||||
|  |             val browserIntent = Intent(Intent.ACTION_VIEW, uri) | ||||||
|  |             startActivity(browserIntent) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||||
|  |             setPreferencesFromResource(R.xml.pref_links, rootKey) | ||||||
|  |  | ||||||
|  |             preferenceManager.findPreference<Preference>("trackerLink")?.onPreferenceClickListener = Preference.OnPreferenceClickListener { | ||||||
|  |                 openUrl(Uri.parse(Config.trackerUrl)) | ||||||
|  |                 true | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             preferenceManager.findPreference<Preference>("sourceLink")?.onPreferenceClickListener = Preference.OnPreferenceClickListener { | ||||||
|  |                 openUrl(Uri.parse(Config.sourceUrl)) | ||||||
|  |                 false | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             preferenceManager.findPreference<Preference>("translation")?.onPreferenceClickListener = Preference.OnPreferenceClickListener { | ||||||
|  |                 openUrl(Uri.parse(Config.translationUrl)) | ||||||
|  |                 false | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     class ExperimentalPreferenceFragment : PreferenceFragmentCompat() { | ||||||
|  |         override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||||
|  |             setPreferencesFromResource(R.xml.pref_experimental, rootKey) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -1,14 +1,9 @@ | |||||||
| package apps.amine.bou.readerforselfoss.themes | package apps.amine.bou.readerforselfoss.themes | ||||||
|  |  | ||||||
| import android.app.Activity | import android.app.Activity | ||||||
| import android.content.Context |  | ||||||
| import android.preference.PreferenceManager |  | ||||||
| import androidx.annotation.ColorInt | import androidx.annotation.ColorInt | ||||||
| import androidx.appcompat.view.ContextThemeWrapper | import androidx.preference.PreferenceManager | ||||||
| import android.util.TypedValue |  | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
| import android.view.LayoutInflater |  | ||||||
| import android.view.ViewGroup |  | ||||||
|  |  | ||||||
| class AppColors(a: Activity) { | class AppColors(a: Activity) { | ||||||
|  |  | ||||||
| @@ -16,7 +11,6 @@ class AppColors(a: Activity) { | |||||||
|     @ColorInt val colorPrimaryDark: Int |     @ColorInt val colorPrimaryDark: Int | ||||||
|     @ColorInt val colorAccent: Int |     @ColorInt val colorAccent: Int | ||||||
|     @ColorInt val colorAccentDark: Int |     @ColorInt val colorAccentDark: Int | ||||||
|     @ColorInt val cardBackgroundColor: Int |  | ||||||
|     @ColorInt val colorBackground: Int |     @ColorInt val colorBackground: Int | ||||||
|     @ColorInt val textColor: Int |     @ColorInt val textColor: Int | ||||||
|     val isDarkTheme: Boolean |     val isDarkTheme: Boolean | ||||||
| @@ -55,7 +49,7 @@ class AppColors(a: Activity) { | |||||||
|             R.color.darkBackground |             R.color.darkBackground | ||||||
|         } else { |         } else { | ||||||
|             a.setTheme(R.style.NoBar) |             a.setTheme(R.style.NoBar) | ||||||
|             android.R.color.background_light |             R.color.grey_50 | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         textColor = if (isDarkTheme) { |         textColor = if (isDarkTheme) { | ||||||
| @@ -63,14 +57,5 @@ class AppColors(a: Activity) { | |||||||
|         } else { |         } else { | ||||||
|             R.color.grey_900 |             R.color.grey_900 | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         val wrapper = Context::class.java |  | ||||||
|         val method = wrapper!!.getMethod("getThemeResId") |  | ||||||
|         method.isAccessible = true |  | ||||||
|  |  | ||||||
|         val typedCardBackground = TypedValue() |  | ||||||
|         a.theme.resolveAttribute(R.attr.cardBackgroundColor, typedCardBackground, true) |  | ||||||
|  |  | ||||||
|         cardBackgroundColor = typedCardBackground.data |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,43 +0,0 @@ | |||||||
| package apps.amine.bou.readerforselfoss.transformers |  | ||||||
|  |  | ||||||
| import androidx.viewpager.widget.ViewPager |  | ||||||
| import android.view.View |  | ||||||
|  |  | ||||||
| class DepthPageTransformer : ViewPager.PageTransformer { |  | ||||||
|  |  | ||||||
|     override fun transformPage(view: View, position: Float) { |  | ||||||
|         val pageWidth = view.width |  | ||||||
|  |  | ||||||
|         when { |  | ||||||
|             position < -1 -> // [-Infinity,-1) |  | ||||||
|                 // This page is way off-screen to the left. |  | ||||||
|                 view.alpha = 0F |  | ||||||
|             position <= 0 -> { // [-1,0] |  | ||||||
|                 // Use the default slide transition when moving to the left page |  | ||||||
|                 view.alpha = 1F |  | ||||||
|                 view.translationX = 0F |  | ||||||
|                 view.scaleX = 1F |  | ||||||
|                 view.scaleY = 1F |  | ||||||
|             } |  | ||||||
|             position <= 1 -> { // (0,1] |  | ||||||
|                 // Fade the page out. |  | ||||||
|                 view.alpha = 1 - position |  | ||||||
|  |  | ||||||
|                 // Counteract the default slide transition |  | ||||||
|                 view.translationX = pageWidth * -position |  | ||||||
|  |  | ||||||
|                 // Scale the page down (between MIN_SCALE and 1) |  | ||||||
|                 val scaleFactor = MIN_SCALE + (1 - MIN_SCALE) * (1 - Math.abs(position)) |  | ||||||
|                 view.scaleX = scaleFactor |  | ||||||
|                 view.scaleY = scaleFactor |  | ||||||
|             } |  | ||||||
|             else -> // (1,+Infinity] |  | ||||||
|                 // This page is way off-screen to the right. |  | ||||||
|                 view.alpha = 0F |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     companion object { |  | ||||||
|         private val MIN_SCALE = 0.75f |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -13,7 +13,7 @@ fun String.longHash(): Long { | |||||||
|     val chars = this.toCharArray() |     val chars = this.toCharArray() | ||||||
|  |  | ||||||
|     for (i in 0 until l) { |     for (i in 0 until l) { | ||||||
|         h = 31 * h + chars[i].toLong() |         h = 31 * h + chars[i].code.toLong() | ||||||
|     } |     } | ||||||
|     return h |     return h | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,11 +4,12 @@ import android.app.Activity | |||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.content.SharedPreferences | import android.content.SharedPreferences | ||||||
|  | import androidx.preference.PreferenceManager | ||||||
| import apps.amine.bou.readerforselfoss.LoginActivity | import apps.amine.bou.readerforselfoss.LoginActivity | ||||||
|  |  | ||||||
| class Config(c: Context) { | class Config(c: Context) { | ||||||
|  |  | ||||||
|     val settings: SharedPreferences = c.getSharedPreferences(settingsName, Context.MODE_PRIVATE) |     val settings: SharedPreferences = PreferenceManager.getDefaultSharedPreferences(c) | ||||||
|  |  | ||||||
|     val baseUrl: String |     val baseUrl: String | ||||||
|         get() = settings.getString("url", "")!! |         get() = settings.getString("url", "")!! | ||||||
| @@ -40,18 +41,17 @@ class Config(c: Context) { | |||||||
|  |  | ||||||
|         const val newItemsChannelId = "new-items-channel-id" |         const val newItemsChannelId = "new-items-channel-id" | ||||||
|  |  | ||||||
|         var dateTimeFormatter = "yyyy-MM-dd HH:mm:ss" |         var apiVersion = 0 | ||||||
|  |  | ||||||
|  |         /* Execute logout and clear all settings to default */ | ||||||
|         fun logoutAndRedirect( |         fun logoutAndRedirect( | ||||||
|             c: Context, |             c: Context, | ||||||
|             callingActivity: Activity, |             callingActivity: Activity, | ||||||
|             editor: SharedPreferences.Editor, |             editor: SharedPreferences.Editor, | ||||||
|             baseUrlFail: Boolean = false |             baseUrlFail: Boolean = false | ||||||
|         ): Boolean { |         ): Boolean { | ||||||
|             editor.remove("url") |             val settings = PreferenceManager.getDefaultSharedPreferences(c) | ||||||
|             editor.remove("login") |             settings.edit().clear().commit() | ||||||
|             editor.remove("password") |  | ||||||
|             editor.apply() |  | ||||||
|             val intent = Intent(c, LoginActivity::class.java) |             val intent = Intent(c, LoginActivity::class.java) | ||||||
|             if (baseUrlFail) { |             if (baseUrlFail) { | ||||||
|                 intent.putExtra("baseUrlFail", baseUrlFail) |                 intent.putExtra("baseUrlFail", baseUrlFail) | ||||||
|   | |||||||
| @@ -0,0 +1,31 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.utils | ||||||
|  |  | ||||||
|  | import android.text.format.DateUtils | ||||||
|  | import java.time.Instant | ||||||
|  | import java.time.LocalDateTime | ||||||
|  | import java.time.OffsetDateTime | ||||||
|  | import java.time.ZoneOffset | ||||||
|  | import java.time.format.DateTimeFormatter | ||||||
|  |  | ||||||
|  | fun parseDate(dateString: String): Instant { | ||||||
|  |  | ||||||
|  |     val FORMATTERV1 = "yyyy-MM-dd HH:mm:ss" | ||||||
|  |  | ||||||
|  |     return if (Config.apiVersion >= 4) { | ||||||
|  |         OffsetDateTime.parse(dateString).toInstant() | ||||||
|  |     } else { | ||||||
|  |         LocalDateTime.parse(dateString, DateTimeFormatter.ofPattern(FORMATTERV1)).toInstant(ZoneOffset.UTC) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun parseRelativeDate(dateString: String): String { | ||||||
|  |  | ||||||
|  |     val date = parseDate(dateString) | ||||||
|  |  | ||||||
|  |     return " " + DateUtils.getRelativeTimeSpanString( | ||||||
|  |             date.toEpochMilli(), | ||||||
|  |             Instant.now().toEpochMilli(), | ||||||
|  |             DateUtils.MINUTE_IN_MILLIS, | ||||||
|  |             DateUtils.FORMAT_ABBREV_RELATIVE | ||||||
|  |     ) | ||||||
|  | } | ||||||
| @@ -1,16 +1,12 @@ | |||||||
| package apps.amine.bou.readerforselfoss.utils | package apps.amine.bou.readerforselfoss.utils | ||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.text.format.DateUtils |  | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossTagType | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossTagType | ||||||
| import java.text.ParseException |  | ||||||
| import java.text.SimpleDateFormat |  | ||||||
| import java.util.* |  | ||||||
|  |  | ||||||
| fun String.toTextDrawableString(c: Context): String { | fun String.toTextDrawableString(c: Context): String { | ||||||
|     val textDrawable = StringBuilder() |     val textDrawable = StringBuilder() | ||||||
|     for (s in this.split(" ".toRegex()).filter { !it.isEmpty() }.toTypedArray()) { |     for (s in this.split(" ".toRegex()).filter { it.isNotEmpty() }.toTypedArray()) { | ||||||
|         try { |         try { | ||||||
|             textDrawable.append(s[0]) |             textDrawable.append(s[0]) | ||||||
|         } catch (e: StringIndexOutOfBoundsException) { |         } catch (e: StringIndexOutOfBoundsException) { | ||||||
| @@ -20,17 +16,7 @@ fun String.toTextDrawableString(c: Context): String { | |||||||
| } | } | ||||||
|  |  | ||||||
| fun Item.sourceAndDateText(): String { | fun Item.sourceAndDateText(): String { | ||||||
|     val formattedDate: String = try { |     val formattedDate = parseRelativeDate(this.datetime) | ||||||
|         " " + DateUtils.getRelativeTimeSpanString( |  | ||||||
|             SimpleDateFormat(Config.dateTimeFormatter).parse(this.datetime).time, |  | ||||||
|             Date().time, |  | ||||||
|             DateUtils.MINUTE_IN_MILLIS, |  | ||||||
|             DateUtils.FORMAT_ABBREV_RELATIVE |  | ||||||
|         ) |  | ||||||
|     } catch (e: ParseException) { |  | ||||||
|         e.printStackTrace() |  | ||||||
|         "" |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return this.getSourceTitle() + formattedDate |     return this.getSourceTitle() + formattedDate | ||||||
| } | } | ||||||
|   | |||||||
| @@ -86,19 +86,30 @@ fun Context.openItemUrlInternally( | |||||||
|         intent.putExtra("currentItem", currentItem) |         intent.putExtra("currentItem", currentItem) | ||||||
|         app.startActivity(intent) |         app.startActivity(intent) | ||||||
|     } else { |     } else { | ||||||
|         try { |         this.openItemUrlInternalBrowser( | ||||||
|             CustomTabActivityHelper.openCustomTab( |                 linkDecoded, | ||||||
|  |                 customTabsIntent, | ||||||
|  |                 app) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun Context.openItemUrlInternalBrowser( | ||||||
|  |         linkDecoded: String, | ||||||
|  |         customTabsIntent: CustomTabsIntent, | ||||||
|  |         app: Activity | ||||||
|  | ) { | ||||||
|  |     try { | ||||||
|  |         CustomTabActivityHelper.openCustomTab( | ||||||
|                 app, |                 app, | ||||||
|                 customTabsIntent, |                 customTabsIntent, | ||||||
|                 Uri.parse(linkDecoded) |                 Uri.parse(linkDecoded) | ||||||
|             ) { _, uri -> |         ) { _, uri -> | ||||||
|                 val intent = Intent(Intent.ACTION_VIEW, uri) |             val intent = Intent(Intent.ACTION_VIEW, uri) | ||||||
|                 intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK |             intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK | ||||||
|                 startActivity(intent) |             startActivity(intent) | ||||||
|             } |  | ||||||
|         } catch (e: Exception) { |  | ||||||
|             openInBrowser(linkDecoded, app) |  | ||||||
|         } |         } | ||||||
|  |     } catch (e: Exception) { | ||||||
|  |         openInBrowser(linkDecoded, app) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -121,7 +132,7 @@ fun Context.openItemUrl( | |||||||
|     } else { |     } else { | ||||||
|         if (!internalBrowser) { |         if (!internalBrowser) { | ||||||
|             openInBrowser(linkDecoded, app) |             openInBrowser(linkDecoded, app) | ||||||
|         } else { |         } else if (articleViewer) { | ||||||
|             this.openItemUrlInternally( |             this.openItemUrlInternally( | ||||||
|                 allItems, |                 allItems, | ||||||
|                 currentItem, |                 currentItem, | ||||||
| @@ -130,6 +141,12 @@ fun Context.openItemUrl( | |||||||
|                 articleViewer, |                 articleViewer, | ||||||
|                 app |                 app | ||||||
|             ) |             ) | ||||||
|  |         } else { | ||||||
|  |             this.openItemUrlInternalBrowser( | ||||||
|  |                     linkDecoded, | ||||||
|  |                     customTabsIntent, | ||||||
|  |                     app | ||||||
|  |             ) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -398,7 +398,7 @@ object SharedItems { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun sortItems() { |     private fun sortItems() { | ||||||
|         val tmpItems = ArrayList(items.sortedByDescending { SimpleDateFormat(Config.dateTimeFormatter).parse((it.datetime)) }) |         val tmpItems = ArrayList(items.sortedByDescending { parseDate(it.datetime) }) | ||||||
|         items = tmpItems |         items = tmpItems | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -1,5 +0,0 @@ | |||||||
| <vector android:height="24dp" android:tint="#FFFFFF" |  | ||||||
|     android:viewportHeight="24.0" android:viewportWidth="24.0" |  | ||||||
|     android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android"> |  | ||||||
|     <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,2zM13,17h-2v-6h2v6zM13,9h-2L11,7h2v2z"/> |  | ||||||
| </vector> |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| <vector xmlns:android="http://schemas.android.com/apk/res/android" |  | ||||||
|         android:width="24dp" |  | ||||||
|         android:height="24dp" |  | ||||||
|         android:viewportWidth="24.0" |  | ||||||
|         android:viewportHeight="24.0"> |  | ||||||
|     <path |  | ||||||
|         android:fillColor="#FF000000" |  | ||||||
|         android:pathData="M15.5,14h-0.79l-0.28,-0.27C15.41,12.59 16,11.11 16,9.5 16,5.91 13.09,3 9.5,3S3,5.91 3,9.5 5.91,16 9.5,16c1.61,0 3.09,-0.59 4.23,-1.57l0.27,0.28v0.79l5,4.99L20.49,19l-4.99,-5zM9.5,14C7.01,14 5,11.99 5,9.5S7.01,5 9.5,5 14,7.01 14,9.5 11.99,14 9.5,14z"/> |  | ||||||
| </vector> |  | ||||||
| @@ -1,5 +0,0 @@ | |||||||
| <vector android:height="24dp" android:tint="#FFFFFF" |  | ||||||
|     android:viewportHeight="24.0" android:viewportWidth="24.0" |  | ||||||
|     android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android"> |  | ||||||
|     <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> |  | ||||||
| @@ -1,5 +0,0 @@ | |||||||
| <vector android:height="24dp" android:tint="#FFFFFF" |  | ||||||
|     android:viewportHeight="24.0" android:viewportWidth="24.0" |  | ||||||
|     android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android"> |  | ||||||
|     <path android:fillColor="#FF000000" android:pathData="M23.64,7c-0.45,-0.34 -4.93,-4 -11.64,-4 -1.5,0 -2.89,0.19 -4.15,0.48L18.18,13.8 23.64,7zM17.04,15.22L3.27,1.44 2,2.72l2.05,2.06C1.91,5.76 0.59,6.82 0.36,7l11.63,14.49 0.01,0.01 0.01,-0.01 3.9,-4.86 3.32,3.32 1.27,-1.27 -3.46,-3.46z"/> |  | ||||||
| </vector> |  | ||||||
| @@ -1,5 +0,0 @@ | |||||||
| <vector android:height="24dp" android:tint="#FFFFFF" |  | ||||||
|     android:viewportHeight="24.0" android:viewportWidth="24.0" |  | ||||||
|     android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android"> |  | ||||||
|     <path android:fillColor="#FF000000" android:pathData="M13,13v8h8v-8h-8zM3,21h8v-8L3,13v8zM3,3v8h8L11,3L3,3zM16.66,1.69L11,7.34 16.66,13l5.66,-5.66 -5.66,-5.65z"/> |  | ||||||
| </vector> |  | ||||||
| @@ -7,7 +7,7 @@ | |||||||
|     tools:context="apps.amine.bou.readerforselfoss.AddSourceActivity"> |     tools:context="apps.amine.bou.readerforselfoss.AddSourceActivity"> | ||||||
|     <LinearLayout |     <LinearLayout | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="match_parent" |         android:layout_height="wrap_content" | ||||||
|         android:orientation="vertical"> |         android:orientation="vertical"> | ||||||
|  |  | ||||||
|         <com.google.android.material.appbar.AppBarLayout |         <com.google.android.material.appbar.AppBarLayout | ||||||
| @@ -55,7 +55,8 @@ | |||||||
|                 android:layout_marginRight="16dp" |                 android:layout_marginRight="16dp" | ||||||
|                 android:layout_marginStart="16dp" |                 android:layout_marginStart="16dp" | ||||||
|                 app:layout_constraintLeft_toLeftOf="parent" |                 app:layout_constraintLeft_toLeftOf="parent" | ||||||
|                 android:layout_marginLeft="16dp"/> |                 android:layout_marginLeft="16dp" | ||||||
|  |                 android:gravity="center_horizontal" /> | ||||||
|  |  | ||||||
|             <EditText |             <EditText | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
| @@ -67,7 +68,9 @@ | |||||||
|                 app:layout_constraintLeft_toLeftOf="parent" |                 app:layout_constraintLeft_toLeftOf="parent" | ||||||
|                 app:layout_constraintRight_toRightOf="parent" |                 app:layout_constraintRight_toRightOf="parent" | ||||||
|                 android:inputType="text" |                 android:inputType="text" | ||||||
|                 android:hint="@string/add_source_hint_name"/> |                 android:hint="@string/add_source_hint_name" | ||||||
|  |                 android:textColorHint="?android:textColorPrimary" | ||||||
|  |                 android:autofillHints="false" /> | ||||||
|  |  | ||||||
|             <EditText |             <EditText | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
| @@ -76,10 +79,12 @@ | |||||||
|                 android:ems="10" |                 android:ems="10" | ||||||
|                 android:id="@+id/sourceUri" |                 android:id="@+id/sourceUri" | ||||||
|                 android:hint="@string/add_source_hint_url" |                 android:hint="@string/add_source_hint_url" | ||||||
|  |                 android:textColorHint="?android:textColorPrimary" | ||||||
|                 android:layout_marginTop="16dp" |                 android:layout_marginTop="16dp" | ||||||
|                 app:layout_constraintTop_toBottomOf="@+id/nameInput" |                 app:layout_constraintTop_toBottomOf="@+id/nameInput" | ||||||
|                 app:layout_constraintRight_toRightOf="parent" |                 app:layout_constraintRight_toRightOf="parent" | ||||||
|                 app:layout_constraintLeft_toLeftOf="parent"/> |                 app:layout_constraintLeft_toLeftOf="parent" | ||||||
|  |                 android:autofillHints="false" /> | ||||||
|  |  | ||||||
|             <EditText |             <EditText | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
| @@ -91,7 +96,9 @@ | |||||||
|                 android:layout_marginTop="16dp" |                 android:layout_marginTop="16dp" | ||||||
|                 app:layout_constraintTop_toBottomOf="@+id/sourceUri" |                 app:layout_constraintTop_toBottomOf="@+id/sourceUri" | ||||||
|                 android:hint="@string/add_source_hint_tags" |                 android:hint="@string/add_source_hint_tags" | ||||||
|                 android:inputType="text"/> |                 android:textColorHint="?android:textColorPrimary" | ||||||
|  |                 android:inputType="text" | ||||||
|  |                 android:autofillHints="false" /> | ||||||
|  |  | ||||||
|             <Spinner |             <Spinner | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
| @@ -100,7 +107,8 @@ | |||||||
|                 app:layout_constraintTop_toBottomOf="@+id/tags" |                 app:layout_constraintTop_toBottomOf="@+id/tags" | ||||||
|                 app:layout_constraintRight_toRightOf="parent" |                 app:layout_constraintRight_toRightOf="parent" | ||||||
|                 app:layout_constraintLeft_toLeftOf="parent" |                 app:layout_constraintLeft_toLeftOf="parent" | ||||||
|                 android:layout_height="40dp"/> |                 android:layout_height="40dp" | ||||||
|  |                 android:theme="@style/App.Spinner"/> | ||||||
|  |  | ||||||
|             <Button |             <Button | ||||||
|                 android:text="@string/add_source_save" |                 android:text="@string/add_source_save" | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ | |||||||
|  |  | ||||||
|     </com.google.android.material.appbar.AppBarLayout> |     </com.google.android.material.appbar.AppBarLayout> | ||||||
|  |  | ||||||
|     <androidx.viewpager.widget.ViewPager |     <androidx.viewpager2.widget.ViewPager2 | ||||||
|         android:id="@+id/pager" |         android:id="@+id/pager" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="0dp" |         android:layout_height="0dp" | ||||||
|   | |||||||
| @@ -45,98 +45,69 @@ | |||||||
|                 android:layout_height="wrap_content" |                 android:layout_height="wrap_content" | ||||||
|                 android:orientation="vertical"> |                 android:orientation="vertical"> | ||||||
|  |  | ||||||
|                 <com.google.android.material.textfield.TextInputLayout |                 <EditText | ||||||
|  |                     android:id="@+id/urlView" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:id="@+id/urlLayout" |                     android:hint="@string/prompt_url" | ||||||
|                     > |                     android:imeOptions="actionUnspecified" | ||||||
|  |                     android:importantForAutofill="no" | ||||||
|  |                     android:inputType="textUri" | ||||||
|  |                     android:maxLines="1" /> | ||||||
|  |  | ||||||
|                     <EditText |                 <com.google.android.material.switchmaterial.SwitchMaterial | ||||||
|                         android:id="@+id/urlView" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:hint="@string/prompt_url" |  | ||||||
|                         android:imeOptions="actionUnspecified" |  | ||||||
|                         android:inputType="textUri" |  | ||||||
|                         android:maxLines="1" /> |  | ||||||
|  |  | ||||||
|                 </com.google.android.material.textfield.TextInputLayout> |  | ||||||
|  |  | ||||||
|                 <Switch |  | ||||||
|                     android:text="@string/withLoginSwitch" |                     android:text="@string/withLoginSwitch" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="0dp" |                     android:layout_height="0dp" | ||||||
|                     android:id="@+id/withLogin" |                     android:id="@+id/withLogin" | ||||||
|                     android:layout_weight="1"/> |                     android:layout_weight="1"/> | ||||||
|  |  | ||||||
|                 <com.google.android.material.textfield.TextInputLayout |                 <EditText | ||||||
|                     android:id="@+id/loginLayout" |                     android:id="@+id/loginView" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:visibility="gone"> |                     android:autofillHints="username" | ||||||
|  |                     android:hint="@string/prompt_login" | ||||||
|  |                     android:inputType="text" | ||||||
|  |                     android:maxLines="1" | ||||||
|  |                     android:visibility="gone" /> | ||||||
|  |  | ||||||
|                     <AutoCompleteTextView |                 <EditText | ||||||
|                         android:id="@+id/loginView" |                     android:id="@+id/passwordView" | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:hint="@string/prompt_login" |  | ||||||
|                         android:inputType="text" |  | ||||||
|                         android:maxLines="1" /> |  | ||||||
|  |  | ||||||
|                 </com.google.android.material.textfield.TextInputLayout> |  | ||||||
|  |  | ||||||
|                 <com.google.android.material.textfield.TextInputLayout |  | ||||||
|                     android:id="@+id/passwordLayout" |  | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:visibility="gone"> |                     android:autofillHints="password" | ||||||
|  |                     android:hint="@string/prompt_password" | ||||||
|  |                     android:inputType="textPassword" | ||||||
|  |                     android:maxLines="1" | ||||||
|  |                     android:visibility="gone" /> | ||||||
|  |  | ||||||
|                     <EditText |                 <com.google.android.material.switchmaterial.SwitchMaterial | ||||||
|                         android:id="@+id/passwordView" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:hint="@string/prompt_password" |  | ||||||
|                         android:inputType="textPassword" |  | ||||||
|                         android:maxLines="1" /> |  | ||||||
|  |  | ||||||
|                 </com.google.android.material.textfield.TextInputLayout> |  | ||||||
|  |  | ||||||
|                 <Switch |  | ||||||
|                     android:id="@+id/withHttpLogin" |                     android:id="@+id/withHttpLogin" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:layout_weight="1" |                     android:layout_weight="1" | ||||||
|                     android:text="@string/withHttpLoginSwitch" /> |                     android:text="@string/withHttpLoginSwitch" /> | ||||||
|  |  | ||||||
|                 <com.google.android.material.textfield.TextInputLayout |                 <EditText | ||||||
|                     android:id="@+id/httpLoginInput" |                     android:id="@+id/httpLoginView" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="match_parent" |                     android:layout_height="wrap_content" | ||||||
|                     android:visibility="gone"> |                     android:autofillHints="username" | ||||||
|  |                     android:hint="@string/prompt_http_login" | ||||||
|  |                     android:inputType="text" | ||||||
|  |                     android:visibility="gone" /> | ||||||
|  |  | ||||||
|                     <EditText |                 <EditText | ||||||
|                         android:inputType="text" |                     android:id="@+id/httpPasswordView" | ||||||
|                         android:id="@+id/httpLoginView" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:hint="@string/prompt_http_login" /> |  | ||||||
|                 </com.google.android.material.textfield.TextInputLayout> |  | ||||||
|  |  | ||||||
|                 <com.google.android.material.textfield.TextInputLayout |  | ||||||
|                     android:id="@+id/httpPasswordInput" |  | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="match_parent" |                     android:layout_height="wrap_content" | ||||||
|                     android:visibility="gone"> |                     android:autofillHints="password" | ||||||
|  |                     android:hint="@string/prompt_http_password" | ||||||
|  |                     android:inputType="textPassword" | ||||||
|  |                     android:visibility="gone" /> | ||||||
|  |  | ||||||
|                     <EditText |                 <com.google.android.material.switchmaterial.SwitchMaterial | ||||||
|                         android:id="@+id/httpPasswordView" |  | ||||||
|                         android:layout_width="match_parent" |  | ||||||
|                         android:layout_height="wrap_content" |  | ||||||
|                         android:hint="@string/prompt_http_password" |  | ||||||
|                         android:inputType="textPassword" /> |  | ||||||
|                 </com.google.android.material.textfield.TextInputLayout> |  | ||||||
|  |  | ||||||
|                 <Switch |  | ||||||
|                     android:id="@+id/withSelfhostedCert" |                     android:id="@+id/withSelfhostedCert" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
| @@ -155,8 +126,8 @@ | |||||||
|                     style="?android:textAppearanceSmall" |                     style="?android:textAppearanceSmall" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:layout_marginBottom="16dp" |  | ||||||
|                     android:layout_marginTop="16dp" |                     android:layout_marginTop="16dp" | ||||||
|  |                     android:layout_marginBottom="16dp" | ||||||
|                     android:text="@string/action_sign_in" |                     android:text="@string/action_sign_in" | ||||||
|                     android:textStyle="bold" /> |                     android:textStyle="bold" /> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,7 +22,7 @@ | |||||||
|  |  | ||||||
|     </com.google.android.material.appbar.AppBarLayout> |     </com.google.android.material.appbar.AppBarLayout> | ||||||
|  |  | ||||||
|     <androidx.viewpager.widget.ViewPager |     <androidx.viewpager2.widget.ViewPager2 | ||||||
|         android:id="@+id/pager" |         android:id="@+id/pager" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="0dp" |         android:layout_height="0dp" | ||||||
| @@ -33,7 +33,7 @@ | |||||||
|         app:layout_constraintTop_toBottomOf="@+id/appBarLayout" /> |         app:layout_constraintTop_toBottomOf="@+id/appBarLayout" /> | ||||||
|  |  | ||||||
|  |  | ||||||
|     <me.relex.circleindicator.CircleIndicator |     <me.relex.circleindicator.CircleIndicator3 | ||||||
|         android:id="@+id/indicator" |         android:id="@+id/indicator" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="20dp" |         android:layout_height="20dp" | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								app/src/main/res/layout/activity_settings.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								app/src/main/res/layout/activity_settings.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     android:id="@+id/layout" | ||||||
|  |     android:layout_width="match_parent" | ||||||
|  |     android:layout_height="match_parent" | ||||||
|  |     android:orientation="vertical"> | ||||||
|  |  | ||||||
|  |     <com.google.android.material.appbar.AppBarLayout | ||||||
|  |         android:layout_width="match_parent" | ||||||
|  |         android:layout_height="wrap_content"> | ||||||
|  |  | ||||||
|  |         <androidx.appcompat.widget.Toolbar | ||||||
|  |             android:id="@+id/toolbar" | ||||||
|  |             android:layout_width="match_parent" | ||||||
|  |             android:layout_height="?attr/actionBarSize" | ||||||
|  |             android:theme="@style/ToolBarStyle" /> | ||||||
|  |     </com.google.android.material.appbar.AppBarLayout> | ||||||
|  |  | ||||||
|  |     <FrameLayout | ||||||
|  |         android:id="@+id/settings" | ||||||
|  |         android:layout_width="match_parent" | ||||||
|  |         android:layout_height="match_parent" /> | ||||||
|  | </LinearLayout> | ||||||
| @@ -31,14 +31,13 @@ | |||||||
|         android:id="@+id/fab" |         android:id="@+id/fab" | ||||||
|         android:layout_width="wrap_content" |         android:layout_width="wrap_content" | ||||||
|         android:layout_height="wrap_content" |         android:layout_height="wrap_content" | ||||||
|         android:layout_gravity="end|bottom|right" |         android:layout_gravity="end|bottom|end" | ||||||
|         android:src="@drawable/ic_add_white_24dp" |         app:srcCompat="@drawable/ic_add_white_24dp" | ||||||
|         android:paddingBottom="@dimen/activity_vertical_margin" |         android:paddingBottom="@dimen/activity_vertical_margin" | ||||||
|         android:paddingTop="@dimen/activity_vertical_margin" |         android:paddingTop="@dimen/activity_vertical_margin" | ||||||
|         android:layout_alignParentBottom="true" |         android:layout_alignParentBottom="true" | ||||||
|         android:layout_alignParentRight="true" |  | ||||||
|         android:layout_alignParentEnd="true" |         android:layout_alignParentEnd="true" | ||||||
|         android:layout_marginBottom="16dp" |         android:layout_marginBottom="16dp" | ||||||
|         android:layout_marginEnd="16dp" |         android:layout_marginEnd="16dp" | ||||||
|         android:layout_marginRight="16dp"/> |         android:contentDescription="@string/add_source" /> | ||||||
| </androidx.coordinatorlayout.widget.CoordinatorLayout> | </androidx.coordinatorlayout.widget.CoordinatorLayout> | ||||||
|   | |||||||
| @@ -16,7 +16,8 @@ | |||||||
|     app:layout_constraintTop_toTopOf="parent" |     app:layout_constraintTop_toTopOf="parent" | ||||||
|     card_view:cardElevation="2dp" |     card_view:cardElevation="2dp" | ||||||
|     card_view:cardUseCompatPadding="true" |     card_view:cardUseCompatPadding="true" | ||||||
|     card_view:layout_constraintBottom_toBottomOf="parent"> |     card_view:layout_constraintBottom_toBottomOf="parent" | ||||||
|  |     app:cardBackgroundColor="?cardBackgroundColor"> | ||||||
|  |  | ||||||
|     <androidx.constraintlayout.widget.ConstraintLayout |     <androidx.constraintlayout.widget.ConstraintLayout | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
| @@ -65,6 +66,7 @@ | |||||||
|                 android:gravity="start" |                 android:gravity="start" | ||||||
|                 android:textAlignment="viewStart" |                 android:textAlignment="viewStart" | ||||||
|                 android:textStyle="bold" |                 android:textStyle="bold" | ||||||
|  |                 android:textColor="?android:textColorPrimary" | ||||||
|                 app:layout_constraintHorizontal_bias="0.0" |                 app:layout_constraintHorizontal_bias="0.0" | ||||||
|                 app:layout_constraintLeft_toRightOf="@+id/sourceImage" |                 app:layout_constraintLeft_toRightOf="@+id/sourceImage" | ||||||
|                 app:layout_constraintRight_toRightOf="parent" |                 app:layout_constraintRight_toRightOf="parent" | ||||||
| @@ -79,6 +81,7 @@ | |||||||
|                 android:gravity="start" |                 android:gravity="start" | ||||||
|                 android:textAlignment="viewStart" |                 android:textAlignment="viewStart" | ||||||
|                 android:textSize="14sp" |                 android:textSize="14sp" | ||||||
|  |                 android:textColor="?android:textColorPrimary" | ||||||
|                 app:layout_constraintLeft_toLeftOf="@+id/title" |                 app:layout_constraintLeft_toLeftOf="@+id/title" | ||||||
|                 app:layout_constraintTop_toBottomOf="@+id/title" |                 app:layout_constraintTop_toBottomOf="@+id/title" | ||||||
|                 tools:text="Google Actualité Il y a 5h" /> |                 tools:text="Google Actualité Il y a 5h" /> | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ | |||||||
|     xmlns:tools="http://schemas.android.com/tools" |     xmlns:tools="http://schemas.android.com/tools" | ||||||
|     android:layout_width="match_parent" |     android:layout_width="match_parent" | ||||||
|     android:layout_height="match_parent" |     android:layout_height="match_parent" | ||||||
|  |     android:background="?android:colorBackground" | ||||||
|     android:descendantFocusability="blocksDescendants"> |     android:descendantFocusability="blocksDescendants"> | ||||||
|  |  | ||||||
|     <androidx.core.widget.NestedScrollView |     <androidx.core.widget.NestedScrollView | ||||||
| @@ -33,7 +34,7 @@ | |||||||
|                 android:layout_marginLeft="16dp" |                 android:layout_marginLeft="16dp" | ||||||
|                 android:layout_marginTop="8dp" |                 android:layout_marginTop="8dp" | ||||||
|                 android:layout_marginRight="16dp" |                 android:layout_marginRight="16dp" | ||||||
|                 android:textAppearance="@style/TextAppearance.AppCompat.Small" |                 android:textColor="?android:textColorSecondary" | ||||||
|                 android:textSize="12sp" |                 android:textSize="12sp" | ||||||
|                 app:layout_constraintHorizontal_bias="0.0" |                 app:layout_constraintHorizontal_bias="0.0" | ||||||
|                 app:layout_constraintLeft_toLeftOf="parent" |                 app:layout_constraintLeft_toLeftOf="parent" | ||||||
| @@ -65,6 +66,7 @@ | |||||||
|                 android:layout_marginRight="16dp" |                 android:layout_marginRight="16dp" | ||||||
|                 android:layout_marginTop="24dp" |                 android:layout_marginTop="24dp" | ||||||
|                 android:paddingBottom="48dp" |                 android:paddingBottom="48dp" | ||||||
|  |                 android:background="?android:colorBackground" | ||||||
|                 app:layout_constraintHorizontal_bias="0.0" |                 app:layout_constraintHorizontal_bias="0.0" | ||||||
|                 app:layout_constraintLeft_toLeftOf="parent" |                 app:layout_constraintLeft_toLeftOf="parent" | ||||||
|                 app:layout_constraintRight_toRightOf="parent" |                 app:layout_constraintRight_toRightOf="parent" | ||||||
|   | |||||||
| @@ -12,7 +12,8 @@ | |||||||
|         android:layout_marginStart="8dp" |         android:layout_marginStart="8dp" | ||||||
|         android:layout_marginTop="21dp" |         android:layout_marginTop="21dp" | ||||||
|         app:layout_constraintStart_toStartOf="parent" |         app:layout_constraintStart_toStartOf="parent" | ||||||
|         app:layout_constraintTop_toTopOf="parent" /> |         app:layout_constraintTop_toTopOf="parent" | ||||||
|  |         android:layout_marginLeft="8dp" /> | ||||||
|  |  | ||||||
|     <TextView |     <TextView | ||||||
|         android:id="@+id/title" |         android:id="@+id/title" | ||||||
| @@ -29,11 +30,14 @@ | |||||||
|         android:textAllCaps="false" |         android:textAllCaps="false" | ||||||
|         android:textSize="16sp" |         android:textSize="16sp" | ||||||
|         android:textStyle="bold" |         android:textStyle="bold" | ||||||
|  |         android:textColor="?android:textColorPrimary" | ||||||
|         app:layout_constraintEnd_toEndOf="parent" |         app:layout_constraintEnd_toEndOf="parent" | ||||||
|         app:layout_constraintHorizontal_bias="0.0" |         app:layout_constraintHorizontal_bias="0.0" | ||||||
|         app:layout_constraintStart_toEndOf="@+id/itemImage" |         app:layout_constraintStart_toEndOf="@+id/itemImage" | ||||||
|         app:layout_constraintTop_toTopOf="parent" |         app:layout_constraintTop_toTopOf="parent" | ||||||
|         tools:text="Titre" /> |         tools:text="Titre" | ||||||
|  |         android:layout_marginLeft="8dp" | ||||||
|  |         android:layout_marginRight="16dp" /> | ||||||
|  |  | ||||||
|     <TextView |     <TextView | ||||||
|         android:id="@+id/sourceTitleAndDate" |         android:id="@+id/sourceTitleAndDate" | ||||||
| @@ -46,10 +50,13 @@ | |||||||
|         android:maxLines="1" |         android:maxLines="1" | ||||||
|         android:textAlignment="viewStart" |         android:textAlignment="viewStart" | ||||||
|         android:textSize="14sp" |         android:textSize="14sp" | ||||||
|  |         android:textColor="?android:textColorPrimary" | ||||||
|         app:layout_constraintEnd_toEndOf="parent" |         app:layout_constraintEnd_toEndOf="parent" | ||||||
|         app:layout_constraintHorizontal_bias="0.0" |         app:layout_constraintHorizontal_bias="0.0" | ||||||
|         app:layout_constraintStart_toEndOf="@+id/itemImage" |         app:layout_constraintStart_toEndOf="@+id/itemImage" | ||||||
|         app:layout_constraintTop_toTopOf="parent" |         app:layout_constraintTop_toTopOf="parent" | ||||||
|         tools:text="Google Actualité Il y a 5h" /> |         tools:text="Google Actualité Il y a 5h" | ||||||
|  |         android:layout_marginLeft="8dp" | ||||||
|  |         android:layout_marginRight="16dp" /> | ||||||
|  |  | ||||||
| </androidx.constraintlayout.widget.ConstraintLayout> | </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> |  | ||||||
| <com.google.android.material.appbar.AppBarLayout |  | ||||||
|     xmlns:android="http://schemas.android.com/apk/res/android" |  | ||||||
|     android:layout_width="match_parent" |  | ||||||
|     android:layout_height="wrap_content" |  | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto"> |  | ||||||
|  |  | ||||||
|     <androidx.appcompat.widget.Toolbar |  | ||||||
|         android:id="@+id/toolbar" |  | ||||||
|         android:layout_width="match_parent" |  | ||||||
|         android:layout_height="?attr/actionBarSize" |  | ||||||
|         app:theme="@style/ToolBarStyle" |  | ||||||
|         app:popupTheme="?attr/toolbarPopupTheme" /> |  | ||||||
|  |  | ||||||
| </com.google.android.material.appbar.AppBarLayout> |  | ||||||
| @@ -1,55 +1,50 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <androidx.constraintlayout.widget.ConstraintLayout | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:android="http://schemas.android.com/apk/res/android" |  | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" |     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||||
|     xmlns:tools="http://schemas.android.com/tools" |     xmlns:tools="http://schemas.android.com/tools" | ||||||
|     android:orientation="vertical" |  | ||||||
|     android:layout_width="match_parent" |     android:layout_width="match_parent" | ||||||
|     android:layout_height="48dp"> |     android:layout_height="48dp" | ||||||
|  |     android:orientation="vertical"> | ||||||
|  |  | ||||||
|  |  | ||||||
|     <ImageView |     <ImageView | ||||||
|         android:id="@+id/itemImage" |         android:id="@+id/itemImage" | ||||||
|         app:layout_constraintTop_toTopOf="parent" |  | ||||||
|         app:layout_constraintBottom_toBottomOf="parent" |  | ||||||
|         android:layout_marginStart="16dp" |  | ||||||
|         app:layout_constraintLeft_toLeftOf="parent" |  | ||||||
|         android:layout_marginLeft="16dp" |  | ||||||
|         android:layout_width="36dp" |         android:layout_width="36dp" | ||||||
|         android:layout_height="36dp"/> |         android:layout_height="36dp" | ||||||
|  |         android:importantForAccessibility="no" | ||||||
|  |         app:layout_constraintBottom_toBottomOf="parent" | ||||||
|  |         app:layout_constraintLeft_toLeftOf="parent" | ||||||
|  |         app:layout_constraintTop_toTopOf="parent" /> | ||||||
|  |  | ||||||
|     <TextView |     <TextView | ||||||
|         android:layout_width="wrap_content" |  | ||||||
|         android:layout_height="17dp" |  | ||||||
|         android:id="@+id/sourceTitle" |         android:id="@+id/sourceTitle" | ||||||
|         app:layout_constraintTop_toTopOf="parent" |         android:layout_width="0dp" | ||||||
|         app:layout_constraintBottom_toBottomOf="parent" |         android:layout_height="17dp" | ||||||
|         app:layout_constraintLeft_toRightOf="@+id/itemImage" |         android:layout_marginStart="8dp" | ||||||
|         android:layout_marginStart="16dp" |         android:ellipsize="end" | ||||||
|         android:layout_marginLeft="16dp" |         android:gravity="start" | ||||||
|  |         android:maxLines="1" | ||||||
|  |         android:textAlignment="textStart" | ||||||
|         android:textSize="13sp" |         android:textSize="13sp" | ||||||
|         android:textAlignment="viewStart" |         android:textColor="?android:textColorPrimary" | ||||||
|         tools:text="source title " |         app:layout_constraintBottom_toBottomOf="parent" | ||||||
|         android:gravity="start" /> |         app:layout_constraintEnd_toStartOf="@+id/deleteBtn" | ||||||
|  |         app:layout_constraintStart_toEndOf="@+id/itemImage" | ||||||
|  |         app:layout_constraintTop_toTopOf="parent" | ||||||
|  |         tools:text="source title" /> | ||||||
|  |  | ||||||
|     <Button |     <Button | ||||||
|         android:id="@+id/deleteBtn" |         android:id="@+id/deleteBtn" | ||||||
|         android:background="@drawable/ic_remove_circle_outline_black_24dp" |  | ||||||
|         style="@style/Widget.AppCompat.Button.Borderless" |         style="@style/Widget.AppCompat.Button.Borderless" | ||||||
|  |         android:layout_width="34dp" | ||||||
|  |         android:layout_height="34dp" | ||||||
|  |         android:layout_marginEnd="8dp" | ||||||
|  |         android:background="@drawable/ic_remove_circle_outline_black_24dp" | ||||||
|         android:backgroundTint="?android:textColorSecondary" |         android:backgroundTint="?android:textColorSecondary" | ||||||
|         android:elevation="4dp" |         android:elevation="4dp" | ||||||
|         android:layout_marginTop="16dp" |         android:contentDescription="@string/remove_source" | ||||||
|         app:layout_constraintTop_toTopOf="parent" |  | ||||||
|         app:layout_constraintBottom_toBottomOf="parent" |         app:layout_constraintBottom_toBottomOf="parent" | ||||||
|         android:layout_marginBottom="16dp" |         app:layout_constraintEnd_toEndOf="parent" | ||||||
|         android:layout_marginEnd="16dp" |         app:layout_constraintTop_toTopOf="parent" /> | ||||||
|         app:layout_constraintRight_toRightOf="parent" |  | ||||||
|         android:layout_marginRight="16dp" |  | ||||||
|         android:layout_marginStart="8dp" |  | ||||||
|         app:layout_constraintLeft_toRightOf="@+id/sourceTitle" |  | ||||||
|         android:layout_marginLeft="8dp" |  | ||||||
|         app:layout_constraintHorizontal_bias="1.0" |  | ||||||
|         android:layout_width="34dp" |  | ||||||
|         android:layout_height="34dp"/> |  | ||||||
|  |  | ||||||
| </androidx.constraintlayout.widget.ConstraintLayout> | </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Alinear a la izquierda</string> |     <string name="reader_text_align_left">Alinear a la izquierda</string> | ||||||
|     <string name="reader_text_align_justify">Justificado</string> |     <string name="reader_text_align_justify">Justificado</string> | ||||||
|     <string name="settings_reader_font">Modo lectura</string> |     <string name="settings_reader_font">Modo lectura</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -139,8 +139,8 @@ | |||||||
|     <string name="pref_switch_items_caching_off">Les articles ne seront pas enregistrés et l\'application ne sera pas utilisable hors ligne.</string> |     <string name="pref_switch_items_caching_off">Les articles ne seront pas enregistrés et l\'application ne sera pas utilisable hors ligne.</string> | ||||||
|     <string name="pref_switch_items_caching_on">Les articles seront enregistrés et l\'application sera utilisable hors ligne.</string> |     <string name="pref_switch_items_caching_on">Les articles seront enregistrés et l\'application sera utilisable hors ligne.</string> | ||||||
|     <string name="pref_switch_items_caching">Sauvegarder les articles pour une utilisation hors ligne</string> |     <string name="pref_switch_items_caching">Sauvegarder les articles pour une utilisation hors ligne</string> | ||||||
|     <string name="pref_switch_update_sources">Check for new sources and tags</string> |     <string name="pref_switch_update_sources">Vérifier les nouvelles sources et tags</string> | ||||||
|     <string name="pref_switch_update_sources_summary">Disable this if your server is receiving excessive amounts of database queries.</string> |     <string name="pref_switch_update_sources_summary">Désactivez cette option si votre serveur reçoit trop de requêtes.</string> | ||||||
|     <string name="no_network_connectivity">Hors connexion !</string> |     <string name="no_network_connectivity">Hors connexion !</string> | ||||||
|     <string name="pref_switch_periodic_refresh">Synchroniser les articles</string> |     <string name="pref_switch_periodic_refresh">Synchroniser les articles</string> | ||||||
|     <string name="pref_switch_periodic_refresh_off">Les articles ne seront pas synchronisés en arrière plan</string> |     <string name="pref_switch_periodic_refresh_off">Les articles ne seront pas synchronisés en arrière plan</string> | ||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Aligner à gauche</string> |     <string name="reader_text_align_left">Aligner à gauche</string> | ||||||
|     <string name="reader_text_align_justify">Justifier le texte</string> |     <string name="reader_text_align_justify">Justifier le texte</string> | ||||||
|     <string name="settings_reader_font">Police du lecteur d\'articles</string> |     <string name="settings_reader_font">Police du lecteur d\'articles</string> | ||||||
|  |     <string name="reader_static_bar_title">Barre statique pour le visionneur d\'articles</string> | ||||||
|  |     <string name="reader_static_bar_on">La barre sera affichée</string> | ||||||
|  |     <string name="reader_static_bar_off">La barre sera affichée grâce au bouton</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <resources xmlns:tools="http://schemas.android.com/tools"> | <resources xmlns:tools="http://schemas.android.com/tools"> | ||||||
|     <string name="app_name">"Lector para Selfoss"</string> |     <string name="app_name">"Lector para selfoss"</string> | ||||||
|     <string name="title_activity_login">"Acceder"</string> |     <string name="title_activity_login">"Conectar"</string> | ||||||
|     <string name="prompt_password">"Contrasinal"</string> |     <string name="prompt_password">"Contrasinal"</string> | ||||||
|     <string name="prompt_http_password">"Contrasinal HTTP"</string> |     <string name="prompt_http_password">"Contrasinal HTTP"</string> | ||||||
|     <string name="action_sign_in">"Ir"</string> |     <string name="action_sign_in">"Ir"</string> | ||||||
| @@ -9,7 +9,7 @@ | |||||||
|     <string name="error_field_required">"Campo requirido"</string> |     <string name="error_field_required">"Campo requirido"</string> | ||||||
|     <string name="prompt_url">"URL"</string> |     <string name="prompt_url">"URL"</string> | ||||||
|     <string name="withLoginSwitch">"É preciso iniciar sesión?"</string> |     <string name="withLoginSwitch">"É preciso iniciar sesión?"</string> | ||||||
|     <string name="withHttpLoginSwitch">"É preciso iniciar sesión HTTP?"</string> |     <string name="withHttpLoginSwitch">"É preciso iniciar sesión?"</string> | ||||||
|     <string name="login_url_problem">"Ups! Pode que precises engadir un \"/\" o final da URL."</string> |     <string name="login_url_problem">"Ups! Pode que precises engadir un \"/\" o final da URL."</string> | ||||||
|     <string name="prompt_login">"Nome de usuario"</string> |     <string name="prompt_login">"Nome de usuario"</string> | ||||||
|     <string name="prompt_http_login">"Nome de usuario HTTP"</string> |     <string name="prompt_http_login">"Nome de usuario HTTP"</string> | ||||||
| @@ -139,8 +139,8 @@ | |||||||
|     <string name="pref_switch_items_caching_off">Os artigos non se gardaran na memoria do dispositivo e non se poderá utilizar a aplicación sen conexión.</string> |     <string name="pref_switch_items_caching_off">Os artigos non se gardaran na memoria do dispositivo e non se poderá utilizar a aplicación sen conexión.</string> | ||||||
|     <string name="pref_switch_items_caching_on">Os artigos gardaranse na memoria do dispositivo e estarán dispoñibles sen conexión.</string> |     <string name="pref_switch_items_caching_on">Os artigos gardaranse na memoria do dispositivo e estarán dispoñibles sen conexión.</string> | ||||||
|     <string name="pref_switch_items_caching">Gardar elementos para uso sen conexión</string> |     <string name="pref_switch_items_caching">Gardar elementos para uso sen conexión</string> | ||||||
|     <string name="pref_switch_update_sources">Check for new sources and tags</string> |     <string name="pref_switch_update_sources">Comproba novas fontes e etiquetas</string> | ||||||
|     <string name="pref_switch_update_sources_summary">Disable this if your server is receiving excessive amounts of database queries.</string> |     <string name="pref_switch_update_sources_summary">Deshabilita isto se o teu servidor está recibindo demasiadas peticións de base de datos.</string> | ||||||
|     <string name="no_network_connectivity">Non conectado!</string> |     <string name="no_network_connectivity">Non conectado!</string> | ||||||
|     <string name="pref_switch_periodic_refresh">Sincronizar artigos</string> |     <string name="pref_switch_periodic_refresh">Sincronizar artigos</string> | ||||||
|     <string name="pref_switch_periodic_refresh_off">Os artigos non se sincronizarán coa aplicación de fondo</string> |     <string name="pref_switch_periodic_refresh_off">Os artigos non se sincronizarán coa aplicación de fondo</string> | ||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Aliñar á esquerda</string> |     <string name="reader_text_align_left">Aliñar á esquerda</string> | ||||||
|     <string name="reader_text_align_justify">Xustificado</string> |     <string name="reader_text_align_justify">Xustificado</string> | ||||||
|     <string name="settings_reader_font">Modo lector</string> |     <string name="settings_reader_font">Modo lector</string> | ||||||
|  |     <string name="reader_static_bar_title">Barra inferior estática na vista de artigos</string> | ||||||
|  |     <string name="reader_static_bar_on">A barra inferior mostrarase sempre</string> | ||||||
|  |     <string name="reader_static_bar_off">A barra inferior pode mostrarse a través do botón flotante</string> | ||||||
|  |     <string name="remove_source">Eliminar fonte</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">左对齐</string> |     <string name="reader_text_align_left">左对齐</string> | ||||||
|     <string name="reader_text_align_justify">左右对齐</string> |     <string name="reader_text_align_justify">左右对齐</string> | ||||||
|     <string name="settings_reader_font">阅读器字体</string> |     <string name="settings_reader_font">阅读器字体</string> | ||||||
|  |     <string name="reader_static_bar_title">文章查看器中的静态底部栏</string> | ||||||
|  |     <string name="reader_static_bar_on">底部栏将始终显示</string> | ||||||
|  |     <string name="reader_static_bar_off">底部栏可以通过浮动按钮显示</string> | ||||||
|  |     <string name="remove_source">删除源</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -162,4 +162,8 @@ | |||||||
|     <string name="reader_text_align_left">Align left</string> |     <string name="reader_text_align_left">Align left</string> | ||||||
|     <string name="reader_text_align_justify">Justify</string> |     <string name="reader_text_align_justify">Justify</string> | ||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|     <color name="colorAccent">#FFff5722</color> |     <color name="colorAccent">#FFff5722</color> | ||||||
|     <color name="colorAccentDark">#FFbf360c</color> |     <color name="colorAccentDark">#FFbf360c</color> | ||||||
|     <color name="pink">#FFe91e63</color> |     <color name="pink">#FFe91e63</color> | ||||||
|     <color name="white">#FFFFFFFF</color> |     <color name="white">#FFFFFF</color> | ||||||
|     <color name="black">#FF000000</color> |     <color name="black">#FF000000</color> | ||||||
|     <color name="red">#FF0000</color> |     <color name="red">#FF0000</color> | ||||||
|     <color name="refresh_progress_1">@color/colorAccentDark</color> |     <color name="refresh_progress_1">@color/colorAccentDark</color> | ||||||
| @@ -20,5 +20,5 @@ | |||||||
|  |  | ||||||
|     <color name="cardBackgroundColor">#FFFFFFFF</color> |     <color name="cardBackgroundColor">#FFFFFFFF</color> | ||||||
|     <color name="materialDrawerHeaderSelectionText">#212121</color> |     <color name="materialDrawerHeaderSelectionText">#212121</color> | ||||||
|     <color name="darkBackground">#FF303030</color> |     <color name="darkBackground">#303030</color> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -165,4 +165,8 @@ | |||||||
|     <string name="settings_reader_font">Reader font</string> |     <string name="settings_reader_font">Reader font</string> | ||||||
|     <string name="open_sans_font_id" translatable="false">open_sans</string> |     <string name="open_sans_font_id" translatable="false">open_sans</string> | ||||||
|     <string name="roboto_font_id" translatable="false">roboto</string> |     <string name="roboto_font_id" translatable="false">roboto</string> | ||||||
|  |     <string name="reader_static_bar_title">Static bottom bar in the article viewer</string> | ||||||
|  |     <string name="reader_static_bar_on">The bottom bar will always be displayed</string> | ||||||
|  |     <string name="reader_static_bar_off">The bottom bar can be shown through the floating button</string> | ||||||
|  |     <string name="remove_source">Remove source</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -14,9 +14,10 @@ | |||||||
|         <item name="colorSurface">@color/grey_50</item> |         <item name="colorSurface">@color/grey_50</item> | ||||||
|         <item name="android:textColorPrimary">@color/grey_900</item> |         <item name="android:textColorPrimary">@color/grey_900</item> | ||||||
|         <item name="android:textColorSecondary">@color/grey_400</item> |         <item name="android:textColorSecondary">@color/grey_400</item> | ||||||
|         <item name="materialDrawerStyle">@style/Widget.MaterialDrawerStyle</item> |         <item name="materialDrawerStyle">@style/App.materialDrawerStyle</item> | ||||||
|         <item name="materialDrawerHeaderStyle">@style/Widget.MaterialDrawerHeaderStyle</item> |         <item name="materialDrawerHeaderStyle">@style/Widget.MaterialDrawerHeaderStyle</item> | ||||||
|         <item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item> |         <item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item> | ||||||
|  |         <item name="preferenceTheme">@style/PreferenceStyle</item> | ||||||
|     </style> |     </style> | ||||||
|  |  | ||||||
|     <style name="NoBarDark" parent="Theme.MaterialComponents.DayNight.NoActionBar"> |     <style name="NoBarDark" parent="Theme.MaterialComponents.DayNight.NoActionBar"> | ||||||
| @@ -27,12 +28,14 @@ | |||||||
|         <item name="cardBackgroundColor">@color/grey_800</item> |         <item name="cardBackgroundColor">@color/grey_800</item> | ||||||
|         <item name="android:colorBackground">@color/darkBackground</item> |         <item name="android:colorBackground">@color/darkBackground</item> | ||||||
|         <item name="colorSurface">@color/darkBackground</item> |         <item name="colorSurface">@color/darkBackground</item> | ||||||
|  |         <item name="alertDialogTheme">@style/AlertDialogDark</item> | ||||||
|         <item name="bnbBackgroundColor">@color/grey_900</item> |         <item name="bnbBackgroundColor">@color/grey_900</item> | ||||||
|         <item name="android:textColorPrimary">@color/white</item> |         <item name="android:textColorPrimary">@color/white</item> | ||||||
|         <item name="android:textColorSecondary">@color/grey_600</item> |         <item name="android:textColorSecondary">@color/grey_600</item> | ||||||
|         <item name="materialDrawerStyle">@style/Widget.MaterialDrawerStyle</item> |         <item name="materialDrawerStyle">@style/App.materialDrawerStyle</item> | ||||||
|         <item name="materialDrawerHeaderStyle">@style/Widget.MaterialDrawerHeaderStyle</item> |         <item name="materialDrawerHeaderStyle">@style/Widget.MaterialDrawerHeaderStyle</item> | ||||||
|         <item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Dark</item> |         <item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Dark</item> | ||||||
|  |         <item name="preferenceTheme">@style/PreferenceStyle</item> | ||||||
|     </style> |     </style> | ||||||
|  |  | ||||||
|     <!-- ToolBar --> |     <!-- ToolBar --> | ||||||
| @@ -44,4 +47,27 @@ | |||||||
|         <item name="drawerArrowStyle">@style/DrawerArrowStyle</item>--> |         <item name="drawerArrowStyle">@style/DrawerArrowStyle</item>--> | ||||||
|     </style> |     </style> | ||||||
|  |  | ||||||
|  |     <!-- Material Drawer Theme --> | ||||||
|  |     <style name="App.materialDrawerStyle" parent="@style/Widget.MaterialDrawerStyle"> | ||||||
|  |         <item name="materialDrawerPrimaryIcon">?android:textColorPrimary</item> | ||||||
|  |         <item name="materialDrawerSecondaryIcon">?android:textColorPrimary</item> | ||||||
|  |         <item name="materialDrawerSecondaryText">?android:textColorPrimary</item> | ||||||
|  |     </style> | ||||||
|  |        | ||||||
|  |     <!-- Preference Theme --> | ||||||
|  |     <style name="PreferenceStyle" parent="@style/PreferenceThemeOverlay"> | ||||||
|  |         <item name="android:tint">?android:textColorPrimary</item> | ||||||
|  |     </style> | ||||||
|  |  | ||||||
|  |     <!-- Spinner Theme --> | ||||||
|  |     <style name="App.Spinner" parent="Widget.AppCompat.Light.DropDownItem.Spinner"> | ||||||
|  |         <item name="android:textColor">?android:textColorPrimary</item> | ||||||
|  |     </style> | ||||||
|  |  | ||||||
|  |     <!-- Alert dialog Theme --> | ||||||
|  |  | ||||||
|  |     <style name="AlertDialogDark" parent="Theme.MaterialComponents.Dialog"> | ||||||
|  |         <item name="android:background">@color/darkBackground</item> | ||||||
|  |     </style> | ||||||
|  |  | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -1,9 +1,11 @@ | |||||||
| <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> | <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|     <EditTextPreference |     <EditTextPreference | ||||||
|         android:inputType="number" |         android:inputType="number" | ||||||
|         android:key="api_timeout" |         android:key="api_timeout" | ||||||
|         android:selectAllOnFocus="true" |         android:selectAllOnFocus="true" | ||||||
|         android:singleLine="true" |         android:singleLine="true" | ||||||
|         android:title="@string/pref_api_timeout" /> |         android:title="@string/pref_api_timeout" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|  |  | ||||||
| </PreferenceScreen> | </PreferenceScreen> | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> | <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|  |  | ||||||
|     <PreferenceCategory |     <PreferenceCategory | ||||||
|         android:title="@string/pref_selfoss_category"> |         android:title="@string/pref_selfoss_category"> | ||||||
| @@ -10,7 +11,8 @@ | |||||||
|         android:key="prefer_api_items_number" |         android:key="prefer_api_items_number" | ||||||
|         android:selectAllOnFocus="true" |         android:selectAllOnFocus="true" | ||||||
|         android:singleLine="true" |         android:singleLine="true" | ||||||
|         android:title="@string/pref_api_items_number_title" /> |         android:title="@string/pref_api_items_number_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|  |  | ||||||
|     <EditTextPreference |     <EditTextPreference | ||||||
|         android:defaultValue="" |         android:defaultValue="" | ||||||
| @@ -18,12 +20,14 @@ | |||||||
|         android:key="hidden_tags" |         android:key="hidden_tags" | ||||||
|         android:selectAllOnFocus="true" |         android:selectAllOnFocus="true" | ||||||
|         android:singleLine="true" |         android:singleLine="true" | ||||||
|         android:title="@string/pref_hidden_tags" /> |         android:title="@string/pref_hidden_tags" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|  |  | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:key="infinite_loading" |         android:key="infinite_loading" | ||||||
|         android:title="@string/pref_general_infinite_loading_title" /> |         android:title="@string/pref_general_infinite_loading_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|     <PreferenceCategory |     <PreferenceCategory | ||||||
|         android:title="@string/pref_general_category_links"> |         android:title="@string/pref_general_category_links"> | ||||||
|  |  | ||||||
| @@ -33,14 +37,24 @@ | |||||||
|         android:key="prefer_internal_browser" |         android:key="prefer_internal_browser" | ||||||
|         android:summaryOff="@string/pref_general_internal_browser_off" |         android:summaryOff="@string/pref_general_internal_browser_off" | ||||||
|         android:summaryOn="@string/pref_general_internal_browser_on" |         android:summaryOn="@string/pref_general_internal_browser_on" | ||||||
|         android:title="@string/pref_general_internal_browser_title" /> |         android:title="@string/pref_general_internal_browser_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="true" |         android:defaultValue="true" | ||||||
|         android:dependency="prefer_internal_browser" |         android:dependency="prefer_internal_browser" | ||||||
|         android:key="prefer_article_viewer" |         android:key="prefer_article_viewer" | ||||||
|         android:summaryOff="@string/prefer_article_viewer_off" |         android:summaryOff="@string/prefer_article_viewer_off" | ||||||
|         android:summaryOn="@string/prefer_article_viewer_on" |         android:summaryOn="@string/prefer_article_viewer_on" | ||||||
|         android:title="@string/prefer_article_viewer_title" /> |         android:title="@string/prefer_article_viewer_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|  |     <SwitchPreference | ||||||
|  |         android:defaultValue="false" | ||||||
|  |         android:dependency="prefer_article_viewer" | ||||||
|  |         android:key="reader_static_bar" | ||||||
|  |         android:summaryOff="@string/reader_static_bar_off" | ||||||
|  |         android:summaryOn="@string/reader_static_bar_on" | ||||||
|  |         android:title="@string/reader_static_bar_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|  |  | ||||||
|     <PreferenceCategory |     <PreferenceCategory | ||||||
|         android:title="@string/pref_general_category_displaying"> |         android:title="@string/pref_general_category_displaying"> | ||||||
| @@ -50,29 +64,34 @@ | |||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:key="account_header_displaying" |         android:key="account_header_displaying" | ||||||
|         android:summary="@string/display_header_drawer_summary" |         android:summary="@string/display_header_drawer_summary" | ||||||
|         android:title="@string/display_header_drawer_title" /> |         android:title="@string/display_header_drawer_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:key="card_view_active" |         android:key="card_view_active" | ||||||
|         android:summaryOff="@string/pref_switch_card_view_off" |         android:summaryOff="@string/pref_switch_card_view_off" | ||||||
|         android:summaryOn="@string/pref_switch_card_view_on" |         android:summaryOn="@string/pref_switch_card_view_on" | ||||||
|         android:title="@string/pref_switch_card_view_title" /> |         android:title="@string/pref_switch_card_view_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:dependency="card_view_active" |         android:dependency="card_view_active" | ||||||
|         android:key="full_height_cards" |         android:key="full_height_cards" | ||||||
|         android:summaryOff="@string/card_height_off" |         android:summaryOff="@string/card_height_off" | ||||||
|         android:summaryOn="@string/card_height_on" |         android:summaryOn="@string/card_height_on" | ||||||
|         android:title="@string/card_height_title" /> |         android:title="@string/card_height_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="true" |         android:defaultValue="true" | ||||||
|         android:key="display_unread_count" |         android:key="display_unread_count" | ||||||
|         android:summaryOn="@string/switch_unread_count" |         android:summaryOn="@string/switch_unread_count" | ||||||
|         android:title="@string/switch_unread_count_title" /> |         android:title="@string/switch_unread_count_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:dependency="display_unread_count" |         android:dependency="display_unread_count" | ||||||
|         android:key="display_other_count" |         android:key="display_other_count" | ||||||
|         android:title="@string/display_all_counts_title" /> |         android:title="@string/display_all_counts_title" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|  |  | ||||||
| </PreferenceScreen> | </PreferenceScreen> | ||||||
|   | |||||||
| @@ -1,57 +0,0 @@ | |||||||
| <preference-headers xmlns:android="http://schemas.android.com/apk/res/android"> |  | ||||||
|  |  | ||||||
|     <header |  | ||||||
|         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$GeneralPreferenceFragment" |  | ||||||
|         android:icon="@drawable/ic_settings_black_24dp" |  | ||||||
|         android:title="@string/pref_header_general"> |  | ||||||
|         <extra |  | ||||||
|             android:name="iconDark" |  | ||||||
|             android:value="ic_settings_white_24dp"/> |  | ||||||
|     </header> |  | ||||||
|  |  | ||||||
|     <header |  | ||||||
|         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$ArticleViewerPreferenceFragment" |  | ||||||
|         android:icon="@drawable/ic_chrome_reader_mode_black_24dp" |  | ||||||
|         android:title="@string/pref_header_viewer"> |  | ||||||
|         <extra |  | ||||||
|             android:name="iconDark" |  | ||||||
|             android:value="ic_chrome_reader_mode_white_24dp"/> |  | ||||||
|     </header> |  | ||||||
|  |  | ||||||
|     <header |  | ||||||
|         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$OfflinePreferenceFragment" |  | ||||||
|         android:icon="@drawable/ic_signal_wifi_off_black_24dp" |  | ||||||
|         android:title="@string/pref_header_offline"> |  | ||||||
|         <extra |  | ||||||
|             android:name="iconDark" |  | ||||||
|             android:value="ic_signal_wifi_off_white_24dp"/> |  | ||||||
|     </header> |  | ||||||
|  |  | ||||||
|     <header |  | ||||||
|         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$ThemePreferenceFragment" |  | ||||||
|         android:icon="@drawable/ic_color_lens_black_24dp" |  | ||||||
|         android:title="@string/pref_header_theme"> |  | ||||||
|         <extra |  | ||||||
|             android:name="iconDark" |  | ||||||
|             android:value="ic_color_lens_white_24dp"/> |  | ||||||
|     </header> |  | ||||||
|  |  | ||||||
|     <header |  | ||||||
|         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$LinksPreferenceFragment" |  | ||||||
|         android:icon="@drawable/ic_info_black_24dp" |  | ||||||
|         android:title="@string/pref_header_links"> |  | ||||||
|         <extra |  | ||||||
|             android:name="iconDark" |  | ||||||
|             android:value="ic_info_white_24dp"/> |  | ||||||
|     </header> |  | ||||||
|  |  | ||||||
|     <header |  | ||||||
|         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$ExperimentalPreferenceFragment" |  | ||||||
|         android:icon="@drawable/ic_widgets_black_24dp" |  | ||||||
|         android:title="@string/pref_header_experimental"> |  | ||||||
|         <extra |  | ||||||
|             android:name="iconDark" |  | ||||||
|             android:value="ic_widgets_white_24dp"/> |  | ||||||
|     </header> |  | ||||||
|  |  | ||||||
| </preference-headers> |  | ||||||
| @@ -1,13 +1,17 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> | <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|  |  | ||||||
|     <Preference android:title="@string/issue_tracker_link" |     <Preference android:title="@string/issue_tracker_link" | ||||||
|                 android:summary="@string/issue_tracker_summary" |                 android:summary="@string/issue_tracker_summary" | ||||||
|                 android:key="trackerLink" /> |                 android:key="trackerLink" | ||||||
|  |                 app:iconSpaceReserved="false"/> | ||||||
|  |  | ||||||
|     <Preference android:title="@string/source_code" |     <Preference android:title="@string/source_code" | ||||||
|         android:key="sourceLink" /> |         android:key="sourceLink" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
|  |  | ||||||
|     <Preference android:title="@string/translation" |     <Preference android:title="@string/translation" | ||||||
|         android:key="translation" /> |         android:key="translation" | ||||||
|  |         app:iconSpaceReserved="false"/> | ||||||
| </PreferenceScreen> | </PreferenceScreen> | ||||||
							
								
								
									
										35
									
								
								app/src/main/res/xml/pref_main.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								app/src/main/res/xml/pref_main.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     android:title="@string/title_activity_settings"> | ||||||
|  |  | ||||||
|  |     <Preference | ||||||
|  |         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$GeneralPreferenceFragment" | ||||||
|  |         android:title="@string/pref_header_general" | ||||||
|  |         android:icon="@drawable/ic_settings_black_24dp" /> | ||||||
|  |  | ||||||
|  |     <Preference | ||||||
|  |         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$ArticleViewerPreferenceFragment" | ||||||
|  |         android:title="@string/pref_header_viewer" | ||||||
|  |         android:icon="@drawable/ic_chrome_reader_mode_black_24dp" /> | ||||||
|  |  | ||||||
|  |     <Preference | ||||||
|  |         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$OfflinePreferenceFragment" | ||||||
|  |         android:title="@string/pref_header_offline" | ||||||
|  |         android:icon="@drawable/ic_signal_wifi_off_black_24dp" /> | ||||||
|  |  | ||||||
|  |     <Preference | ||||||
|  |         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$ThemePreferenceFragment" | ||||||
|  |         android:title="@string/pref_header_theme" | ||||||
|  |         android:icon="@drawable/ic_color_lens_black_24dp" /> | ||||||
|  |  | ||||||
|  |     <Preference | ||||||
|  |         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$LinksPreferenceFragment" | ||||||
|  |         android:title="@string/pref_header_links" | ||||||
|  |         android:icon="@drawable/ic_info_black_24dp" /> | ||||||
|  |  | ||||||
|  |     <Preference | ||||||
|  |         android:fragment="apps.amine.bou.readerforselfoss.settings.SettingsActivity$ExperimentalPreferenceFragment" | ||||||
|  |         android:title="@string/pref_header_experimental" | ||||||
|  |         android:icon="@drawable/ic_widgets_black_24dp" /> | ||||||
|  |  | ||||||
|  | </PreferenceScreen> | ||||||
| @@ -1,7 +1,9 @@ | |||||||
| <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> | <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|  |  | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:key="items_caching" |         android:key="items_caching" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:summaryOff="@string/pref_switch_items_caching_off" |         android:summaryOff="@string/pref_switch_items_caching_off" | ||||||
|         android:summaryOn="@string/pref_switch_items_caching_on" |         android:summaryOn="@string/pref_switch_items_caching_on" | ||||||
|         android:title="@string/pref_switch_items_caching" /> |         android:title="@string/pref_switch_items_caching" /> | ||||||
| @@ -10,6 +12,7 @@ | |||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:key="periodic_refresh" |         android:key="periodic_refresh" | ||||||
|         android:dependency="items_caching" |         android:dependency="items_caching" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:summaryOff="@string/pref_switch_periodic_refresh_off" |         android:summaryOff="@string/pref_switch_periodic_refresh_off" | ||||||
|         android:summaryOn="@string/pref_switch_periodic_refresh_on" |         android:summaryOn="@string/pref_switch_periodic_refresh_on" | ||||||
|         android:title="@string/pref_switch_periodic_refresh" /> |         android:title="@string/pref_switch_periodic_refresh" /> | ||||||
| @@ -18,6 +21,7 @@ | |||||||
|         android:dependency="periodic_refresh" |         android:dependency="periodic_refresh" | ||||||
|         android:defaultValue="360" |         android:defaultValue="360" | ||||||
|         android:inputType="number" |         android:inputType="number" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:key="periodic_refresh_minutes" |         android:key="periodic_refresh_minutes" | ||||||
|         android:selectAllOnFocus="true" |         android:selectAllOnFocus="true" | ||||||
|         android:singleLine="true" |         android:singleLine="true" | ||||||
| @@ -25,18 +29,21 @@ | |||||||
|  |  | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:key="refresh_when_charging" |         android:key="refresh_when_charging" | ||||||
|         android:dependency="periodic_refresh" |         android:dependency="periodic_refresh" | ||||||
|         android:title="@string/pref_switch_refresh_when_charging" /> |         android:title="@string/pref_switch_refresh_when_charging" /> | ||||||
|  |  | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:key="notify_new_items" |         android:key="notify_new_items" | ||||||
|         android:dependency="periodic_refresh" |         android:dependency="periodic_refresh" | ||||||
|         android:title="@string/pref_switch_notify_new_items" /> |         android:title="@string/pref_switch_notify_new_items" /> | ||||||
|  |  | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="true" |         android:defaultValue="true" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:key="update_sources" |         android:key="update_sources" | ||||||
|         android:summary="@string/pref_switch_update_sources_summary" |         android:summary="@string/pref_switch_update_sources_summary" | ||||||
|         android:title="@string/pref_switch_update_sources" /> |         android:title="@string/pref_switch_update_sources" /> | ||||||
|   | |||||||
| @@ -1,29 +1,35 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> | <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|     <!-- TODO translate this file --> |     <!-- TODO translate this file --> | ||||||
|  |  | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:key="dark_theme" |         android:key="dark_theme" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:title="Dark theme" /> |         android:title="Dark theme" /> | ||||||
|  |  | ||||||
|     <com.jaredrummler.android.colorpicker.ColorPreference |     <com.jaredrummler.android.colorpicker.ColorPreferenceCompat | ||||||
|         android:defaultValue="@color/colorPrimary" |         android:defaultValue="@color/colorPrimary" | ||||||
|         android:key="color_primary" |         android:key="color_primary" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:title="Primary color"/> |         android:title="Primary color"/> | ||||||
|  |  | ||||||
|     <com.jaredrummler.android.colorpicker.ColorPreference |     <com.jaredrummler.android.colorpicker.ColorPreferenceCompat | ||||||
|         android:defaultValue="@color/colorPrimaryDark" |         android:defaultValue="@color/colorPrimaryDark" | ||||||
|         android:key="color_primary_dark" |         android:key="color_primary_dark" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:title="Primary dark color"/> |         android:title="Primary dark color"/> | ||||||
|  |  | ||||||
|     <com.jaredrummler.android.colorpicker.ColorPreference |     <com.jaredrummler.android.colorpicker.ColorPreferenceCompat | ||||||
|         android:defaultValue="@color/colorAccent" |         android:defaultValue="@color/colorAccent" | ||||||
|         android:key="color_accent" |         android:key="color_accent" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:title="Accent color"/> |         android:title="Accent color"/> | ||||||
|  |  | ||||||
|     <com.jaredrummler.android.colorpicker.ColorPreference |     <com.jaredrummler.android.colorpicker.ColorPreferenceCompat | ||||||
|         android:defaultValue="@color/colorAccentDark" |         android:defaultValue="@color/colorAccentDark" | ||||||
|         android:key="color_accent_dark" |         android:key="color_accent_dark" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:title="Accent dark color"/> |         android:title="Accent dark color"/> | ||||||
| </PreferenceScreen> | </PreferenceScreen> | ||||||
| @@ -1,7 +1,9 @@ | |||||||
| <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> | <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|     <SwitchPreference |     <SwitchPreference | ||||||
|         android:defaultValue="false" |         android:defaultValue="false" | ||||||
|         android:key="mark_on_scroll" |         android:key="mark_on_scroll" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:summaryOff="@string/pref_switch_actions_pager_scroll_off" |         android:summaryOff="@string/pref_switch_actions_pager_scroll_off" | ||||||
|         android:summaryOn="@string/pref_switch_actions_pager_scroll_on" |         android:summaryOn="@string/pref_switch_actions_pager_scroll_on" | ||||||
|         android:title="@string/pref_switch_actions_pager_scroll" /> |         android:title="@string/pref_switch_actions_pager_scroll" /> | ||||||
| @@ -10,6 +12,7 @@ | |||||||
|         android:defaultValue="16" |         android:defaultValue="16" | ||||||
|         android:inputType="number" |         android:inputType="number" | ||||||
|         android:key="reader_font_size" |         android:key="reader_font_size" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:selectAllOnFocus="true" |         android:selectAllOnFocus="true" | ||||||
|         android:singleLine="true" |         android:singleLine="true" | ||||||
|         android:title="@string/pref_content_reader_font_size" /> |         android:title="@string/pref_content_reader_font_size" /> | ||||||
| @@ -18,5 +21,6 @@ | |||||||
|         android:entries="@array/preloaded_fonts_values" |         android:entries="@array/preloaded_fonts_values" | ||||||
|         android:entryValues="@array/preloaded_fonts_keys" |         android:entryValues="@array/preloaded_fonts_keys" | ||||||
|         android:key="reader_font" |         android:key="reader_font" | ||||||
|  |         app:iconSpaceReserved="false" | ||||||
|         android:title="@string/settings_reader_font" /> |         android:title="@string/settings_reader_font" /> | ||||||
| </PreferenceScreen> | </PreferenceScreen> | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								build.gradle
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								build.gradle
									
									
									
									
									
								
							| @@ -2,7 +2,7 @@ | |||||||
|  |  | ||||||
| buildscript { | buildscript { | ||||||
|     ext { |     ext { | ||||||
|         kotlin_version = '1.5.31' |         kotlin_version = '1.6.10' | ||||||
|         android_version = '1.0.0' |         android_version = '1.0.0' | ||||||
|         androidx_version = '1.1.0-alpha05' |         androidx_version = '1.1.0-alpha05' | ||||||
|         lifecycle_version = '2.2.0-alpha01' |         lifecycle_version = '2.2.0-alpha01' | ||||||
| @@ -12,24 +12,20 @@ buildscript { | |||||||
|     repositories { |     repositories { | ||||||
|         google() |         google() | ||||||
|         jcenter() |         jcenter() | ||||||
|         maven { |         maven { url "https://www.jitpack.io" } | ||||||
|             url "https://jitpack.io" |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|     dependencies { |     dependencies { | ||||||
|         classpath 'com.android.tools.build:gradle:7.0.3' |         classpath 'com.android.tools.build:gradle:7.0.4' | ||||||
|         classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" |         classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| allprojects { | allprojects { | ||||||
|     repositories { |     repositories { | ||||||
|         // For likebutton only |  | ||||||
|         maven { url "https://jitpack.io" } |  | ||||||
|  |  | ||||||
|         google() |         google() | ||||||
|         jcenter() |  | ||||||
|         mavenCentral() |         mavenCentral() | ||||||
|  |         jcenter() | ||||||
|  |         maven { url "https://www.jitpack.io" } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user