Compare commits
	
		
			14 Commits
		
	
	
		
			v125010131
			...
			7a0202689f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 7a0202689f | |||
| 6b96eb358d | |||
| dfc1bf9fa3 | |||
| b173664ff0 | |||
| bc20a421ae | |||
| 794500355a | |||
| 44f9dd53d3 | |||
| 717d6b664c | |||
| e23289a3dc | |||
| 2f5ebe2420 | |||
| 1893904135 | |||
| a4cb28ba81 | |||
| ae3cada1c7 | |||
| 309500276f | 
| @@ -16,6 +16,7 @@ jobs: | |||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v4 | ||||||
|         with: |         with: | ||||||
|           fetch-depth: 0 |           fetch-depth: 0 | ||||||
|  |           ref: master | ||||||
|       - name: Config git |       - name: Config git | ||||||
|         run: | |         run: | | ||||||
|           git config --global user.email aminecmi+giteadrone@pm.me |           git config --global user.email aminecmi+giteadrone@pm.me | ||||||
| @@ -50,7 +51,7 @@ jobs: | |||||||
|           followtags: true |           followtags: true | ||||||
|           ssh_key: ${{ secrets.PRIVATE_KEY }} |           ssh_key: ${{ secrets.PRIVATE_KEY }} | ||||||
|           tags: true |           tags: true | ||||||
|           branch: release |           branch: master | ||||||
|       - name: copy file via ssh password |       - name: copy file via ssh password | ||||||
|         uses: appleboy/scp-action@v0.1.7 |         uses: appleboy/scp-action@v0.1.7 | ||||||
|         with: |         with: | ||||||
|   | |||||||
							
								
								
									
										28
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,3 +1,31 @@ | |||||||
|  | **v125010241 | ||||||
|  |  | ||||||
|  | - Merge pull request 'fix: Link not opening.' (#178) from fix-open-link into master | ||||||
|  | - refactor: context fragments issues. | ||||||
|  | - logs: Context issues. | ||||||
|  | - fix: Handle empty url issue, again. | ||||||
|  | - fix: Link not opening. | ||||||
|  | - Changelog for v125010201 | ||||||
|  |  | ||||||
|  | -------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | **v125010201 | ||||||
|  |  | ||||||
|  | - fix: Handle empty url issue. | ||||||
|  | - Merge pull request 'Removed the floating bar.' (#177) from floating-bar into master | ||||||
|  | - chore: changing actions in reader fragment. | ||||||
|  | - Changelog for v125010131 | ||||||
|  |  | ||||||
|  | -------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | **v125010131 | ||||||
|  |  | ||||||
|  | - fix: reload the adapter when it's needed. Fixes #128. (#176) | ||||||
|  | - feat: basic auth and images loading. Fixes #172. (#175) | ||||||
|  | - Changelog for v125010111 | ||||||
|  |  | ||||||
|  | -------------------------------------------------------------------- | ||||||
|  |  | ||||||
| **v125010111 | **v125010111 | ||||||
|  |  | ||||||
| - Debug trying to fix context issues. (#174) | - Debug trying to fix context issues. (#174) | ||||||
|   | |||||||
| @@ -156,7 +156,7 @@ dependencies { | |||||||
|     implementation("com.github.bumptech.glide:okhttp3-integration:4.16.0") |     implementation("com.github.bumptech.glide:okhttp3-integration:4.16.0") | ||||||
|  |  | ||||||
|     // Themes |     // Themes | ||||||
|     implementation("com.github.rubensousa:floatingtoolbar:1.5.1") |     implementation("com.leinardi.android:speed-dial:3.3.0") | ||||||
|  |  | ||||||
|     // Pager |     // Pager | ||||||
|     implementation("me.relex:circleindicator:2.1.6") |     implementation("me.relex:circleindicator:2.1.6") | ||||||
|   | |||||||
| @@ -65,19 +65,6 @@ class SettingsActivityGeneralTest { | |||||||
|                 ), |                 ), | ||||||
|             ), |             ), | ||||||
|         ) |         ) | ||||||
|         onView(withSettingsCheckboxWidget(R.string.reader_static_bar_title)).check( |  | ||||||
|             matches( |  | ||||||
|                 allOf( |  | ||||||
|                     isDisplayed(), |  | ||||||
|                     not(isChecked()), |  | ||||||
|                 ), |  | ||||||
|             ), |  | ||||||
|         ) |  | ||||||
|         onView(withSettingsCheckboxFrame(R.string.reader_static_bar_title)).check( |  | ||||||
|             matches( |  | ||||||
|                 isEnabled(), |  | ||||||
|             ), |  | ||||||
|         ) |  | ||||||
|         onView(withText(R.string.pref_general_category_displaying)).check(matches(isDisplayed())) |         onView(withText(R.string.pref_general_category_displaying)).check(matches(isDisplayed())) | ||||||
|         onView(withSettingsCheckboxWidget(R.string.pref_switch_card_view_title)).check( |         onView(withSettingsCheckboxWidget(R.string.pref_switch_card_view_title)).check( | ||||||
|             matches( |             matches( | ||||||
| @@ -161,19 +148,6 @@ class SettingsActivityGeneralTest { | |||||||
|  |  | ||||||
|     @Test |     @Test | ||||||
|     fun testGeneralActionsCheckboxes() { |     fun testGeneralActionsCheckboxes() { | ||||||
|         // article viewer settings |  | ||||||
|         onView(withSettingsCheckboxFrame(R.string.reader_static_bar_title)).check( |  | ||||||
|             matches( |  | ||||||
|                 isEnabled(), |  | ||||||
|             ), |  | ||||||
|         ) |  | ||||||
|         onView(withSettingsCheckboxWidget(R.string.pref_article_viewer_title)).perform(click()) |  | ||||||
|         onView(withSettingsCheckboxFrame(R.string.reader_static_bar_title)).check( |  | ||||||
|             matches( |  | ||||||
|                 not(isEnabled()), |  | ||||||
|             ), |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|         onView(withSettingsCheckboxFrame(R.string.card_height_title)).check(matches(not(isEnabled()))) |         onView(withSettingsCheckboxFrame(R.string.card_height_title)).check(matches(not(isEnabled()))) | ||||||
|         onView(withSettingsCheckboxWidget(R.string.pref_switch_card_view_title)).perform(click()) |         onView(withSettingsCheckboxWidget(R.string.pref_switch_card_view_title)).perform(click()) | ||||||
|         onView(withSettingsCheckboxFrame(R.string.card_height_title)).check(matches(isEnabled())) |         onView(withSettingsCheckboxFrame(R.string.card_height_title)).check(matches(isEnabled())) | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ import bou.amine.apps.readerforselfossv2.android.settings.SettingsActivity | |||||||
| import bou.amine.apps.readerforselfossv2.android.testing.CountingIdlingResourceSingleton | import bou.amine.apps.readerforselfossv2.android.testing.CountingIdlingResourceSingleton | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.bottombar.maybeShow | import bou.amine.apps.readerforselfossv2.android.utils.bottombar.maybeShow | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.bottombar.removeBadge | import bou.amine.apps.readerforselfossv2.android.utils.bottombar.removeBadge | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.openUrlInBrowser | import bou.amine.apps.readerforselfossv2.android.utils.openUrlInBrowserAsNewTask | ||||||
| import bou.amine.apps.readerforselfossv2.model.SelfossModel | import bou.amine.apps.readerforselfossv2.model.SelfossModel | ||||||
| import bou.amine.apps.readerforselfossv2.repository.Repository | import bou.amine.apps.readerforselfossv2.repository.Repository | ||||||
| import bou.amine.apps.readerforselfossv2.service.AppSettingsService | import bou.amine.apps.readerforselfossv2.service.AppSettingsService | ||||||
| @@ -599,7 +599,7 @@ class HomeActivity : | |||||||
|     override fun onOptionsItemSelected(item: MenuItem): Boolean { |     override fun onOptionsItemSelected(item: MenuItem): Boolean { | ||||||
|         when (item.itemId) { |         when (item.itemId) { | ||||||
|             R.id.issue_tracker -> { |             R.id.issue_tracker -> { | ||||||
|                 baseContext.openUrlInBrowser(AppSettingsService.BUG_URL) |                 baseContext.openUrlInBrowserAsNewTask(AppSettingsService.BUG_URL) | ||||||
|                 return true |                 return true | ||||||
|             } |             } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,18 +2,14 @@ package bou.amine.apps.readerforselfossv2.android.fragments | |||||||
|  |  | ||||||
| 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.TypedArray | import android.content.res.TypedArray | ||||||
| import android.graphics.Bitmap | import android.graphics.Bitmap | ||||||
| import android.graphics.Typeface | import android.graphics.Typeface | ||||||
| import android.graphics.drawable.ColorDrawable |  | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.util.TypedValue |  | ||||||
| import android.util.TypedValue.DATA_NULL_UNDEFINED | import android.util.TypedValue.DATA_NULL_UNDEFINED | ||||||
| import android.view.GestureDetector | import android.view.GestureDetector | ||||||
| import android.view.InflateException | import android.view.InflateException | ||||||
| import android.view.LayoutInflater | import android.view.LayoutInflater | ||||||
| import android.view.MenuItem |  | ||||||
| import android.view.MotionEvent | import android.view.MotionEvent | ||||||
| import android.view.View | import android.view.View | ||||||
| import android.view.ViewGroup | import android.view.ViewGroup | ||||||
| @@ -23,7 +19,6 @@ import android.webkit.WebView | |||||||
| import android.webkit.WebViewClient | import android.webkit.WebViewClient | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import androidx.appcompat.app.AlertDialog | import androidx.appcompat.app.AlertDialog | ||||||
| import androidx.core.widget.NestedScrollView |  | ||||||
| import androidx.fragment.app.Fragment | import androidx.fragment.app.Fragment | ||||||
| import bou.amine.apps.readerforselfossv2.android.ImageActivity | import bou.amine.apps.readerforselfossv2.android.ImageActivity | ||||||
| import bou.amine.apps.readerforselfossv2.android.R | import bou.amine.apps.readerforselfossv2.android.R | ||||||
| @@ -32,12 +27,15 @@ import bou.amine.apps.readerforselfossv2.android.model.ParecelableItem | |||||||
| import bou.amine.apps.readerforselfossv2.android.model.toModel | import bou.amine.apps.readerforselfossv2.android.model.toModel | ||||||
| import bou.amine.apps.readerforselfossv2.android.model.toParcelable | import bou.amine.apps.readerforselfossv2.android.model.toParcelable | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.acra.sendSilentlyWithAcraWithName | import bou.amine.apps.readerforselfossv2.android.utils.acra.sendSilentlyWithAcraWithName | ||||||
|  | import bou.amine.apps.readerforselfossv2.android.utils.bottombar.addHomeMadeActionItem | ||||||
|  | import bou.amine.apps.readerforselfossv2.android.utils.getColorFromAttr | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.glide.bitmapFitCenter | import bou.amine.apps.readerforselfossv2.android.utils.glide.bitmapFitCenter | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.glide.getBitmapInputStream | import bou.amine.apps.readerforselfossv2.android.utils.glide.getBitmapInputStream | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.glide.getGlideImageForResource | import bou.amine.apps.readerforselfossv2.android.utils.glide.getGlideImageForResource | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.isUrlValid | import bou.amine.apps.readerforselfossv2.android.utils.isUrlValid | ||||||
|  | import bou.amine.apps.readerforselfossv2.android.utils.maybeIfContext | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.openItemUrlInBrowserAsNewTask | import bou.amine.apps.readerforselfossv2.android.utils.openItemUrlInBrowserAsNewTask | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.openUrlInBrowser | import bou.amine.apps.readerforselfossv2.android.utils.openUrlInBrowserAsNewTask | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.shareLink | import bou.amine.apps.readerforselfossv2.android.utils.shareLink | ||||||
| import bou.amine.apps.readerforselfossv2.model.MercuryModel | import bou.amine.apps.readerforselfossv2.model.MercuryModel | ||||||
| import bou.amine.apps.readerforselfossv2.model.SelfossModel | import bou.amine.apps.readerforselfossv2.model.SelfossModel | ||||||
| @@ -48,8 +46,7 @@ import bou.amine.apps.readerforselfossv2.utils.getHtmlDecoded | |||||||
| import bou.amine.apps.readerforselfossv2.utils.getImages | import bou.amine.apps.readerforselfossv2.utils.getImages | ||||||
| import bou.amine.apps.readerforselfossv2.utils.getThumbnail | import bou.amine.apps.readerforselfossv2.utils.getThumbnail | ||||||
| import bou.amine.apps.readerforselfossv2.utils.isEmptyOrNullOrNullString | import bou.amine.apps.readerforselfossv2.utils.isEmptyOrNullOrNullString | ||||||
| import com.github.rubensousa.floatingtoolbar.FloatingToolbar | import com.leinardi.android.speeddial.SpeedDialView | ||||||
| import com.google.android.material.floatingactionbutton.FloatingActionButton |  | ||||||
| import kotlinx.coroutines.CoroutineScope | import kotlinx.coroutines.CoroutineScope | ||||||
| import kotlinx.coroutines.Dispatchers | import kotlinx.coroutines.Dispatchers | ||||||
| import kotlinx.coroutines.launch | import kotlinx.coroutines.launch | ||||||
| @@ -74,6 +71,8 @@ private const val DEFAULT_FONT_SIZE = 16 | |||||||
| class ArticleFragment : | class ArticleFragment : | ||||||
|     Fragment(), |     Fragment(), | ||||||
|     DIAware { |     DIAware { | ||||||
|  |     private var colorOnSurface: Int = 0 | ||||||
|  |     private var colorSurface: Int = 0 | ||||||
|     private var fontSize: Int = DEFAULT_FONT_SIZE |     private var fontSize: Int = DEFAULT_FONT_SIZE | ||||||
|     private lateinit var item: SelfossModel.Item |     private lateinit var item: SelfossModel.Item | ||||||
|     private lateinit var url: String |     private lateinit var url: String | ||||||
| @@ -82,7 +81,7 @@ class ArticleFragment : | |||||||
|     private lateinit var contentImage: String |     private lateinit var contentImage: String | ||||||
|     private lateinit var contentTitle: String |     private lateinit var contentTitle: String | ||||||
|     private lateinit var allImages: ArrayList<String> |     private lateinit var allImages: ArrayList<String> | ||||||
|     private lateinit var fab: FloatingActionButton |     private lateinit var fab: SpeedDialView | ||||||
|     private lateinit var textAlignment: String |     private lateinit var textAlignment: String | ||||||
|     private lateinit var binding: FragmentArticleBinding |     private lateinit var binding: FragmentArticleBinding | ||||||
|  |  | ||||||
| @@ -93,7 +92,6 @@ class ArticleFragment : | |||||||
|     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 |  | ||||||
|  |  | ||||||
|     private val mercuryApi: MercuryApi by instance() |     private val mercuryApi: MercuryApi by instance() | ||||||
|  |  | ||||||
| @@ -120,6 +118,9 @@ class ArticleFragment : | |||||||
|                 e.sendSilentlyWithAcra() |                 e.sendSilentlyWithAcra() | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             colorOnSurface = getColorFromAttr(R.attr.colorOnSurface) | ||||||
|  |             colorSurface = getColorFromAttr(R.attr.colorSurface) | ||||||
|  |  | ||||||
|             contentText = item.content |             contentText = item.content | ||||||
|             contentTitle = item.title.getHtmlDecoded() |             contentTitle = item.title.getHtmlDecoded() | ||||||
|             contentImage = item.getThumbnail(repository.baseUrl) |             contentImage = item.getThumbnail(repository.baseUrl) | ||||||
| @@ -133,23 +134,11 @@ class ArticleFragment : | |||||||
|             allImages = item.getImages() |             allImages = item.getImages() | ||||||
|  |  | ||||||
|             fontSize = appSettingsService.getFontSize() |             fontSize = appSettingsService.getFontSize() | ||||||
|             staticBar = appSettingsService.isStaticBarEnabled() |  | ||||||
|             font = appSettingsService.getFont() |             font = appSettingsService.getFont() | ||||||
|  |  | ||||||
|             refreshAlignment() |             refreshAlignment() | ||||||
|  |  | ||||||
|             fab = binding.fab |             handleFloatingToolbar() | ||||||
|  |  | ||||||
|             fab.backgroundTintList = ColorStateList.valueOf(resources.getColor(R.color.colorAccent)) |  | ||||||
|  |  | ||||||
|             fab.rippleColor = resources.getColor(R.color.colorAccentDark) |  | ||||||
|  |  | ||||||
|             val floatingToolbar: FloatingToolbar = handleFloatingToolbar() |  | ||||||
|  |  | ||||||
|             if (staticBar) { |  | ||||||
|                 fab.hide() |  | ||||||
|                 floatingToolbar.show() |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             binding.source.text = contentSource |             binding.source.text = contentSource | ||||||
|             if (typeface != null) { |             if (typeface != null) { | ||||||
| @@ -157,28 +146,13 @@ class ArticleFragment : | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             handleContent() |             handleContent() | ||||||
|  |  | ||||||
|             binding.nestedScrollView.setOnScrollChangeListener( |  | ||||||
|                 NestedScrollView.OnScrollChangeListener { _, _, scrollY, _, oldScrollY -> |  | ||||||
|                     if (scrollY > oldScrollY) { |  | ||||||
|                         floatingToolbar.hide() |  | ||||||
|                         fab.hide() |  | ||||||
|                     } else { |  | ||||||
|                         if (staticBar) { |  | ||||||
|                             floatingToolbar.show() |  | ||||||
|                         } else { |  | ||||||
|                             if (floatingToolbar.isShowing) floatingToolbar.hide() else fab.show() |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 }, |  | ||||||
|             ) |  | ||||||
|         } catch (e: InflateException) { |         } catch (e: InflateException) { | ||||||
|             e.sendSilentlyWithAcraWithName("webview not available") |             e.sendSilentlyWithAcraWithName("webview not available") | ||||||
|             try { |             maybeIfContext { | ||||||
|                 AlertDialog |                 AlertDialog | ||||||
|                     .Builder(requireContext()) |                     .Builder(it) | ||||||
|                     .setMessage(requireContext().getString(R.string.webview_dialog_issue_message)) |                     .setMessage(it.getString(R.string.webview_dialog_issue_message)) | ||||||
|                     .setTitle(requireContext().getString(R.string.webview_dialog_issue_title)) |                     .setTitle(it.getString(R.string.webview_dialog_issue_title)) | ||||||
|                     .setPositiveButton( |                     .setPositiveButton( | ||||||
|                         android.R.string.ok, |                         android.R.string.ok, | ||||||
|                     ) { _, _ -> |                     ) { _, _ -> | ||||||
| @@ -186,8 +160,6 @@ class ArticleFragment : | |||||||
|                         requireActivity().finish() |                         requireActivity().finish() | ||||||
|                     }.create() |                     }.create() | ||||||
|                     .show() |                     .show() | ||||||
|             } catch (e: IllegalStateException) { |  | ||||||
|                 e.sendSilentlyWithAcraWithName("Context required is null") |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -209,67 +181,84 @@ class ArticleFragment : | |||||||
|  |  | ||||||
|             if (!contentImage.isEmptyOrNullOrNullString() && context != null) { |             if (!contentImage.isEmptyOrNullOrNullString() && context != null) { | ||||||
|                 binding.imageView.visibility = View.VISIBLE |                 binding.imageView.visibility = View.VISIBLE | ||||||
|                 requireContext().bitmapFitCenter(contentImage, binding.imageView, appSettingsService) |                 maybeIfContext { it.bitmapFitCenter(contentImage, binding.imageView, appSettingsService) } | ||||||
|             } else { |             } else { | ||||||
|                 binding.imageView.visibility = View.GONE |                 binding.imageView.visibility = View.GONE | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleFloatingToolbar(): FloatingToolbar { |     private fun handleFloatingToolbar() { | ||||||
|         val floatingToolbar: FloatingToolbar = binding.floatingToolbar |         fab = binding.speedDial | ||||||
|         if (appSettingsService.getPublicAccess()) { |         fab.mainFabClosedIconColor = colorOnSurface | ||||||
|             floatingToolbar.setMenu(R.menu.reader_toolbar_no_read) |         fab.mainFabOpenedIconColor = colorOnSurface | ||||||
|         } |  | ||||||
|         floatingToolbar.attachFab(fab) |  | ||||||
|  |  | ||||||
|         floatingToolbar.background = ColorDrawable(resources.getColor(R.color.colorAccent)) |         maybeIfContext { handleFloatingToolbarActionItems(it) } | ||||||
|  |  | ||||||
|         floatingToolbar.setClickListener( |         fab.setOnActionSelectedListener { actionItem -> | ||||||
|             object : FloatingToolbar.ItemClickListener { |             when (actionItem.id) { | ||||||
|                 override fun onItemClick(item: MenuItem) { |                 R.id.share_action -> requireActivity().shareLink(url, contentTitle) | ||||||
|                     when (item.itemId) { |                 R.id.open_action -> requireActivity().openItemUrlInBrowserAsNewTask(this@ArticleFragment.item) | ||||||
|                         R.id.share_action -> requireActivity().shareLink(url, contentTitle) |                 R.id.unread_action -> | ||||||
|                         R.id.open_action -> requireActivity().openItemUrlInBrowserAsNewTask(this@ArticleFragment.item) |                     if (this@ArticleFragment.item.unread) { | ||||||
|                         R.id.unread_action -> |                         CoroutineScope(Dispatchers.IO).launch { | ||||||
|                             try { |                             repository.markAsRead(this@ArticleFragment.item) | ||||||
|                                 if (this@ArticleFragment.item.unread) { |                         } | ||||||
|                                     CoroutineScope(Dispatchers.IO).launch { |                         this@ArticleFragment.item.unread = false | ||||||
|                                         repository.markAsRead(this@ArticleFragment.item) |                         maybeIfContext { | ||||||
|                                     } |                             Toast | ||||||
|                                     this@ArticleFragment.item.unread = false |                                 .makeText( | ||||||
|                                     Toast |                                     it, | ||||||
|                                         .makeText( |                                     R.string.marked_as_read, | ||||||
|                                             requireContext(), |                                     Toast.LENGTH_LONG, | ||||||
|                                             R.string.marked_as_read, |                                 ).show() | ||||||
|                                             Toast.LENGTH_LONG, |                         } | ||||||
|                                         ).show() |                     } else { | ||||||
|                                 } else { |                         CoroutineScope(Dispatchers.IO).launch { | ||||||
|                                     CoroutineScope(Dispatchers.IO).launch { |                             repository.unmarkAsRead(this@ArticleFragment.item) | ||||||
|                                         repository.unmarkAsRead(this@ArticleFragment.item) |                         } | ||||||
|                                     } |                         this@ArticleFragment.item.unread = true | ||||||
|                                     this@ArticleFragment.item.unread = true |                         maybeIfContext { | ||||||
|                                     Toast |                             Toast | ||||||
|                                         .makeText( |                                 .makeText( | ||||||
|                                             context, |                                     it, | ||||||
|                                             R.string.marked_as_unread, |                                     R.string.marked_as_unread, | ||||||
|                                             Toast.LENGTH_LONG, |                                     Toast.LENGTH_LONG, | ||||||
|                                         ).show() |                                 ).show() | ||||||
|                                 } |                         } | ||||||
|                             } catch (e: IllegalStateException) { |  | ||||||
|                                 e.sendSilentlyWithAcraWithName("Context required is null") |  | ||||||
|                             } |  | ||||||
|  |  | ||||||
|                         else -> Unit |  | ||||||
|                     } |                     } | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 override fun onItemLongClick(item: MenuItem?) { |                 else -> Unit | ||||||
|                     // We do nothing |             } | ||||||
|                 } |             false | ||||||
|             }, |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private fun handleFloatingToolbarActionItems(c: Context) { | ||||||
|  |         fab.addHomeMadeActionItem( | ||||||
|  |             R.id.share_action, | ||||||
|  |             resources.getDrawable(R.drawable.ic_share_white_24dp), | ||||||
|  |             R.string.reader_action_share, | ||||||
|  |             colorOnSurface, | ||||||
|  |             colorSurface, | ||||||
|  |             c, | ||||||
|  |         ) | ||||||
|  |         fab.addHomeMadeActionItem( | ||||||
|  |             R.id.open_action, | ||||||
|  |             resources.getDrawable(R.drawable.ic_open_in_browser_white_24dp), | ||||||
|  |             R.string.reader_action_open, | ||||||
|  |             colorOnSurface, | ||||||
|  |             colorSurface, | ||||||
|  |             c, | ||||||
|  |         ) | ||||||
|  |         fab.addHomeMadeActionItem( | ||||||
|  |             R.id.unread_action, | ||||||
|  |             resources.getDrawable(R.drawable.ic_baseline_white_eye_24dp), | ||||||
|  |             R.string.unmark, | ||||||
|  |             colorOnSurface, | ||||||
|  |             colorSurface, | ||||||
|  |             c, | ||||||
|         ) |         ) | ||||||
|         return floatingToolbar |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun refreshAlignment() { |     private fun refreshAlignment() { | ||||||
| @@ -321,9 +310,11 @@ class ArticleFragment : | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleLeadImage(leadImageUrl: String?) { |     private fun handleLeadImage(leadImageUrl: String?) { | ||||||
|         if (!leadImageUrl.isNullOrEmpty() && context != null) { |         if (!leadImageUrl.isNullOrEmpty()) { | ||||||
|             binding.imageView.visibility = View.VISIBLE |             maybeIfContext { | ||||||
|             requireContext().bitmapFitCenter(leadImageUrl, binding.imageView, appSettingsService) |                 binding.imageView.visibility = View.VISIBLE | ||||||
|  |                 it.bitmapFitCenter(leadImageUrl, binding.imageView, appSettingsService) | ||||||
|  |             } | ||||||
|         } else { |         } else { | ||||||
|             binding.imageView.visibility = View.GONE |             binding.imageView.visibility = View.GONE | ||||||
|         } |         } | ||||||
| @@ -337,11 +328,10 @@ class ArticleFragment : | |||||||
|                     view: WebView?, |                     view: WebView?, | ||||||
|                     url: String, |                     url: String, | ||||||
|                 ): Boolean = |                 ): Boolean = | ||||||
|                     if (context != null && |                     if (url.isUrlValid() && | ||||||
|                         url.isUrlValid() && |  | ||||||
|                         binding.webcontent.hitTestResult.type != WebView.HitTestResult.SRC_IMAGE_ANCHOR_TYPE |                         binding.webcontent.hitTestResult.type != WebView.HitTestResult.SRC_IMAGE_ANCHOR_TYPE | ||||||
|                     ) { |                     ) { | ||||||
|                         requireContext().openUrlInBrowser(url) |                         maybeIfContext { it.openUrlInBrowserAsNewTask(url) } | ||||||
|                         true |                         true | ||||||
|                     } else { |                     } else { | ||||||
|                         false |                         false | ||||||
| @@ -384,50 +374,33 @@ class ArticleFragment : | |||||||
|  |  | ||||||
|     @Suppress("detekt:LongMethod", "detekt:ImplicitDefaultLocale") |     @Suppress("detekt:LongMethod", "detekt:ImplicitDefaultLocale") | ||||||
|     private fun htmlToWebview() { |     private fun htmlToWebview() { | ||||||
|         val context: Context |         maybeIfContext { | ||||||
|         try { |  | ||||||
|             context = requireContext() |  | ||||||
|         } catch (e: IllegalStateException) { |  | ||||||
|             e.sendSilentlyWithAcraWithName("Context required is null") |  | ||||||
|             return |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         val colorOnSurface = TypedValue() |  | ||||||
|         val colorSurface = TypedValue() |  | ||||||
|  |  | ||||||
|         try { |  | ||||||
|             val attrs: IntArray = intArrayOf(android.R.attr.fontFamily) |             val attrs: IntArray = intArrayOf(android.R.attr.fontFamily) | ||||||
|             val a: TypedArray = context.obtainStyledAttributes(resId, attrs) |             val a: TypedArray = it.obtainStyledAttributes(resId, attrs) | ||||||
|  |  | ||||||
|             binding.webcontent.settings.standardFontFamily = a.getString(0) |             binding.webcontent.settings.standardFontFamily = a.getString(0) | ||||||
|             binding.webcontent.visibility = View.VISIBLE |             "" | ||||||
|  |  | ||||||
|             context.theme.resolveAttribute(R.attr.colorOnSurface, colorOnSurface, true) |  | ||||||
|  |  | ||||||
|             context.theme.resolveAttribute(R.attr.colorSurface, colorSurface, true) |  | ||||||
|         } catch (e: IllegalStateException) { |  | ||||||
|             e.sendSilentlyWithAcraWithName("Context issue when setting attributes, but context wasn't null before") |  | ||||||
|         } |         } | ||||||
|  |         binding.webcontent.visibility = View.VISIBLE | ||||||
|  |  | ||||||
|         val colorSurfaceString = |         val colorSurfaceString = | ||||||
|             String.format( |             String.format( | ||||||
|                 "#%06X", |                 "#%06X", | ||||||
|                 WHITE_COLOR_HEX and (if (colorSurface.data != DATA_NULL_UNDEFINED) colorSurface.data else WHITE_COLOR_HEX), |                 WHITE_COLOR_HEX and (if (colorSurface != DATA_NULL_UNDEFINED) colorSurface else WHITE_COLOR_HEX), | ||||||
|             ) |             ) | ||||||
|  |  | ||||||
|         val colorOnSurfaceString = |         val colorOnSurfaceString = | ||||||
|             String.format( |             String.format( | ||||||
|                 "#%06X", |                 "#%06X", | ||||||
|                 WHITE_COLOR_HEX and (if (colorOnSurface.data != DATA_NULL_UNDEFINED) colorOnSurface.data else 0), |                 WHITE_COLOR_HEX and (if (colorOnSurface != DATA_NULL_UNDEFINED) colorOnSurface else 0), | ||||||
|             ) |             ) | ||||||
|  |  | ||||||
|  |         binding.webcontent.settings.useWideViewPort = true | ||||||
|  |         binding.webcontent.settings.loadWithOverviewMode = true | ||||||
|  |         binding.webcontent.settings.javaScriptEnabled = false | ||||||
|  |  | ||||||
|  |         handleImageLoading() | ||||||
|         try { |         try { | ||||||
|             binding.webcontent.settings.useWideViewPort = true |  | ||||||
|             binding.webcontent.settings.loadWithOverviewMode = true |  | ||||||
|             binding.webcontent.settings.javaScriptEnabled = false |  | ||||||
|  |  | ||||||
|             handleImageLoading() |  | ||||||
|  |  | ||||||
|             val gestureDetector = |             val gestureDetector = | ||||||
|                 GestureDetector( |                 GestureDetector( | ||||||
|                     activity, |                     activity, | ||||||
| @@ -441,49 +414,50 @@ class ArticleFragment : | |||||||
|                     event, |                     event, | ||||||
|                 ) |                 ) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             binding.webcontent.settings.layoutAlgorithm = |  | ||||||
|                 WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING |  | ||||||
|         } catch (e: IllegalStateException) { |         } catch (e: IllegalStateException) { | ||||||
|             e.sendSilentlyWithAcraWithName("Context is null but wasn't, and that's causing issues with webview config") |             e.sendSilentlyWithAcraWithName("Gesture detector issue ?") | ||||||
|             return |             return | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         try { |         binding.webcontent.settings.layoutAlgorithm = | ||||||
|             var baseUrl: String? = null |             WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING | ||||||
|             try { |  | ||||||
|                 val itemUrl = URL(url) |  | ||||||
|                 baseUrl = itemUrl.protocol + "://" + itemUrl.host |  | ||||||
|             } catch (e: MalformedURLException) { |  | ||||||
|                 e.sendSilentlyWithAcraWithName("htmlToWebview > $url") |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             val fontName = |         var baseUrl: String? = null | ||||||
|  |         try { | ||||||
|  |             val itemUrl = URL(url) | ||||||
|  |             baseUrl = itemUrl.protocol + "://" + itemUrl.host | ||||||
|  |         } catch (e: MalformedURLException) { | ||||||
|  |             e.sendSilentlyWithAcraWithName("htmlToWebview > $url") | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         val fontName: String = | ||||||
|  |             maybeIfContext { | ||||||
|                 when (font) { |                 when (font) { | ||||||
|                     getString(R.string.open_sans_font_id) -> "Open Sans" |                     it.getString(R.string.open_sans_font_id) -> "Open Sans" | ||||||
|                     getString(R.string.roboto_font_id) -> "Roboto" |                     it.getString(R.string.roboto_font_id) -> "Roboto" | ||||||
|                     getString(R.string.source_code_pro_font_id) -> "Source Code Pro" |                     it.getString(R.string.source_code_pro_font_id) -> "Source Code Pro" | ||||||
|                     else -> "" |                     else -> "" | ||||||
|                 } |                 } | ||||||
|  |             }?.toString().orEmpty() | ||||||
|  |  | ||||||
|             val fontLinkAndStyle = |         val fontLinkAndStyle = | ||||||
|                 if (font.isNotEmpty()) { |             if (fontName.isNotEmpty()) { | ||||||
|                     """<link href="https://fonts.googleapis.com/css?family=${ |                 """<link href="https://fonts.googleapis.com/css?family=${ | ||||||
|                         fontName.replace( |                     fontName.replace( | ||||||
|                             " ", |                         " ", | ||||||
|                             "+", |                         "+", | ||||||
|                         ) |                     ) | ||||||
|                     }" rel="stylesheet"> |                 }" rel="stylesheet"> | ||||||
|                 |<style> |                 |<style> | ||||||
|                 |   * { |                 |   * { | ||||||
|                 |       font-family: '$fontName'; |                 |       font-family: '$fontName'; | ||||||
|                 |   } |                 |   } | ||||||
|                 |</style> |                 |</style> | ||||||
|                     """.trimMargin() |                 """.trimMargin() | ||||||
|                 } else { |             } else { | ||||||
|                     "" |                 "" | ||||||
|                 } |             } | ||||||
|  |         try { | ||||||
|             binding.webcontent.loadDataWithBaseURL( |             binding.webcontent.loadDataWithBaseURL( | ||||||
|                 baseUrl, |                 baseUrl, | ||||||
|                 """<html> |                 """<html> | ||||||
| @@ -500,7 +474,7 @@ class ArticleFragment : | |||||||
|                 |        color: ${ |                 |        color: ${ | ||||||
|                     String.format( |                     String.format( | ||||||
|                         "#%06X", |                         "#%06X", | ||||||
|                         WHITE_COLOR_HEX and context.resources.getColor(R.color.colorAccent), |                         WHITE_COLOR_HEX and (maybeIfContext { it.resources.getColor(R.color.colorAccent) } as Int), | ||||||
|                     ) |                     ) | ||||||
|                 } !important; |                 } !important; | ||||||
|                 |      } |                 |      } | ||||||
| @@ -557,10 +531,8 @@ class ArticleFragment : | |||||||
|  |  | ||||||
|     private fun openInBrowserAfterFailing() { |     private fun openInBrowserAfterFailing() { | ||||||
|         binding.progressBar.visibility = View.GONE |         binding.progressBar.visibility = View.GONE | ||||||
|         try { |         maybeIfContext { | ||||||
|             requireContext().openItemUrlInBrowserAsNewTask(this@ArticleFragment.item) |             it.openItemUrlInBrowserAsNewTask(this@ArticleFragment.item) | ||||||
|         } catch (e: IllegalStateException) { |  | ||||||
|             e.sendSilentlyWithAcraWithName("Context required is null") |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| package bou.amine.apps.readerforselfossv2.android.fragments | package bou.amine.apps.readerforselfossv2.android.fragments | ||||||
|  |  | ||||||
| import android.content.Context |  | ||||||
| import android.graphics.Color | import android.graphics.Color | ||||||
| import android.graphics.drawable.Drawable | import android.graphics.drawable.Drawable | ||||||
| import android.graphics.drawable.GradientDrawable | import android.graphics.drawable.GradientDrawable | ||||||
| @@ -17,6 +16,7 @@ import bou.amine.apps.readerforselfossv2.android.R | |||||||
| import bou.amine.apps.readerforselfossv2.android.databinding.FilterFragmentBinding | import bou.amine.apps.readerforselfossv2.android.databinding.FilterFragmentBinding | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.acra.sendSilentlyWithAcraWithName | import bou.amine.apps.readerforselfossv2.android.utils.acra.sendSilentlyWithAcraWithName | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.glide.imageIntoViewTarget | import bou.amine.apps.readerforselfossv2.android.utils.glide.imageIntoViewTarget | ||||||
|  | import bou.amine.apps.readerforselfossv2.android.utils.maybeIfContext | ||||||
| import bou.amine.apps.readerforselfossv2.repository.Repository | import bou.amine.apps.readerforselfossv2.repository.Repository | ||||||
| import bou.amine.apps.readerforselfossv2.service.AppSettingsService | import bou.amine.apps.readerforselfossv2.service.AppSettingsService | ||||||
| import bou.amine.apps.readerforselfossv2.utils.getColorHexCode | import bou.amine.apps.readerforselfossv2.utils.getColorHexCode | ||||||
| @@ -60,8 +60,8 @@ class FilterSheetFragment : | |||||||
|  |  | ||||||
|         try { |         try { | ||||||
|             CoroutineScope(Dispatchers.Main).launch { |             CoroutineScope(Dispatchers.Main).launch { | ||||||
|                 handleTagChips(requireContext()) |                 handleTagChips() | ||||||
|                 handleSourceChips(requireContext()) |                 handleSourceChips() | ||||||
|  |  | ||||||
|                 binding.progressBar2.visibility = GONE |                 binding.progressBar2.visibility = GONE | ||||||
|                 binding.filterView.visibility = VISIBLE |                 binding.filterView.visibility = VISIBLE | ||||||
| @@ -79,29 +79,31 @@ class FilterSheetFragment : | |||||||
|         return binding.root |         return binding.root | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private suspend fun handleSourceChips(context: Context) { |     private suspend fun handleSourceChips() { | ||||||
|         val sourceGroup = binding.sourcesGroup |         val sourceGroup = binding.sourcesGroup | ||||||
|  |  | ||||||
|         repository.getSourcesDetailsOrStats().forEachIndexed { _, source -> |         repository.getSourcesDetailsOrStats().forEachIndexed { _, source -> | ||||||
|             val c = Chip(context) |             val c = Chip(context) | ||||||
|             c.ellipsize = TextUtils.TruncateAt.END |             c.ellipsize = TextUtils.TruncateAt.END | ||||||
|  |  | ||||||
|             context.imageIntoViewTarget( |             maybeIfContext { | ||||||
|                 source.getIcon(repository.baseUrl), |                 it.imageIntoViewTarget( | ||||||
|                 object : ViewTarget<Chip?, Drawable?>(c) { |                     source.getIcon(repository.baseUrl), | ||||||
|                     override fun onResourceReady( |                     object : ViewTarget<Chip?, Drawable?>(c) { | ||||||
|                         resource: Drawable, |                         override fun onResourceReady( | ||||||
|                         transition: Transition<in Drawable?>?, |                             resource: Drawable, | ||||||
|                     ) { |                             transition: Transition<in Drawable?>?, | ||||||
|                         try { |                         ) { | ||||||
|                             c.chipIcon = resource |                             try { | ||||||
|                         } catch (e: Exception) { |                                 c.chipIcon = resource | ||||||
|                             e.sendSilentlyWithAcraWithName("sources > onResourceReady") |                             } catch (e: Exception) { | ||||||
|  |                                 e.sendSilentlyWithAcraWithName("sources > onResourceReady") | ||||||
|  |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                     }, | ||||||
|                 }, |                     appSettingsService, | ||||||
|                 appSettingsService, |                 ) | ||||||
|             ) |             } | ||||||
|  |  | ||||||
|             c.text = source.title.getHtmlDecoded() |             c.text = source.title.getHtmlDecoded() | ||||||
|  |  | ||||||
| @@ -137,7 +139,7 @@ class FilterSheetFragment : | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private suspend fun handleTagChips(context: Context) { |     private suspend fun handleTagChips() { | ||||||
|         val tagGroup = binding.tagsGroup |         val tagGroup = binding.tagsGroup | ||||||
|  |  | ||||||
|         val tags = repository.getTags() |         val tags = repository.getTags() | ||||||
|   | |||||||
| @@ -2,7 +2,12 @@ package bou.amine.apps.readerforselfossv2.android.utils | |||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
|  | import android.util.TypedValue | ||||||
|  | import androidx.annotation.AttrRes | ||||||
|  | import androidx.annotation.ColorInt | ||||||
|  | import androidx.fragment.app.Fragment | ||||||
| import bou.amine.apps.readerforselfossv2.android.R | import bou.amine.apps.readerforselfossv2.android.R | ||||||
|  | import bou.amine.apps.readerforselfossv2.android.utils.acra.sendSilentlyWithAcraWithName | ||||||
| import bou.amine.apps.readerforselfossv2.utils.toStringUriWithHttp | import bou.amine.apps.readerforselfossv2.utils.toStringUriWithHttp | ||||||
|  |  | ||||||
| fun Context.shareLink( | fun Context.shareLink( | ||||||
| @@ -23,3 +28,32 @@ fun Context.shareLink( | |||||||
|             ).setFlags(Intent.FLAG_ACTIVITY_NEW_TASK), |             ).setFlags(Intent.FLAG_ACTIVITY_NEW_TASK), | ||||||
|     ) |     ) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ColorInt | ||||||
|  | fun Fragment.getColorFromAttr( | ||||||
|  |     @AttrRes attrColor: Int, | ||||||
|  |     resolveRefs: Boolean = true, | ||||||
|  | ): Int { | ||||||
|  |     val typedValue = TypedValue() | ||||||
|  |     maybeIfContextWithLog { this.requireContext().theme.resolveAttribute(attrColor, typedValue, resolveRefs) } | ||||||
|  |     return typedValue.data | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @Suppress("detekt:SwallowedException") | ||||||
|  | fun Fragment.maybeIfContext(fn: (Context) -> Any): Any? { | ||||||
|  |     try { | ||||||
|  |         return fn(this.requireContext()) | ||||||
|  |     } catch (e: Exception) { | ||||||
|  |         // Do nothing | ||||||
|  |         return null | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun Fragment.maybeIfContextWithLog(fn: (Context) -> Any): Any? { | ||||||
|  |     try { | ||||||
|  |         return fn(this.requireContext()) | ||||||
|  |     } catch (e: Exception) { | ||||||
|  |         e.sendSilentlyWithAcraWithName("Fragment context issue...") | ||||||
|  |         return null | ||||||
|  |     } | ||||||
|  | } | ||||||
|   | |||||||
| @@ -1,6 +1,13 @@ | |||||||
| package bou.amine.apps.readerforselfossv2.android.utils.bottombar | package bou.amine.apps.readerforselfossv2.android.utils.bottombar | ||||||
|  |  | ||||||
|  | import android.content.Context | ||||||
|  | import android.graphics.drawable.Drawable | ||||||
|  | import androidx.annotation.IdRes | ||||||
|  | import androidx.annotation.StringRes | ||||||
|  | import bou.amine.apps.readerforselfossv2.android.R | ||||||
| import com.ashokvarma.bottomnavigation.TextBadgeItem | import com.ashokvarma.bottomnavigation.TextBadgeItem | ||||||
|  | import com.leinardi.android.speeddial.SpeedDialActionItem | ||||||
|  | import com.leinardi.android.speeddial.SpeedDialView | ||||||
|  |  | ||||||
| fun TextBadgeItem.removeBadge(): TextBadgeItem { | fun TextBadgeItem.removeBadge(): TextBadgeItem { | ||||||
|     this.setText("") |     this.setText("") | ||||||
| @@ -9,3 +16,25 @@ fun TextBadgeItem.removeBadge(): TextBadgeItem { | |||||||
| } | } | ||||||
|  |  | ||||||
| fun TextBadgeItem.maybeShow(): TextBadgeItem = if (this.isHidden) this.show() else this | fun TextBadgeItem.maybeShow(): TextBadgeItem = if (this.isHidden) this.show() else this | ||||||
|  |  | ||||||
|  | @Suppress("detekt:LongParameterList") | ||||||
|  | fun SpeedDialView.addHomeMadeActionItem( | ||||||
|  |     @IdRes actionId: Int, | ||||||
|  |     actionIcon: Drawable, | ||||||
|  |     @StringRes labelId: Int, | ||||||
|  |     colorOnSurface: Int, | ||||||
|  |     colorSurface: Int, | ||||||
|  |     context: Context, | ||||||
|  | ) { | ||||||
|  |     this.addActionItem( | ||||||
|  |         SpeedDialActionItem | ||||||
|  |             .Builder(actionId, actionIcon) | ||||||
|  |             .setFabBackgroundColor(context.resources.getColor(R.color.colorAccent)) | ||||||
|  |             .setFabImageTintColor(colorOnSurface) | ||||||
|  |             .setLabel(context.getString(labelId)) | ||||||
|  |             .setLabelClickable(false) | ||||||
|  |             .setLabelBackgroundColor(colorOnSurface) | ||||||
|  |             .setLabelColor(colorSurface) | ||||||
|  |             .create(), | ||||||
|  |     ) | ||||||
|  | } | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ import android.webkit.WebView | |||||||
| import android.widget.ImageView | import android.widget.ImageView | ||||||
| import bou.amine.apps.readerforselfossv2.android.utils.CircleImageView | import bou.amine.apps.readerforselfossv2.android.utils.CircleImageView | ||||||
| import bou.amine.apps.readerforselfossv2.service.AppSettingsService | import bou.amine.apps.readerforselfossv2.service.AppSettingsService | ||||||
|  | import bou.amine.apps.readerforselfossv2.utils.isEmptyOrNullOrNullString | ||||||
| import com.bumptech.glide.Glide | import com.bumptech.glide.Glide | ||||||
| import com.bumptech.glide.load.engine.DiskCacheStrategy | import com.bumptech.glide.load.engine.DiskCacheStrategy | ||||||
| import com.bumptech.glide.load.model.GlideUrl | import com.bumptech.glide.load.model.GlideUrl | ||||||
| @@ -22,8 +23,12 @@ import kotlin.io.encoding.ExperimentalEncodingApi | |||||||
|  |  | ||||||
| private const val PRELOAD_IMAGE_TIMEOUT = 10000 | private const val PRELOAD_IMAGE_TIMEOUT = 10000 | ||||||
|  |  | ||||||
|  | @Suppress("detekt:ReturnCount") | ||||||
| @OptIn(ExperimentalEncodingApi::class) | @OptIn(ExperimentalEncodingApi::class) | ||||||
| fun String.toGlideUrl(appSettingsService: AppSettingsService): GlideUrl { | fun String.toGlideUrl(appSettingsService: AppSettingsService): Any { // GlideUrl Or String | ||||||
|  |     if (this.isEmptyOrNullOrNullString()) { | ||||||
|  |         return "" | ||||||
|  |     } | ||||||
|     if (appSettingsService.getBasicUserName().isNotEmpty()) { |     if (appSettingsService.getBasicUserName().isNotEmpty()) { | ||||||
|         val authString = "${appSettingsService.getBasicUserName()}:${appSettingsService.getBasicPassword()}" |         val authString = "${appSettingsService.getBasicUserName()}:${appSettingsService.getBasicPassword()}" | ||||||
|         val authBuf = Base64.encode(authString.toByteArray(Charsets.UTF_8)) |         val authBuf = Base64.encode(authString.toByteArray(Charsets.UTF_8)) | ||||||
|   | |||||||
| @@ -71,35 +71,13 @@ | |||||||
|  |  | ||||||
|     </androidx.core.widget.NestedScrollView> |     </androidx.core.widget.NestedScrollView> | ||||||
|  |  | ||||||
|     <FrameLayout |     <com.leinardi.android.speeddial.SpeedDialView | ||||||
|         android:layout_width="match_parent" |         android:id="@+id/speedDial" | ||||||
|  |         android:layout_width="wrap_content" | ||||||
|         android:layout_height="wrap_content" |         android:layout_height="wrap_content" | ||||||
|         android:layout_gravity="start|bottom|end" |         android:layout_gravity="bottom|end" | ||||||
|         app:layout_constraintBottom_toBottomOf="parent" |         app:layout_behavior="@string/speeddial_scrolling_view_snackbar_behavior" | ||||||
|         app:layout_constraintEnd_toEndOf="parent" |         app:sdMainFabClosedSrc="@drawable/ic_add_white_24dp" /> | ||||||
|         app:layout_constraintStart_toStartOf="parent"> |  | ||||||
|  |  | ||||||
|         <com.github.rubensousa.floatingtoolbar.FloatingToolbar |  | ||||||
|             android:id="@+id/floatingToolbar" |  | ||||||
|             android:layout_width="match_parent" |  | ||||||
|             android:layout_height="?attr/actionBarSize" |  | ||||||
|             android:layout_gravity="bottom" |  | ||||||
|             app:floatingMenu="@menu/reader_toolbar" /> |  | ||||||
|  |  | ||||||
|         <com.google.android.material.floatingactionbutton.FloatingActionButton |  | ||||||
|             android:id="@+id/fab" |  | ||||||
|             android:layout_width="wrap_content" |  | ||||||
|             android:layout_height="wrap_content" |  | ||||||
|             android:layout_gravity="end|bottom" |  | ||||||
|             android:layout_marginEnd="16dp" |  | ||||||
|             android:layout_marginBottom="16dp" |  | ||||||
|             android:paddingTop="@dimen/activity_vertical_margin" |  | ||||||
|             android:paddingBottom="@dimen/activity_vertical_margin" |  | ||||||
|             android:src="@drawable/ic_add_white_24dp" |  | ||||||
|             app:backgroundTint="?attr/colorAccent" |  | ||||||
|             app:fabSize="mini" |  | ||||||
|             app:rippleColor="?attr/colorAccentDark" /> |  | ||||||
|     </FrameLayout> |  | ||||||
|  |  | ||||||
|     <FrameLayout |     <FrameLayout | ||||||
|         android:id="@+id/progressBar" |         android:id="@+id/progressBar" | ||||||
| @@ -119,4 +97,5 @@ | |||||||
|             android:progressTint="?attr/colorAccent" /> |             android:progressTint="?attr/colorAccent" /> | ||||||
|     </FrameLayout> |     </FrameLayout> | ||||||
|  |  | ||||||
|  |  | ||||||
| </androidx.coordinatorlayout.widget.CoordinatorLayout> | </androidx.coordinatorlayout.widget.CoordinatorLayout> | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> |  | ||||||
| <menu xmlns:android="http://schemas.android.com/apk/res/android" |  | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto"> |  | ||||||
|  |  | ||||||
|     <item |  | ||||||
|         android:id="@+id/unread_action" |  | ||||||
|         android:icon="@drawable/ic_baseline_white_eye_24dp" |  | ||||||
|         android:title="@string/unmark" |  | ||||||
|         app:showAsAction="ifRoom" /> |  | ||||||
|  |  | ||||||
|     <item |  | ||||||
|         android:id="@+id/open_action" |  | ||||||
|         android:icon="@drawable/ic_open_in_browser_white_24dp" |  | ||||||
|         android:title="@string/reader_action_open" |  | ||||||
|         app:showAsAction="ifRoom" /> |  | ||||||
|  |  | ||||||
|     <item |  | ||||||
|         android:id="@+id/share_action" |  | ||||||
|         android:icon="@drawable/ic_share_white_24dp" |  | ||||||
|         android:title="@string/reader_action_share" |  | ||||||
|         app:showAsAction="ifRoom" /> |  | ||||||
|  |  | ||||||
| </menu> |  | ||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <string name="reader_text_align_left">Linksbündig</string> |     <string name="reader_text_align_left">Linksbündig</string> | ||||||
|     <string name="reader_text_align_justify">Blocksatz</string> |     <string name="reader_text_align_justify">Blocksatz</string> | ||||||
|     <string name="settings_reader_font">Schriftgröße im Lesemodus</string> |     <string name="settings_reader_font">Schriftgröße im Lesemodus</string> | ||||||
|     <string name="reader_static_bar_title">Statische untere Leiste im Lesemodus</string> |  | ||||||
|     <string name="reader_static_bar_on">Die untere Leiste wird dauerhaft angezeigt</string> |  | ||||||
|     <string name="reader_static_bar_off">Die untere Leiste kann über einen schwebenden Button angezeigt werden</string> |  | ||||||
|     <string name="remove_source">Quelle entfernen</string> |     <string name="remove_source">Quelle entfernen</string> | ||||||
|     <string name="pref_theme_title">Heller/Dunkler Modus</string> |     <string name="pref_theme_title">Heller/Dunkler Modus</string> | ||||||
|     <string name="mode_dark">Dunkler Modus</string> |     <string name="mode_dark">Dunkler Modus</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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">Supprimer la source</string> |     <string name="remove_source">Supprimer la source</string> | ||||||
|     <string name="pref_theme_title">Thème Clair/Sombre</string> |     <string name="pref_theme_title">Thème Clair/Sombre</string> | ||||||
|     <string name="mode_dark">Thème sombre</string> |     <string name="mode_dark">Thème sombre</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Eliminar fonte</string> | ||||||
|     <string name="pref_theme_title">Modo Claro/Escuro</string> |     <string name="pref_theme_title">Modo Claro/Escuro</string> | ||||||
|     <string name="mode_dark">Modo escuro</string> |     <string name="mode_dark">Modo escuro</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ | |||||||
|     <string name="wrong_infos">"Controleer de gegevens nogmaals."</string> |     <string name="wrong_infos">"Controleer de gegevens nogmaals."</string> | ||||||
|     <string name="all_posts_not_read">"Fout bij markeren als gelezen"</string> |     <string name="all_posts_not_read">"Fout bij markeren als gelezen"</string> | ||||||
|     <string name="all_posts_read">"Alle artikelen gemarkeerd als gelezen"</string> |     <string name="all_posts_read">"Alle artikelen gemarkeerd als gelezen"</string> | ||||||
|  |     <string name="undo_string">"Ongedaan maken"</string> | ||||||
|     <string name="addStringNoUrl">"Login om bronnen toe te voegen"</string> |     <string name="addStringNoUrl">"Login om bronnen toe te voegen"</string> | ||||||
|     <string name="cant_get_sources">"Kan de lijst met bronnen niet ophalen"</string> |     <string name="cant_get_sources">"Kan de lijst met bronnen niet ophalen"</string> | ||||||
|     <string name="cant_create_source">"Kan bron niet creëeren"</string> |     <string name="cant_create_source">"Kan bron niet creëeren"</string> | ||||||
| @@ -105,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
| @@ -131,5 +129,4 @@ | |||||||
|     <string name="action_about">"Over"</string> |     <string name="action_about">"Over"</string> | ||||||
|     <string name="marked_as_read">"Artikel gelezen"</string> |     <string name="marked_as_read">"Artikel gelezen"</string> | ||||||
|     <string name="marked_as_unread">"Item unread"</string> |     <string name="marked_as_unread">"Item unread"</string> | ||||||
|     <string name="undo_string">"Ongedaan maken"</string> |  | ||||||
| </resources> | </resources> | ||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">删除源</string> | ||||||
|     <string name="pref_theme_title">浅色/深色模式</string> |     <string name="pref_theme_title">浅色/深色模式</string> | ||||||
|     <string name="mode_dark">深色模式</string> |     <string name="mode_dark">深色模式</string> | ||||||
|   | |||||||
| @@ -106,9 +106,6 @@ | |||||||
|     <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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								androidApp/src/main/res/values/ids.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								androidApp/src/main/res/values/ids.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <resources> | ||||||
|  |     <item name="unread_action" type="id" /> | ||||||
|  |     <item name="open_action" type="id" /> | ||||||
|  |     <item name="share_action" type="id" /> | ||||||
|  | </resources> | ||||||
| @@ -108,9 +108,6 @@ | |||||||
|     <string name="source_code_pro_font_id" translatable="false">source_code_pro_medium</string> |     <string name="source_code_pro_font_id" translatable="false">source_code_pro_medium</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> |     <string name="remove_source">Remove source</string> | ||||||
|     <string name="pref_theme_title">Light/Dark mode</string> |     <string name="pref_theme_title">Light/Dark mode</string> | ||||||
|     <string name="mode_dark">Dark mode</string> |     <string name="mode_dark">Dark mode</string> | ||||||
|   | |||||||
| @@ -30,14 +30,6 @@ | |||||||
|         android:summaryOn="@string/pref_article_viewer_on" |         android:summaryOn="@string/pref_article_viewer_on" | ||||||
|         android:title="@string/pref_article_viewer_title" |         android:title="@string/pref_article_viewer_title" | ||||||
|         app:iconSpaceReserved="false"/> |         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"> | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| plugins { | plugins { | ||||||
|     //trick: for the same plugin versions in all sub-modules |     // trick: for the same plugin versions in all sub-modules | ||||||
|     id("com.android.application").version("8.7.3").apply(false) |     id("com.android.application").version("8.8.0").apply(false) | ||||||
|     id("com.android.library").version("8.7.3").apply(false) |     id("com.android.library").version("8.8.0").apply(false) | ||||||
|     id("org.jetbrains.kotlin.android").version("2.1.0").apply(false) |     id("org.jetbrains.kotlin.android").version("2.1.0").apply(false) | ||||||
|     kotlin("multiplatform").version("2.1.0").apply(false) |     kotlin("multiplatform").version("2.1.0").apply(false) | ||||||
|     id("com.mikepenz.aboutlibraries.plugin").version("10.5.1").apply(false) |     id("com.mikepenz.aboutlibraries.plugin").version("10.5.1").apply(false) | ||||||
| @@ -16,7 +16,6 @@ allprojects { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| tasks.register("clean", Delete::class) { | tasks.register("clean", Delete::class) { | ||||||
|     delete(layout.buildDirectory) |     delete(layout.buildDirectory) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,5 @@ | |||||||
|  | **v125010131** | ||||||
|  |  | ||||||
|  | - fix: reload the adapter when it's needed. Fixes #128. (#176) | ||||||
|  | - feat: basic auth and images loading. Fixes #172. (#175) | ||||||
|  | - Changelog for v125010111 | ||||||
| @@ -0,0 +1,6 @@ | |||||||
|  | **v125010201** | ||||||
|  |  | ||||||
|  | - fix: Handle empty url issue. | ||||||
|  | - Merge pull request 'Removed the floating bar.' (#177) from floating-bar into master | ||||||
|  | - chore: changing actions in reader fragment. | ||||||
|  | - Changelog for v125010131 | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | **v125010241** | ||||||
|  |  | ||||||
|  | - Merge pull request 'fix: Link not opening.' (#178) from fix-open-link into master | ||||||
|  | - refactor: context fragments issues. | ||||||
|  | - logs: Context issues. | ||||||
|  | - fix: Handle empty url issue, again. | ||||||
|  | - fix: Link not opening. | ||||||
|  | - Changelog for v125010201 | ||||||
| @@ -18,7 +18,7 @@ kotlin.code.style=official | |||||||
| #Android | #Android | ||||||
| android.useAndroidX=true | android.useAndroidX=true | ||||||
| #android.nonTransitiveRClass=true | #android.nonTransitiveRClass=true | ||||||
| android.enableJetifier=true | android.enableJetifier=false | ||||||
| android.nonTransitiveRClass=false | android.nonTransitiveRClass=false | ||||||
| #MPP | #MPP | ||||||
| kotlin.mpp.enableCInteropCommonization=true | kotlin.mpp.enableCInteropCommonization=true | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| #Mon Nov 25 22:48:24 CET 2024 | #Sun Feb 09 14:44:52 CET 2025 | ||||||
| distributionBase=GRADLE_USER_HOME | distributionBase=GRADLE_USER_HOME | ||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.9-bin.zip | distributionUrl=https\://services.gradle.org/distributions/gradle-8.10.2-bin.zip | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
| zipStorePath=wrapper/dists | zipStorePath=wrapper/dists | ||||||
|   | |||||||
| @@ -53,7 +53,6 @@ class AppSettingsService( | |||||||
|     private var activeAlignment: Int? = null |     private var activeAlignment: Int? = null | ||||||
|  |  | ||||||
|     private var fontSize: Int? = null |     private var fontSize: Int? = null | ||||||
|     private var staticBar: Boolean? = null |  | ||||||
|     private var font: String = "" |     private var font: String = "" | ||||||
|     private var theme: Int? = null |     private var theme: Int? = null | ||||||
|  |  | ||||||
| @@ -386,17 +385,6 @@ class AppSettingsService( | |||||||
|         return fontSize ?: DEFAULT_FONT_SIZE |         return fontSize ?: DEFAULT_FONT_SIZE | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun refreshStaticBarEnabled() { |  | ||||||
|         staticBar = settings.getBoolean(READER_STATIC_BAR, false) |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     fun isStaticBarEnabled(): Boolean { |  | ||||||
|         if (staticBar != null) { |  | ||||||
|             refreshStaticBarEnabled() |  | ||||||
|         } |  | ||||||
|         return staticBar == true |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private fun refreshFont() { |     private fun refreshFont() { | ||||||
|         font = settings.getString(READER_FONT, "") |         font = settings.getString(READER_FONT, "") | ||||||
|     } |     } | ||||||
| @@ -449,7 +437,6 @@ class AppSettingsService( | |||||||
|         refreshActiveAllignment() |         refreshActiveAllignment() | ||||||
|         refreshFontSize() |         refreshFontSize() | ||||||
|         refreshFont() |         refreshFont() | ||||||
|         refreshStaticBarEnabled() |  | ||||||
|         refreshCurrentTheme() |         refreshCurrentTheme() | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -547,8 +534,6 @@ class AppSettingsService( | |||||||
|  |  | ||||||
|         const val READER_FONT = "reader_font" |         const val READER_FONT = "reader_font" | ||||||
|  |  | ||||||
|         const val READER_STATIC_BAR = "reader_static_bar" |  | ||||||
|  |  | ||||||
|         const val READER_FONT_SIZE = "reader_font_size" |         const val READER_FONT_SIZE = "reader_font_size" | ||||||
|  |  | ||||||
|         const val TEXT_ALIGN = "text_align" |         const val TEXT_ALIGN = "text_align" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user