mirror of
https://github.com/InsanusMokrassar/MicroUtils.git
synced 2026-06-24 20:25:10 +00:00
Compare commits
6 Commits
v0.25.7
...
50f3f586ab
| Author | SHA1 | Date | |
|---|---|---|---|
| 50f3f586ab | |||
| 36a2d7ec8e | |||
| 4890b5833e | |||
| e20ab89688 | |||
| e557ba8184 | |||
| 8540e21d5a |
@@ -1,5 +1,12 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## 0.25.8
|
||||||
|
|
||||||
|
* `Pagination`:
|
||||||
|
* `Compose`:
|
||||||
|
* New function `rememberInfinityPagedComponentContext` to create `InfinityPagedComponentContext`
|
||||||
|
* New variants of `InfinityPagedComponent` component
|
||||||
|
|
||||||
## 0.25.7
|
## 0.25.7
|
||||||
|
|
||||||
* `Versions`:
|
* `Versions`:
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ if ((project.hasProperty('SONATYPE_USER') || System.getenv('SONATYPE_USER') != n
|
|||||||
username = project.hasProperty('SONATYPE_USER') ? project.property('SONATYPE_USER') : System.getenv('SONATYPE_USER')
|
username = project.hasProperty('SONATYPE_USER') ? project.property('SONATYPE_USER') : System.getenv('SONATYPE_USER')
|
||||||
password = project.hasProperty('SONATYPE_PASSWORD') ? project.property('SONATYPE_PASSWORD') : System.getenv('SONATYPE_PASSWORD')
|
password = project.hasProperty('SONATYPE_PASSWORD') ? project.property('SONATYPE_PASSWORD') : System.getenv('SONATYPE_PASSWORD')
|
||||||
verificationTimeout = Duration.ofHours(4)
|
verificationTimeout = Duration.ofHours(4)
|
||||||
publishingType = "USER_MANAGED"
|
publishingType = System.getenv('PUBLISHING_TYPE') != "" ? System.getenv('PUBLISHING_TYPE') : "USER_MANAGED"
|
||||||
}
|
}
|
||||||
|
|
||||||
publishAllProjectsProbablyBreakingProjectIsolation()
|
publishAllProjectsProbablyBreakingProjectIsolation()
|
||||||
|
|||||||
@@ -15,5 +15,5 @@ crypto_js_version=4.1.1
|
|||||||
# Project data
|
# Project data
|
||||||
|
|
||||||
group=dev.inmo
|
group=dev.inmo
|
||||||
version=0.25.7
|
version=0.25.8
|
||||||
android_code_version=297
|
android_code_version=298
|
||||||
|
|||||||
@@ -65,6 +65,60 @@ class InfinityPagedComponentContext<T> internal constructor(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates and remembers an [InfinityPagedComponentContext] for managing infinite pagination in a Compose UI.
|
||||||
|
* This function is used to create a persistent pagination context that survives recompositions.
|
||||||
|
*
|
||||||
|
* @param size Number of items to load per page.
|
||||||
|
* @param page Initial page number to start pagination from (defaults to 0).
|
||||||
|
* @param scope [CoroutineScope] to launch pagination operations in. If not provided, a new scope will be created
|
||||||
|
* using [rememberCoroutineScope].
|
||||||
|
* @param loader Suspended function that loads paginated data. Receives the current pagination context and
|
||||||
|
* pagination parameters, and returns a [PaginationResult] containing the loaded data.
|
||||||
|
* @return An [InfinityPagedComponentContext] instance that manages the pagination state and operations.
|
||||||
|
*/
|
||||||
|
@Composable
|
||||||
|
fun <T> rememberInfinityPagedComponentContext(
|
||||||
|
size: Int,
|
||||||
|
page: Int = 0,
|
||||||
|
scope: CoroutineScope = rememberCoroutineScope(),
|
||||||
|
doReloadInInit: Boolean = true,
|
||||||
|
loader: suspend InfinityPagedComponentContext<T>.(Pagination) -> PaginationResult<T>
|
||||||
|
): InfinityPagedComponentContext<T> {
|
||||||
|
val context = remember {
|
||||||
|
InfinityPagedComponentContext(
|
||||||
|
page = page,
|
||||||
|
size = size,
|
||||||
|
scope = scope,
|
||||||
|
loader = loader
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
LaunchedEffect(context) {
|
||||||
|
if (doReloadInInit) {
|
||||||
|
context.reload()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return context
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Composable function for managing an infinitely paged component.
|
||||||
|
*
|
||||||
|
* @param T The type of the paginated data.
|
||||||
|
* @param block Composable function that renders the UI with the loaded data. When data is in loading state, block will
|
||||||
|
* receive null as `it` parameter
|
||||||
|
*/
|
||||||
|
@Composable
|
||||||
|
fun <T> InfinityPagedComponent(
|
||||||
|
context: InfinityPagedComponentContext<T>,
|
||||||
|
block: @Composable InfinityPagedComponentContext<T>.(List<T>?) -> Unit
|
||||||
|
) {
|
||||||
|
val dataState = context.dataState.collectAsState()
|
||||||
|
context.block(dataState.value)
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Composable function for managing an infinitely paged component.
|
* Composable function for managing an infinitely paged component.
|
||||||
*
|
*
|
||||||
@@ -76,7 +130,7 @@ class InfinityPagedComponentContext<T> internal constructor(
|
|||||||
* receive null as `it` parameter
|
* receive null as `it` parameter
|
||||||
*/
|
*/
|
||||||
@Composable
|
@Composable
|
||||||
internal fun <T> InfinityPagedComponent(
|
fun <T> InfinityPagedComponent(
|
||||||
page: Int,
|
page: Int,
|
||||||
size: Int,
|
size: Int,
|
||||||
loader: suspend InfinityPagedComponentContext<T>.(Pagination) -> PaginationResult<T>,
|
loader: suspend InfinityPagedComponentContext<T>.(Pagination) -> PaginationResult<T>,
|
||||||
@@ -84,13 +138,8 @@ internal fun <T> InfinityPagedComponent(
|
|||||||
block: @Composable InfinityPagedComponentContext<T>.(List<T>?) -> Unit
|
block: @Composable InfinityPagedComponentContext<T>.(List<T>?) -> Unit
|
||||||
) {
|
) {
|
||||||
val scope = predefinedScope ?: rememberCoroutineScope()
|
val scope = predefinedScope ?: rememberCoroutineScope()
|
||||||
val context = remember { InfinityPagedComponentContext<T>(page, size, scope, loader) }
|
val context = rememberInfinityPagedComponentContext(page = page, size = size, scope = scope, loader = loader)
|
||||||
remember {
|
InfinityPagedComponent(context, block)
|
||||||
context.reload()
|
|
||||||
}
|
|
||||||
|
|
||||||
val dataState = context.dataState.collectAsState()
|
|
||||||
context.block(dataState.value)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Reference in New Issue
Block a user