Skip to Content
Creation UI 15.0 is released 🎉

Drawer

A drawer is a UI element that overlays on top of the current page. It is commonly used to display additional content or actions for the user.

Custom styles drawer

import { Button, Drawer } from '@creation-ui/react' import { useState } from 'react' export const DrawerCustomizedExample = () => { const [open, setOpen] = useState(false) const handleOpen = () => setOpen(true) const handleClose = () => setOpen(false) const innerClasses = [ '!w-[calc(100%-30px)]', '!h-[calc(100%-30px)]', 'rounded-xl', 'm-[15px]', ] return ( <Container> <Button onClick={handleOpen}>Open Drawer</Button> <Drawer open={open} onClose={handleClose} cx={{ width: 'xl:w-1/3 lg:w-1/2 w-full', container: { inner: clsx(innerClasses), }, }} > <div className='p-5 flex flex-col'> <h1>Title</h1> <div className='mt-2 flex-grow'> <p className='text-sm text-gray-500'>Content</p> </div> <div className='mt-4'> <Button onClick={handleClose}>Save</Button> </div> </div> </Drawer> </Container> ) }

Component API

Drawer component props.

PropDefaultDescription
openfalse
boolean

Is component visible

children—
React.ReactNode

Children to be rendered inside the component

position—
top | bottom | right | left

Position of the element

onClose—
() => void

Callback function called when closing Drawer

onOverlayClick—
() => void

Callback function called on overlay click. Maybe used to close Drawer or prevent closing.

cx—
{"height?":"string","width?":"string","container?":{"outer?":"string","inner?":"string"}}

Class names manipulation API. Width and height control how much space Drawer takes. container.outer and container.inner control can be used to change how content is styled.

Last updated on