Skip to content
forked from dokar3/sheets

Another BottomSheet in Jetpack Compose.

License

Notifications You must be signed in to change notification settings

niels-hubs/sheets

 
 

Repository files navigation

Sheets

Another BottomSheet in Jetpack Compose.

Features:

  • Independent. Unlike ModalBottomSheetLayout , this bottom sheet will be displayed in a dialog window, which means we can easily create and display multiple sheets in the same composable:

    @Composable
    fun MyComposable() {
        val scope = rememberCoroutineScope()
    
        val sheet1 = rememberBottomSheetState()
        val sheet2 = rememberBottomSheetState()
    
        Column {    
            Button(onClick = { scope.launch { sheet1.expand() } }) {
                Text("Sheet 1")
          }
    
            Button(onClick = { scope.launch { sheet2.expand() } }) {
                Text("Sheet 2")
          }
        }
    
        BottomSheet(state = sheet1) { ... }
        BottomSheet(state = sheet2) { ... }
    }
  • Peek state support:

    val state = rememberBottomSheetState()
    
    BottomSheet(
        state = state,
        /*
         * PeekHeight.px(Int) and PeekHeight.fraction(Float) are supported as well.
         */
        peekHeight = PeekHeight.dp(300),
    ) {
        ...
    }
    
    state.peek()
  • Customizable animation spec:

    val state = rememberBottomSheetState()
    
    state.expand(animationSpec = spring())

Quick start

Add the dependency Maven Central:

implementation "io.github.dokar3:sheets:latest_version"

Basic

val scope = rememberCoroutineScope()
val state = rememberBottomSheetState()

Button(onClick = { scope.launch { state.expand() } }) {
    Text("Show bottom sheet")
}

BottomSheet(state = state) {
    Text("Sheet content")
}

Skip peek state

BottomSheet(
    state = state,
    skipPeek = true,
) { 
    ...
}

Embedded sheet

To embed the sheet in the current layout hierarchy, use the BottomSheetLayout():

Box {
    OtherContent()
    
    val state = rememberBottomSheetState()
    if (state.visible) {
        BottomSheetLayout(state = state) {
            ...
        }
    }
}

License

Copyright 2022 dokar3

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

    http://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.

About

Another BottomSheet in Jetpack Compose.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Kotlin 100.0%