🚀 DAY 2 OF LAUNCH WEEK: Unify Your Security Stack with Socket Basics.Learn more →
Socket
Book a DemoInstallSign in
Socket

@element-public/react-drawer

Package Overview
Dependencies
Maintainers
3
Versions
11
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@element-public/react-drawer

Drawer component for Element React

alpha
npmnpm
Version
2.0.0-alpha.0
Version published
Weekly downloads
79
64.58%
Maintainers
3
Weekly downloads
 
Created
Source

Drawer

Description

Navigation drawers provide access to destinations and app functionality, such as switching accounts. It can either be permanently on-screen or controlled by a navigation menu icon. A navigation drawer is recommended for: 1. Apps with five or more top-level destinations 2. Apps with two or more levels of navigation hierarchy 3. Quick navigation between unrelated destinations

See live demos on storybook

Storybook Drawer Demos

Install bundle from npm-e

npm i @element-public/react-components @element-public/themes

Optional: install the component individually

npm i @element-public/react-drawer @element-public/themes
Please Note: You will need to add @element to your .npmrc!

Open ~/.npmrc in an editor and add the following line to enable the @element scope:


@element:registry=https://npm.platforms.engineering

Troubleshooting

See below if you have never installed a package from Bayer's npm-enterprise or run into the following error:


npm ERR! code E401
npm ERR! Unable to authenticate, your authentication token seems to be invalid.
npm ERR! To correct this please trying logging in again with:
npm ERR!     npm login

Setup an access token

See the devtools npm-e guide to learn how to create an access token if this is the first time you are using a npm-e package at Bayer or you do not have a line that starts with the following in your ~/.npmrc file:

//npm.platforms.engineering/:_authToken=

Notes

The Drawer component works with, or include, other components, like Button, to open, close, and navigate the Drawer, Typography, to apply certain styles and sizes of text in the Drawer, and List, to improve the flow of the Drawer's contents for users.

Usage

Different Drawers should be used in various cases. For example, a Permanent Drawer could be used to prevent a user from closing or navigating away from the Drawer, so it is always visible. Alternatively, a Dismissible Drawer can be opened and closed by clicking a button, so it only appears when the user wants it to.

Sub Components

Drawer uses the following sub components:

NameDescription
DrawerPrimary container for all the drawer contents
DrawerHeaderContains the top title portion of the drawer.
DrawerContentThe container for the main body of the drawer.
DrawerScrimCovers the screen behind the drawer component to focus the users attention.
DrawerAppContentContainer for app contents. Its child is resized when the drawer opens/closes.

Drawer Props

NameTypeDefaultRequiredDescription
belowTopAppBarbooleannullfalsePositions the modal lower, below the TopAppBar.
classNamestringundefinedfalseThe css class name to be passed through to the component markup.
openbooleannullfalseDisplays the drawer when variant is either dismissible or modal`
variantstringempty stringfalseDefines the type of drawer. By default the drawer will be always shown, a permanent drawer. If defined, either modal or dismissible
Accepted Values: modal, dismissible

Drawer Deprecated Props

NameTypeDefaultRequiredDeprecatedDescription
dismissiblebooleanundefinedfalseUse variant='dismissible' instead.Enables a dismissible drawer.
modalbooleanundefinedfalseUse variant='modal' instead.Enabled a modal drawer.

Drawer Render Props

NameTypeDefaultRequiredDescription
childrenReact.ReactNodenullfalseContent to be rendered inside the Drawer

Drawer Events

NameDefaultRequiredParamsDescription
onClosenullfalseFired when drawer is closed.
onOpennullfalseFired when drawer is opened.

Drawer Breaking Changes

Description
Drawer: Child component DrawerToolbarSpacer has been removed. See DrawerAppContent.

Drawer App Content Props

NameTypeDefaultRequiredDescription
belowTopAppBarbooleannullfalsePositions the modal lower, below the TopAppBar.
classNamestringundefinedfalseThe css class name to be passed through to the component markup.

Drawer App Content Render Props

NameTypeDefaultRequiredDescription
childrenReact.ReactNodenullfalseContent to be rendered inside the DrawerAppContent

Drawer Content Props

NameTypeDefaultRequiredDescription
classNamestringundefinedfalseThe css class name to be passed through to the component markup.

Drawer Content Render Props

NameTypeDefaultRequiredDescription
childrenReact.ReactNodenullfalseContent to be rendered inside the drawer. Most commonly a list, but accepts any valid markup.

Drawer Header Props

NameTypeDefaultRequiredDescription
classNamestringundefinedfalseThe css class name to be passed through to the component markup.
subtitlestringempty stringfalseSubtitle of Drawer Header
titlestringempty stringfalseTitle of Drawer Header

Drawer Header Render Props

NameTypeDefaultRequiredDescription
avatarReact.ReactNodenullfalseMost commonly an avatar style image, but accepts any valid markup.
childrenReact.ReactNodenullfalseMost commonly a text or a Typography component, but accepts any valid markup.

FAQs

Package last updated on 08 Feb 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts