moko-paging
0.7.2indexedImplements pagination logic for data sources, manages data loading asynchronously, and observes pagination states using `LiveData`. Features include loading pages, refreshing data, and handling pagination states.
Implements pagination logic for data sources, manages data loading asynchronously, and observes pagination states using `LiveData`. Features include loading pages, refreshing data, and handling pagination states.
This is a Kotlin MultiPlatform library that contains pagination logic for kotlin multiplatform
root build.gradle
allprojects {
repositories {
mavenCentral()
}
}
project build.gradle
dependencies {
commonMainApi("dev.icerock.moko:paging:0.7.1")
}
You can use Pagination in commonMain sourceset.
Pagination creation:
val pagination: Pagination<Int> = Pagination(
parentScope = coroutineScope,
dataSource = LambdaPagedListDataSource { currentList ->
extrenalRepository.loadPage(currentList)
},
comparator = Comparator { a: Int, b: Int ->
a - b
},
nextPageListener = { result: Result<List<>> ->
(result.isSuccess) {
println()
} {
println()
}
},
refreshListener = { result: Result<List<>> ->
(result.isSuccess) {
println()
} {
println()
}
},
initValue = listOf(, , )
)
Managing data loading:
// Loading first page
pagination.loadFirstPage()
// Loading next page
pagination.loadNextPage()
// Refreshing pagnation
pagination.refresh()
// Setting new list
pagination.setData(itemsList)
Observing Pagination states:
// Observing the state of the pagination
pagination.state.addObserver { state: ResourceState<List<ItemClass>, Throwable> ->
// ...
}
// Observing the next page loading process
pagination.nextPageLoading.addObserver { isLoading: Boolean ->
// ...
}
// Observing the refresh process
pagination.refreshLoading.addObserver { isRefreshing: Boolean ->
// ...
}
Please see more examples in the sample directory.
paging library;All development (both new features and bug fixes) is performed in the develop branch. This way master always contains the sources of the most recently released version. Please send PRs with bug fixes to the develop branch. Documentation fixes in the markdown files are an exception to this rule. They are updated directly in master.
The develop branch is pushed to master on release.
For more details on contributing please see the contributing guide.
Copyright 2020 IceRock MAG Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance the License.
You may obtain a copy of the License at
http:
Unless applicable law agreed to writing, software
distributed under the License distributed an BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express implied.
See the License the specific language governing permissions
limitations under the License.
PagedListDataSourceloadFirstPage, loadNextPage,
refresh or their duplicates with suspend modifier.LiveData from moko-mvvm.Surfaced from shared tags and platforms — no rankings paid for.