-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
23 changed files
with
264 additions
and
37 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# Collapsing Header | ||
|
||
Collapsing headers in the library are achieved with a wrapping Composable enclosing a scrollable | ||
layout. | ||
|
||
```kotlin | ||
@Composable | ||
fun CollapsingHeader( | ||
state: CollapsingHeaderState, | ||
headerContent: @Composable () -> Unit, | ||
body: @Composable () -> Unit, | ||
) { | ||
... | ||
} | ||
``` | ||
|
||
It works with any layout in the body composable that supports nested scrolling. | ||
|
||
| Composable | | | | | ||
|---------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------| | ||
| Collapsing Headers | data:image/s3,"s3://crabby-images/5aad4/5aad43731b286cf9a7b9b16829838fc00b2c8a81" alt="collapsing header with scrollbars in a list" | data:image/s3,"s3://crabby-images/9b885/9b88558893e702dc49074bc4acaa7af8c302da70" alt="collapsing header with scrollbars in a grid" | data:image/s3,"s3://crabby-images/2192a/2192adbb0d6ba7a6559921b84397eff0e3de70f1" alt="collapsing header with scrollbars in staggered_grid" | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
# Drag To Dismiss | ||
|
||
Used for easily implementing the drag to dismiss pattern for media. | ||
|
||
```kotlin | ||
@Composable | ||
fun ParentLayout() { | ||
Child( | ||
modifier = Modifier | ||
.dragToDismiss( | ||
state = dragToDismissState, | ||
dragThresholdCheck = { offset, _ -> | ||
offset.getDistanceSquared() > with(density) { | ||
240.dp.toPx().let { it * it } | ||
} | ||
}, | ||
onDismissed = { | ||
... | ||
}, | ||
) | ||
) | ||
... | ||
} | ||
``` | ||
|
||
|
||
| Composable | | | | | ||
|-----------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | ||
| Drag To Dismiss | data:image/s3,"s3://crabby-images/e2643/e2643fac567eb8c38f37b916ca2d4a6f33fad51f" alt="color drag to dismiss" | data:image/s3,"s3://crabby-images/45475/45475874af24f39fe4f6a7c43ccad645717ad2e2" alt="image drag to dismiss" | data:image/s3,"s3://crabby-images/c3548/c3548fe7c91963630c038e7ce71a84ca9082b5b4" alt="video drag to dismiss" | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# Interpolation | ||
|
||
`Alignment` and `ContentScale` are used to help in the layout of composables, however it can be | ||
necessary to interpolate between them when they change. `interpolate()` Composable extension | ||
methods are added to help create a seamless transition. | ||
|
||
```kotlin | ||
@Composable | ||
fun ParentLayout( | ||
contentScale: ContentScale, | ||
alignment: Alignment, | ||
) { | ||
Image( | ||
painter = painter, | ||
contentScale = contentScale.interpolate(), | ||
alignment = alignment.interpolate(), | ||
) | ||
... | ||
} | ||
``` | ||
|
||
| Composable | | | | ||
|----------------------------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------| | ||
| Alignment / ContentScale Interpolation | data:image/s3,"s3://crabby-images/e2ffc/e2ffcfb19ccc10ce1244dde3aa52fab7721da3b3" alt="rounded rect interpolation" | data:image/s3,"s3://crabby-images/3a5e6/3a5e6226a7ae863045617e4c78397f2eb23243f2" alt="beach scene interpolation" | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
# Pointer Offset Scroll Header | ||
|
||
Pointer offsets are useful for manually scrolling containers with [ScrollableState], when the | ||
pointer is already involved in another interaction. For example drag and drop or a long press. | ||
|
||
```kotlin | ||
@Composable | ||
fun Modifier.pointerOffsetScroll( | ||
state: PointerOffsetScrollState, | ||
) { | ||
... | ||
} | ||
``` | ||
|
||
| Composable | | | | | ||
|-----------------------------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------| | ||
| Pointer Offset Scroll | data:image/s3,"s3://crabby-images/1c85e/1c85ee6cf314c272e2c771e848594cf6acfd0e37" alt="pointer offset list scroll" | data:image/s3,"s3://crabby-images/412cb/412cbc8ab20d66865d874537ced9b4aaad3126f1" alt="pointer offset grid scroll" | data:image/s3,"s3://crabby-images/d4569/d4569771be4183eb6a1b4cd0e8f94f927a3bf59e" alt="pointer offset staggered grid" | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
# Scrollbars | ||
|
||
Scrollbars enable tracking a user's position in the list and fast scrolling through it. | ||
|
||
For lazy containers, the easiest way to use them is via the `scrollbarState` extension method: | ||
|
||
```kotlin | ||
@Composable | ||
fun Lazy_State.scrollbarState( | ||
itemsAvailable: Int, | ||
itemIndex: (Lazy_ItemInfo) -> Int = Lazy_ItemInfo::index, | ||
): ScrollbarState { | ||
... | ||
} | ||
``` | ||
|
||
Use of the scroll bar follows the following pattern: | ||
|
||
```kotlin | ||
@Composable | ||
fun FastScrollbar( | ||
modifier: Modifier = Modifier, | ||
state: ScrollbarState, | ||
scrollInProgress: Boolean, | ||
orientation: Orientation, | ||
onThumbMoved: (Float) -> Unit, | ||
) { | ||
val interactionSource = remember { MutableInteractionSource() } | ||
Scrollbar( | ||
modifier = modifier, | ||
orientation = orientation, | ||
interactionSource = interactionSource, | ||
state = state, | ||
thumb = { | ||
FastScrollbarThumb( | ||
scrollInProgress = scrollInProgress, | ||
interactionSource = interactionSource, | ||
orientation = orientation, | ||
) | ||
}, | ||
onThumbMoved = onThumbMoved, | ||
) | ||
} | ||
``` | ||
|
||
They are implemented for scrollable containers with [ScrollState], lists, grids and staggered grids. | ||
|
||
|
||
| Composable | | | | | ||
|-----------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------| | ||
| Collapsing Headers and Scrollbars | data:image/s3,"s3://crabby-images/5aad4/5aad43731b286cf9a7b9b16829838fc00b2c8a81" alt="collapsing header with scrollbars in a list" | data:image/s3,"s3://crabby-images/9b885/9b88558893e702dc49074bc4acaa7af8c302da70" alt="collapsing header with scrollbars in a grid" | data:image/s3,"s3://crabby-images/e4bf1/e4bf1d22c06be3e98ed719c817aacfd3a1ef5356" alt="collapsing header with scrollbars in staggered_grid" | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
# Sticky Headers | ||
|
||
Sticky headers in the library are achieved with a wrapping Composable enclosing the lazy layout. | ||
|
||
```kotlin | ||
@Composable | ||
fun StickyHeader_( | ||
state: Lazy_State, | ||
modifier: Modifier = Modifier, | ||
isStickyHeaderItem: @DisallowComposableCalls (Lazy_ItemInfo) -> Boolean, | ||
stickyHeader: @Composable (key: Any?, contentType: Any?) -> Unit, | ||
content: @Composable () -> Unit | ||
) { | ||
... | ||
} | ||
``` | ||
|
||
They are implemented for lists, grids and staggered grids. | ||
|
||
| Composable | | | | | ||
|-----------------------------------|---------------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------------| | ||
| Sticky Headers | data:image/s3,"s3://crabby-images/423aa/423aaf8fc43cf83db672a2e6ef1e08f664bd88e1" alt="list" | data:image/s3,"s3://crabby-images/69582/69582e0a0e8786675753f400b5a0699876827190" alt="grid" | data:image/s3,"s3://crabby-images/2c514/2c5149e4d84397f86b076650909c7ab9ddffab0e" alt="staggered_grid" | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
# Composables | ||
|
||
[data:image/s3,"s3://crabby-images/743ec/743ec3eaa551eac9247540d75926314f58647eca" alt="JVM Tests"](https://github.com/tunjid/Tiler/actions/workflows/tests.yml) | ||
data:image/s3,"s3://crabby-images/f9926/f992666e42c200b04b490c5c07772ebc036a892e" alt="Composables" | ||
|
||
![badge][badge-ios] | ||
![badge][badge-js] | ||
![badge][badge-jvm] | ||
![badge][badge-linux] | ||
![badge][badge-windows] | ||
![badge][badge-mac] | ||
![badge][badge-tvos] | ||
![badge][badge-watchos] | ||
|
||
Please note, this is an experimental repository. It is a Kotlin multiplatform experiment that makes no guarantees | ||
about API stability or long term support. None of the works presented here are production tested, and should not be | ||
taken as anything more than its face value. | ||
|
||
## Introduction | ||
|
||
Composables are a collection of utility methods that build on the Jetpack Compose UI and Foundation packages. | ||
|
||
They offer APIs for common UI interactions that make UI more delightful. They are summarize below | ||
|
||
| Composable | | | | | ||
|----------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | ||
| Sticky Headers | data:image/s3,"s3://crabby-images/d4648/d46481f06526577b822822e3cb9dffa524435716" alt="list" | data:image/s3,"s3://crabby-images/34b86/34b86de36b3c22fff83ec6524bc9b65eb6eac593" alt="grid" | data:image/s3,"s3://crabby-images/e6ddc/e6ddcc6cd141552c2012229a954ab61a6bc3b02a" alt="staggered_grid" | | ||
| Collapsing Headers and Scrollbars | data:image/s3,"s3://crabby-images/9e789/9e7895b8009e7ae4e7f1996567ba659cbdd152ca" alt="collapsing header with scrollbars in a list" | data:image/s3,"s3://crabby-images/cc255/cc2550a104d2dc860ee52d12bfd912b5aadab2dc" alt="collapsing header with scrollbars in a grid" | data:image/s3,"s3://crabby-images/4275f/4275ff49e70d4c66de3b656d41854a53fb4c4ed9" alt="collapsing header with scrollbars in staggered_grid" | | ||
| Pointer Offset Scroll | data:image/s3,"s3://crabby-images/515c4/515c4a1fd16edb4c874ffcdb503972ab8ea335b6" alt="pointer offset list scroll" | data:image/s3,"s3://crabby-images/c5a5b/c5a5bf5527460cd67064627ef8ec8cbcafcf1a1a" alt="pointer offset grid scroll" | data:image/s3,"s3://crabby-images/8b761/8b7612e11743a513c3a0d983cb936e7a3979287e" alt="pointer offset staggered grid" | | ||
| Drag To Dismiss | data:image/s3,"s3://crabby-images/c596a/c596a62d2f897351fdae438f4ea0810a21c6dcd4" alt="color drag to dismiss" | data:image/s3,"s3://crabby-images/18387/18387a7200acb49534eb13798f5e3d1e4fdd8409" alt="image drag to dismiss" | data:image/s3,"s3://crabby-images/06b7e/06b7eb440ca766b9fad87d74009f79ad9ff8605c" alt="video drag to dismiss" | | ||
| Alignment / ContentScale Interpolation | data:image/s3,"s3://crabby-images/4470f/4470ffdd32f050acb0c4c52946e61dc5851eb902" alt="rounded rect interpolation" | data:image/s3,"s3://crabby-images/17a6b/17a6b7fcba471970c4dbee04d06a5d8ab40cec0b" alt="beach scene interpolation" | | | ||
|
||
Please see the [documentation](https://tunjid.github.io/Composables/) for more details. | ||
|
||
## License | ||
|
||
Copyright 2023 Adetunji Dahunsi | ||
|
||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
|
||
https://www.apache.org/licenses/LICENSE-2.0 | ||
|
||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
|
||
[badge-android]: http://img.shields.io/badge/-android-6EDB8D.svg?style=flat | ||
|
||
[badge-jvm]: http://img.shields.io/badge/-jvm-DB413D.svg?style=flat | ||
|
||
[badge-js]: http://img.shields.io/badge/-js-F8DB5D.svg?style=flat | ||
|
||
[badge-js-ir]: https://img.shields.io/badge/support-[IR]-AAC4E0.svg?style=flat | ||
|
||
[badge-nodejs]: https://img.shields.io/badge/-nodejs-68a063.svg?style=flat | ||
|
||
[badge-linux]: http://img.shields.io/badge/-linux-2D3F6C.svg?style=flat | ||
|
||
[badge-windows]: http://img.shields.io/badge/-windows-4D76CD.svg?style=flat | ||
|
||
[badge-wasm]: https://img.shields.io/badge/-wasm-624FE8.svg?style=flat | ||
|
||
[badge-apple-silicon]: http://img.shields.io/badge/support-[AppleSilicon]-43BBFF.svg?style=flat | ||
|
||
[badge-ios]: http://img.shields.io/badge/-ios-CDCDCD.svg?style=flat | ||
|
||
[badge-mac]: http://img.shields.io/badge/-macos-111111.svg?style=flat | ||
|
||
[badge-watchos]: http://img.shields.io/badge/-watchos-C0C0C0.svg?style=flat | ||
|
||
[badge-tvos]: http://img.shields.io/badge/-tvos-808080.svg?style=flat |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.