mirror of
				https://github.com/InsanusMokrassar/MicroUtils.git
				synced 2025-10-26 17:50:41 +00:00 
			
		
		
		
	paginations improvements
This commit is contained in:
		| @@ -20,7 +20,13 @@ data class PaginationResult<T>( | ||||
|      * Amount of pages for current pagination | ||||
|      */ | ||||
|     @EncodeDefault | ||||
|     val pagesNumber: Int = ceil(objectsNumber / size.toFloat()).toInt() | ||||
|     @SerialName("pagesNumber") | ||||
|     val pagesNumberLong: Long = ceil(objectsNumber / size.toFloat()).toLong() | ||||
|     /** | ||||
|      * Amount of pages for current pagination | ||||
|      */ | ||||
|     @Transient | ||||
|     val pagesNumber: Int = pagesNumberLong.toInt() | ||||
|  | ||||
|     constructor( | ||||
|         page: Int, | ||||
| @@ -35,6 +41,15 @@ data class PaginationResult<T>( | ||||
|     ) | ||||
| } | ||||
|  | ||||
| val PaginationResult<*>.lastPageLong | ||||
|     get() = pagesNumberLong - 1 | ||||
|  | ||||
| val PaginationResult<*>.lastPage | ||||
|     get() = lastPageLong.toInt() | ||||
|  | ||||
| val PaginationResult<*>.isLastPage | ||||
|     get() = page.toLong() == lastPageLong | ||||
|  | ||||
| fun <T> emptyPaginationResult() = PaginationResult<T>(0, 0, emptyList(), 0L) | ||||
| fun <T> emptyPaginationResult( | ||||
|     basePagination: Pagination | ||||
|   | ||||
| @@ -10,8 +10,7 @@ inline fun doWithPagination( | ||||
|     } | ||||
| } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun PaginationResult<*>.nextPageIfNotEmpty() = if (results.isNotEmpty()) { | ||||
| inline fun <T, PR: PaginationResult<T>> PR.nextPageIfTrue(condition: PR.() -> Boolean) = if (condition()) { | ||||
|     SimplePagination( | ||||
|         page + 1, | ||||
|         size | ||||
| @@ -20,12 +19,28 @@ inline fun PaginationResult<*>.nextPageIfNotEmpty() = if (results.isNotEmpty()) | ||||
|     null | ||||
| } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun <T> PaginationResult<T>.thisPageIfNotEmpty(): PaginationResult<T>? = if (results.isNotEmpty()) { | ||||
| inline fun <T, PR: PaginationResult<T>> PR.thisPageIfTrue(condition: PR.() -> Boolean): PR? = if (condition()) { | ||||
|     this | ||||
| } else { | ||||
|     null | ||||
| } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun <T> PaginationResult<T>.currentPageIfNotEmpty() = thisPageIfNotEmpty() | ||||
| fun PaginationResult<*>.nextPageIfNotEmpty() = nextPageIfTrue { results.isNotEmpty() } | ||||
|  | ||||
| fun <T> PaginationResult<T>.thisPageIfNotEmpty(): PaginationResult<T>? = thisPageIfTrue { results.isNotEmpty() } | ||||
|  | ||||
| fun <T> PaginationResult<T>.currentPageIfNotEmpty() = thisPageIfNotEmpty() | ||||
|  | ||||
|  | ||||
| fun PaginationResult<*>.nextPageIfNotEmptyOrLastPage() = nextPageIfTrue { results.isNotEmpty() && !this.isLastPage } | ||||
|  | ||||
| fun <T> PaginationResult<T>.thisPageIfNotEmptyOrLastPage(): PaginationResult<T>? = thisPageIfTrue  { results.isNotEmpty() && !this.isLastPage } | ||||
|  | ||||
| fun <T> PaginationResult<T>.currentPageIfNotEmptyOrLastPage() = thisPageIfNotEmptyOrLastPage() | ||||
|  | ||||
|  | ||||
| fun PaginationResult<*>.nextPageIfNotLastPage() = nextPageIfTrue { !this.isLastPage } | ||||
|  | ||||
| fun <T> PaginationResult<T>.thisPageIfNotLastPage(): PaginationResult<T>? = thisPageIfTrue  { !this.isLastPage } | ||||
|  | ||||
| fun <T> PaginationResult<T>.currentPageIfNotLastPage() = thisPageIfNotLastPage() | ||||
|   | ||||
| @@ -18,7 +18,7 @@ inline fun <T> doForAllWithNextPaging( | ||||
| ) { | ||||
|     doForAll( | ||||
|         initialPagination, | ||||
|         { it.nextPageIfNotEmpty() }, | ||||
|         { it.nextPageIfNotEmptyOrLastPage() }, | ||||
|         block | ||||
|     ) | ||||
| } | ||||
| @@ -29,7 +29,7 @@ inline fun <T> doAllWithCurrentPaging( | ||||
| ) { | ||||
|     doForAll( | ||||
|         initialPagination, | ||||
|         { it.currentPageIfNotEmpty() }, | ||||
|         { it.nextPageIfNotEmptyOrLastPage() }, | ||||
|         block | ||||
|     ) | ||||
| } | ||||
|   | ||||
| @@ -31,7 +31,7 @@ inline fun <T> getAllWithNextPaging( | ||||
|     block: (Pagination) -> PaginationResult<T> | ||||
| ): List<T> = getAll( | ||||
|     initialPagination, | ||||
|     { it.nextPageIfNotEmpty() }, | ||||
|     { it.nextPageIfNotEmptyOrLastPage() }, | ||||
|     block | ||||
| ) | ||||
|  | ||||
| @@ -48,7 +48,7 @@ inline fun <T> getAllWithCurrentPaging( | ||||
|     block: (Pagination) -> PaginationResult<T> | ||||
| ): List<T> = getAll( | ||||
|     initialPagination, | ||||
|     { it.currentPageIfNotEmpty() }, | ||||
|     { it.thisPageIfNotEmptyOrLastPage() }, | ||||
|     block | ||||
| ) | ||||
|  | ||||
|   | ||||
| @@ -21,8 +21,9 @@ fun <T> Iterable<T>.paginate(with: Pagination): PaginationResult<T> { | ||||
| } | ||||
|  | ||||
| fun <T> List<T>.paginate(with: Pagination): PaginationResult<T> { | ||||
|     val firstIndex = maxOf(with.firstIndex, 0) | ||||
|     val lastIndex = minOf(with.lastIndexExclusive, size) | ||||
|     val indices = indices | ||||
|     val firstIndex = with.firstIndex.coerceIn(indices) | ||||
|     val lastIndex = with.lastIndex.coerceIn(indices) + 1 // up to size | ||||
|     if (firstIndex > lastIndex) { | ||||
|         return emptyPaginationResult() | ||||
|     } | ||||
| @@ -38,8 +39,8 @@ fun <T> List<T>.paginate(with: Pagination, reversed: Boolean): PaginationResult< | ||||
|         reversed | ||||
|     ) | ||||
|  | ||||
|     val firstIndex = maxOf(actualPagination.firstIndex, 0) | ||||
|     val lastIndex = minOf(actualPagination.lastIndexExclusive, size) | ||||
|     val firstIndex = actualPagination.firstIndex.coerceIn(indices) | ||||
|     val lastIndex = actualPagination.lastIndex.coerceIn(indices) + 1 // up to size | ||||
|     if (firstIndex > lastIndex) { | ||||
|         return emptyPaginationResult() | ||||
|     } | ||||
|   | ||||
| @@ -0,0 +1,34 @@ | ||||
| package dev.inmo.micro_utils.pagination.utils | ||||
|  | ||||
| import dev.inmo.micro_utils.pagination.FirstPagePagination | ||||
| import dev.inmo.micro_utils.pagination.firstIndex | ||||
| import dev.inmo.micro_utils.pagination.isLastPage | ||||
| import dev.inmo.micro_utils.pagination.lastIndexExclusive | ||||
| import kotlin.test.Test | ||||
| import kotlin.test.assertEquals | ||||
| import kotlin.test.assertTrue | ||||
|  | ||||
| class PaginationPaging { | ||||
|     @Test | ||||
|     fun testPaginateOnList() { | ||||
|         val list = (0 until 7).toList() | ||||
|         val startPagination = FirstPagePagination(2) | ||||
|  | ||||
|         var lastPageHappened = false | ||||
|         doForAllWithNextPaging(startPagination) { | ||||
|             val result = list.paginate(it) | ||||
|  | ||||
|             if (result.isLastPage) { | ||||
|                 lastPageHappened = true | ||||
|                 assertTrue(result.results.size == 1) | ||||
|             } | ||||
|  | ||||
|             val testSublist = list.subList(it.firstIndex, minOf(it.lastIndexExclusive, list.size)) | ||||
|             assertEquals(result.results, testSublist) | ||||
|  | ||||
|             result | ||||
|         } | ||||
|  | ||||
|         assertTrue(lastPageHappened) | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user