Skip to content

Commit

Permalink
PagerPageHolder: lazy init loading indicator
Browse files Browse the repository at this point in the history
Co-authored-by: ivan <12537387+ivaniskandar@users.noreply.github.com>
  • Loading branch information
AntsyLich and ivaniskandar committed Sep 2, 2024
1 parent 8f9a325 commit a45eb5e
Showing 1 changed file with 18 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ class PagerPageHolder(
/**
* Loading progress bar to indicate the current progress.
*/
private val progressIndicator: ReaderProgressIndicator = ReaderProgressIndicator(readerThemedContext)
private var progressIndicator: ReaderProgressIndicator? = null // = ReaderProgressIndicator(readerThemedContext)

/**
* Error layout to show when the image fails to load.
Expand All @@ -60,7 +60,6 @@ class PagerPageHolder(
private var loadJob: Job? = null

init {
addView(progressIndicator)
loadJob = scope.launch { loadPageAndProcessStatus() }
}

Expand All @@ -74,6 +73,13 @@ class PagerPageHolder(
loadJob = null
}

private fun initProgressIndicator() {
if (progressIndicator == null) {
progressIndicator = ReaderProgressIndicator(context)
addView(progressIndicator)
}
}

/**
* Loads the page and processes changes to the page's status.
*
Expand All @@ -95,7 +101,7 @@ class PagerPageHolder(
Page.State.DOWNLOAD_IMAGE -> {
setDownloading()
page.progressFlow.collectLatest { value ->
progressIndicator.setProgress(value)
progressIndicator?.setProgress(value)
}
}
Page.State.READY -> setImage()
Expand All @@ -109,31 +115,34 @@ class PagerPageHolder(
* Called when the page is queued.
*/
private fun setQueued() {
progressIndicator.show()
initProgressIndicator()
progressIndicator?.show()
removeErrorLayout()
}

/**
* Called when the page is loading.
*/
private fun setLoading() {
progressIndicator.show()
initProgressIndicator()
progressIndicator?.show()
removeErrorLayout()
}

/**
* Called when the page is downloading.
*/
private fun setDownloading() {
progressIndicator.show()
initProgressIndicator()
progressIndicator?.show()
removeErrorLayout()
}

/**
* Called when the page is ready.
*/
private suspend fun setImage() {
progressIndicator.setProgress(0)
progressIndicator?.setProgress(0)

val streamFn = page.stream ?: return

Expand Down Expand Up @@ -234,13 +243,13 @@ class PagerPageHolder(
* Called when the page has an error.
*/
private fun setError() {
progressIndicator.hide()
progressIndicator?.hide()
showErrorLayout()
}

override fun onImageLoaded() {
super.onImageLoaded()
progressIndicator.hide()
progressIndicator?.hide()
}

/**
Expand Down

0 comments on commit a45eb5e

Please sign in to comment.