vue-spring-bottom-sheet is built on top of @vueuse/gesture and @vueuse/motion.
π Modern and π Performant Bottom Sheet for Vue.js
Demo π
npm install @douxcode/vue-spring-bottom-sheet
bun i @douxcode/vue-spring-bottom-sheet
<script setup>
import BottomSheet from '@douxcode/vue-bottom-sheet'
import '@douxcode/vue-bottom-sheet/dist/style.css'
import { ref } from 'vue'
const bottomSheet = ref(null)
const open = () => {
bottomSheet.value.open()
}
const close = () => {
bottomSheet.value.close()
}
</script>
<template>
<BottomSheet ref="bottomSheet"> Your awesome content </BottomSheet>
</template>
<script setup lang="ts">
import BottomSheet from '@douxcode/vue-bottom-sheet'
import '@douxcode/vue-bottom-sheet/dist/style.css'
import { ref } from 'vue'
const bottomSheet = ref<InstanceType<typeof BottomSheet>>()
const open = () => {
bottomSheet.value.open()
}
const close = () => {
bottomSheet.value.close()
}
</script>
<template>
<BottomSheet ref="bottomSheet"> Your content </BottomSheet>
</template>
For Nuxt 3, just wrap component in <ClientOnly>
<template>
<ClientOnly>
<BottomSheet ref="bottomSheet"> Your awesome content </BottomSheet>
</ClientOnly>
</template>
--vsbs-backdrop-bg: rgba(0, 0, 0, 0.5);
--vsbs-shadow-color: rgba(89, 89, 89, 0.2);
--vsbs-background: #fff;
--vsbs-border-radius: 16px;
--vsbs-max-width: 640px;
--vsbs-border-color: rgba(46, 59, 66, 0.125);
--vsbs-padding-x: 16px;
--vsbs-handle-background: rgba(0, 0, 0, 0.28);
Prop | Type | Description | Example |
---|---|---|---|
snapPoints | Number[] | Defines custom snapping positions for the bottom sheet | :snapPoints="[300, 600, 900]" |
defaultSnapPoint | Number | Specifies the default snap point | :default-snap-point="600" |
blocking | Boolean | Controls whether the bottom sheet blocks interactions with underlying content | :blocking="true" |
canSwipeClose | Boolean | Enables or disables swipe gestures for closing the sheet | :can-swipe-close="true" |
canOverlayClose | Boolean | Allows tapping the overlay to close the sheet | :can-overlay-close="true" |
expandOnContentDrag | Boolean | Enables expanding the sheet by dragging its content | :expand-on-content-drag="true" |
Prop | Default |
---|---|
snapPoints | minHeight |
defaultSnapPoint | minHeight / minSnapPoint |
blocking | true |
canSwipeClose | true |
canOverlayClose | true |
expandOnContentDrag | true |
Assuming there is const bottomSheet = ref()
Method | Description | Example |
---|---|---|
snapToPoint | Snaps the sheet to a specified point | bottomSheet.value.snapToPoint(300) |
open | Opens the bottom sheet | bottomSheet.value.open() |
close | Closes the bottom sheet | bottomSheet.value.close() |
Event | Description | Example |
---|---|---|
min-height | Fires when the minimum height of the sheet changes. Passes the value as an argument. | @min-height="(n) => {}" |
dragging-up | Fires when the bottom sheet is being dragged up | @dragging-up="() => {}" |
dragging-down | Fires when the bottom sheet is being dragged down | @dragging-down="() => {}" |
opened | Fires when the bottom sheet is opened | @opened="() => {}" |
closed | Fires when the bottom sheet is closed | @closed="() => {}" |
This project was inspired by the following:
- react-spring-bottom-sheet: Accessible βΏοΈ, Delightful β¨, & Fast π
- @webzlodimir/vue-bottom-sheet: π₯ A nice clean and touch-friendly bottom sheet component based on Vue.js and Hammer.js for Vue 3