Compare commits
	
		
			6 Commits
		
	
	
		
			7d6e24f1fd
			...
			v172201007
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b2609554e6 | |||
| 5db312bbb8 | |||
| 7592ab512b | |||
| 000b346529 | |||
| 1bb975c584 | |||
| 69aaa323e2 | 
| @@ -155,6 +155,7 @@ dependencies { | |||||||
|  |  | ||||||
|     // Pager |     // Pager | ||||||
|     implementation 'me.relex:circleindicator:2.1.6' |     implementation 'me.relex:circleindicator:2.1.6' | ||||||
|  |     implementation "androidx.viewpager2:viewpager2:1.1.0-beta01" | ||||||
|  |  | ||||||
|     //PhotoView |     //PhotoView | ||||||
|     implementation 'com.github.chrisbanes:PhotoView:2.3.0' |     implementation 'com.github.chrisbanes:PhotoView:2.3.0' | ||||||
|   | |||||||
| @@ -52,19 +52,19 @@ class AddSourceActivity : AppCompatActivity() { | |||||||
|         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 | ||||||
|         binding.nameInput.background = drawable |         binding.nameInput.background = drawable | ||||||
|  |  | ||||||
|         val drawable1 = binding.sourceUri.background |         val drawable1 = binding.sourceUri.background | ||||||
|         drawable1.setColorFilter(appColors.colorAccent, PorterDuff.Mode.SRC_ATOP) |         drawable1.setTint(appColors.colorAccent) | ||||||
|  |  | ||||||
|         binding.sourceUri.background = drawable1 |         binding.sourceUri.background = drawable1 | ||||||
|  |  | ||||||
|         val drawable2 = binding.tags.background |         val drawable2 = binding.tags.background | ||||||
|         drawable2.setColorFilter(appColors.colorAccent, PorterDuff.Mode.SRC_ATOP) |         drawable2.setTint(appColors.colorAccent) | ||||||
|  |  | ||||||
|         binding.tags.background = drawable2 |         binding.tags.background = drawable2 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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]) |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -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 androidx.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 | ||||||
|  |  | ||||||
| @@ -116,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) { | ||||||
| @@ -151,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 getItemCount(): Int = allItems.size | ||||||
|  |  | ||||||
|  |         override fun createFragment(position: Int): Fragment = ArticleFragment.newInstance(allItems[position]) | ||||||
|  |  | ||||||
|         override fun getCount(): Int { |  | ||||||
|             return allItems.size |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|         override fun getItem(position: Int): ArticleFragment { |     private fun alignmentMenu(showJustify: Boolean) { | ||||||
|             return ArticleFragment.newInstance(position, allItems) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         override fun startUpdate(container: ViewGroup) { |  | ||||||
|             super.startUpdate(container) |  | ||||||
|  |  | ||||||
|             container.background = ColorDrawable( |  | ||||||
|                 ContextCompat.getColor( |  | ||||||
|                     this@ReaderActivity, |  | ||||||
|                     appColors.colorBackground |  | ||||||
|                 ) |  | ||||||
|             ) |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     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 | ||||||
|     } |     } | ||||||
| @@ -200,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() | ||||||
| @@ -211,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 | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -218,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() | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -28,17 +28,17 @@ 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) | ||||||
|         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) | ||||||
|         supportActionBar?.setDisplayShowHomeEnabled(true) |         supportActionBar?.setDisplayShowHomeEnabled(true) | ||||||
|   | |||||||
| @@ -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) | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -14,12 +14,11 @@ 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 | ||||||
| @@ -48,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 | ||||||
| @@ -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,16 +102,16 @@ 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() | ||||||
| @@ -163,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, | ||||||
| @@ -193,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, | ||||||
| @@ -223,7 +213,7 @@ class ArticleFragment : Fragment() { | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             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) { | ||||||
| @@ -265,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() | ||||||
| @@ -292,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() | ||||||
| @@ -390,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 | ||||||
| @@ -442,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)) | ||||||
| @@ -556,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, |  | ||||||
|             pageNumber.toInt(), |  | ||||||
|                 url, |                 url, | ||||||
|                 customTabsIntent, |                 customTabsIntent, | ||||||
|             true, |  | ||||||
|             false, |  | ||||||
|                 requireActivity() |                 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 | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -13,7 +13,10 @@ import androidx.core.widget.addTextChangedListener | |||||||
| import androidx.preference.Preference | import androidx.preference.Preference | ||||||
| import androidx.preference.PreferenceFragmentCompat | import androidx.preference.PreferenceFragmentCompat | ||||||
| import apps.amine.bou.readerforselfoss.R | 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 apps.amine.bou.readerforselfoss.utils.Config | ||||||
|  | import com.ftinc.scoop.Scoop | ||||||
| import java.lang.NumberFormatException | import java.lang.NumberFormatException | ||||||
|  |  | ||||||
| private const val TITLE_TAG = "settingsActivityTitle" | private const val TITLE_TAG = "settingsActivityTitle" | ||||||
| @@ -26,7 +29,13 @@ class SettingsActivity : AppCompatActivity(), | |||||||
|         if (PreferenceManager.getDefaultSharedPreferences(this).getBoolean("dark_theme", false)) { |         if (PreferenceManager.getDefaultSharedPreferences(this).getBoolean("dark_theme", false)) { | ||||||
|             setTheme(R.style.NoBarDark) |             setTheme(R.style.NoBarDark) | ||||||
|         } |         } | ||||||
|         setContentView(R.layout.activity_settings) |         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) { |         if (savedInstanceState == null) { | ||||||
|             supportFragmentManager |             supportFragmentManager | ||||||
|                     .beginTransaction() |                     .beginTransaction() | ||||||
| @@ -41,7 +50,7 @@ class SettingsActivity : AppCompatActivity(), | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         setSupportActionBar(findViewById(R.id.toolbar)) |         setSupportActionBar(binding.toolbar) | ||||||
|  |  | ||||||
|         supportActionBar?.setDisplayHomeAsUpEnabled(true) |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
|         supportActionBar?.setDisplayShowHomeEnabled(true) |         supportActionBar?.setDisplayShowHomeEnabled(true) | ||||||
|   | |||||||
| @@ -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 androidx.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 | ||||||
| } | } | ||||||
|   | |||||||
| @@ -86,6 +86,18 @@ fun Context.openItemUrlInternally( | |||||||
|         intent.putExtra("currentItem", currentItem) |         intent.putExtra("currentItem", currentItem) | ||||||
|         app.startActivity(intent) |         app.startActivity(intent) | ||||||
|     } else { |     } else { | ||||||
|  |         this.openItemUrlInternalBrowser( | ||||||
|  |                 linkDecoded, | ||||||
|  |                 customTabsIntent, | ||||||
|  |                 app) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun Context.openItemUrlInternalBrowser( | ||||||
|  |         linkDecoded: String, | ||||||
|  |         customTabsIntent: CustomTabsIntent, | ||||||
|  |         app: Activity | ||||||
|  | ) { | ||||||
|     try { |     try { | ||||||
|         CustomTabActivityHelper.openCustomTab( |         CustomTabActivityHelper.openCustomTab( | ||||||
|                 app, |                 app, | ||||||
| @@ -100,7 +112,6 @@ fun Context.openItemUrlInternally( | |||||||
|         openInBrowser(linkDecoded, app) |         openInBrowser(linkDecoded, app) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| } |  | ||||||
|  |  | ||||||
| fun Context.openItemUrl( | fun Context.openItemUrl( | ||||||
|     allItems: ArrayList<Item>, |     allItems: ArrayList<Item>, | ||||||
| @@ -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 | ||||||
|  |             ) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -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" | ||||||
|   | |||||||
| @@ -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" | ||||||
|   | |||||||
| @@ -32,7 +32,7 @@ | |||||||
|         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|end" |         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" | ||||||
|   | |||||||
| @@ -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> | ||||||
| @@ -26,6 +26,7 @@ | |||||||
|         android:maxLines="1" |         android:maxLines="1" | ||||||
|         android:textAlignment="textStart" |         android:textAlignment="textStart" | ||||||
|         android:textSize="13sp" |         android:textSize="13sp" | ||||||
|  |         android:textColor="?android:textColorPrimary" | ||||||
|         app:layout_constraintBottom_toBottomOf="parent" |         app:layout_constraintBottom_toBottomOf="parent" | ||||||
|         app:layout_constraintEnd_toStartOf="@+id/deleteBtn" |         app:layout_constraintEnd_toStartOf="@+id/deleteBtn" | ||||||
|         app:layout_constraintStart_toEndOf="@+id/itemImage" |         app:layout_constraintStart_toEndOf="@+id/itemImage" | ||||||
|   | |||||||
| @@ -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> | ||||||
|   | |||||||
| @@ -28,6 +28,7 @@ | |||||||
|         <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> | ||||||
| @@ -58,4 +59,15 @@ | |||||||
|         <item name="android:tint">?android:textColorPrimary</item> |         <item name="android:tint">?android:textColorPrimary</item> | ||||||
|     </style> |     </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> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user