Research
Security News
Threat Actor Exposes Playbook for Exploiting npm to Build Blockchain-Powered Botnets
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
@accessible/modal
Advanced tools
npm i @accessible/modal
An accessible and versatile modal component for React
style
objects, anything!Check out the example on CodeSandbox
import {Modal, Target, Trigger, Close} from '@accessible/modal'
const Component = () => (
<Modal>
<Target>
<div className="my-modal">
<Close>
<button>Close me</button>
</Close>
</div>
</Target>
<Trigger>
<button>Open me</button>
</Trigger>
</Modal>
)
Component | Description |
---|---|
<Modal> | This component creates the context for your modal box and trigger and contains some configuration options. |
<Target> | This component wraps any React element and turns it into a modal box. |
<Trigger> | This component wraps any React element and turns it into a modal trigger. |
<Close> | This is a convenience component that wraps any React element and adds an onClick handler to close the modal. |
Hook | Description |
---|---|
useModal() | This hook provides the value of the modal's ModalContextValue object. |
useControls() | This hook provides access to the modal's open , close , and toggle functions. |
useIsOpen() | This hook provides access to the modal's isOpen value. |
<Modal>
This component creates the context for your modal box and trigger and contains some configuration options.
Prop | Type | Default | Required? | Description |
---|---|---|---|---|
defaultOpen | boolean | false | No | This sets the default open state of the modal. By default the modal is closed. |
open | boolean | undefined | No | You can control the open/closed state of the modal with this prop. When it isn't undefined, this value will take precedence over any calls to open() , close() , or toggle() . |
onChange | (open: boolean) => void | undefined | No | This callback is invoked any time the open state of the disclosure changes. |
id | string | undefined | No | By default this component creates a unique id for you, as it is required for certain aria attributes. Supplying an id here overrides the auto id feature. |
children | React.ReactNode | React.ReactNode[] | JSX.Element | ((context: ModalContextValue) => React.ReactNode) | undefined | No | Your modal contents and any other children. |
<Target>
This component wraps any React element and turns it into a modal target.
Prop | Type | Default | Required? | Description |
---|---|---|---|---|
portal | boolean | string | false | No | When true this will render the modal into a React portal with the id #portals . You can render it into any portal by providing its query selector here, e.g. #foobar , [data-portal=true] , or .foobar . |
closeOnEscape | boolean | true | No | By default the modal will close when the Escape key is pressed. You can turn this off by providing false here. |
closedClass | string | undefined | No | This class name will be applied to the child element when the modal is closed . |
openClass | string | undefined | No | This class name will be applied to the child element when the modal is open . |
closedStyle | React.CSSProperties | undefined | No | These styles will be applied to the child element when the modal is closed in addition to the default styles that set the box's visibility. |
openStyle | React.CSSProperties | undefined | No | These styles name will be applied to the child element when the modal is open in addition to the default styles that set the box's visibility. |
preventScroll | boolean | false | No | When true this will prevent your browser from scrolling the document to bring the newly-focused tab into view. |
children | React.ReactElement | undefined | Yes | The child is cloned by this component and has aria attributes injected into its props as well as the events defined above. |
<Target>
<div className="alert">Alert</div>
</Target>
// <div
// class="alert"
// aria-hidden="true"
// aria-modal="false"
// id="modal--12"
// role="dialog"
// style="visibility: hidden; position: fixed; margin: auto; left: 0px; right: 0px; top: 50%; transform: translateY(-50%); z-index: 1;"
// >
// Alert
// </div>
<Trigger>
This component wraps any React element and adds an onClick
handler which toggles the open state
of the modal target.
Prop | Type | Default | Required? | Description |
---|---|---|---|---|
closedClass | string | undefined | No | This class name will be applied to the child element when the modal is closed . |
openClass | string | undefined | No | This class name will be applied to the child element when the modal is open . |
closedStyle | React.CSSProperties | undefined | No | These styles will be applied to the child element when the modal is closed . |
openStyle | React.CSSProperties | undefined | No | These styles name will be applied to the child element when the modal is open . |
children | React.ReactElement | undefined | Yes | The child is cloned by this component and has aria attributes injected into its props as well as the events defined above. |
<Trigger on="click">
<button className="my-button">Open me!</button>
</Trigger>
// <button
// class="my-button"
// aria-controls="modal--12"
// aria-haspopup="dialog"
// aria-expanded="false"
// >
// Open me!
// </button>
<Close>
This is a convenience component that wraps any React element and adds an onClick handler which closes the modal.
Prop | Type | Default | Required? | Description |
---|---|---|---|---|
children | React.ReactElement | undefined | Yes | The child is cloned by this component and has aria attributes injected into its props as well as the events defined above. |
<Close>
<button className="my-button">Close me</button>
</Close>
// <button
// class="my-button"
// aria-controls="modal--12"
// aria-expanded="false"
// >
// Close me
// </button>
useModal()
This hook provides the value of the modal's ModalContextValue object
const Component = () => {
const {open, close, toggle, isOpen} = useModal()
return <button onClick={toggle}>Toggle the modal</button>
}
ModalContextValue
interface ModalContextValue {
isOpen: boolean
open: () => void
close: () => void
toggle: () => void
id: string
}
useControls()
This hook provides access to the modal's open
, close
, and toggle
functions
const Component = () => {
const {open, close, toggle} = useControls()
return (
<Target>
<div className="my-modal">
<button onClick={close}>Close me</button>
</div>
</Target>
)
}
useIsOpen()
This hook provides access to the modal's isOpen
value
const Component = () => {
const isOpen = useIsOpen()
return (
<Target>
<div className="my-modal">Am I open? {isOpen ? 'Yes' : 'No'}</div>
</Target>
)
}
MIT
FAQs
🅰 An accessible and versatile modal component for React
We found that @accessible/modal demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
Security News
NVD’s backlog surpasses 20,000 CVEs as analysis slows and NIST announces new system updates to address ongoing delays.
Security News
Research
A malicious npm package disguised as a WhatsApp client is exploiting authentication flows with a remote kill switch to exfiltrate data and destroy files.