Table of contents
information
Demos for variant Basic Dialog
<Dialog title="What is a Dialog?"><P>The Dialog component is a Modal variation that appears at the center ofthe screen. The Dialog has similar functionality to a traditional popupwindow and is mostly used for informational purposes (for exampleexplaining a word on the page). Similar to Modal, it has to betriggered by the user to appear. Typical usage would be to read anexplanation, then closing it.</P><Button variant="secondary" size="large" top="large">Read more</Button></Dialog>
Dialog as help button
<Inputlabel="Input"placeholder="Placeholder ..."suffix={<Dialog><P>Some additional information for the input field.</P></Dialog>}/>
Dialog with custom trigger
<Dialogtitle="Modal Title"trigger={(props) => (<Button {...props} variant="primary" icon="information">Custom trigger button</Button>)}><P>This Modal was opened by a custom trigger component.</P></Dialog>
Dialog with custom content
const handleBack = () => nullrender(<><Dialog title="Custom title"><Dialog.Navigation><Breadcrumb onClick={handleBack} /></Dialog.Navigation><Dialog.Header><P bottom>This is in the Dialog header</P></Dialog.Header><Button bottom size="large" right top>Read more</Button><Button bottom size="large" variant="secondary">Open example</Button><FormStatus state="info">This is a formstatus in a Dialog</FormStatus></Dialog></>,)
Fullscreen Dialog
<Dialogtitle={<span className="dnb-sr-only">"Hidden" Dialog title</span>}fullscreentriggerAttributes={{variant: 'tertiary',text: 'Open a fullscreen dialog',icon: 'bell',}}modalContent="The Dialog component is a Modal variation that appears at the center of the screen. The Dialog has similar functionality to a traditional popup window and is mostly used for informational purposes."/>
Dialog as progress indicator
<Dialogspacing={false}fullscreen={false}alignContent="centered"hideCloseButtontriggerAttributes={{text: 'Show',}}preventClose={false}maxWidth="12rem"><ProgressIndicatorshow_labellabel_direction="vertical"top="large"bottom="large"/></Dialog>
Dialog with close delay
<Dialogtitle=".5s close delay"triggerAttributes={{text: 'Click me',}}focusSelector=".dnb-input__input:first-of-type"preventClosehideCloseButtononOpen={(e) => console.log('on_open', e)}onClose={(e) => console.log('on_close', e)}onClosePrevent={({ close, triggeredBy }) => {console.log('triggeredBy', triggeredBy)const timeout = setTimeout(close, 500)return () => clearTimeout(timeout) // clear timeout on unmount}}><P>This is a Dialog with no close button.</P><P>Click outside me, and I will be closed within 1 second.</P><Input label="Focus:" top>Focus me with Tab key</Input></Dialog>
confirmation
Demos for variant Confirm dialog
<Dialogvariant="confirmation"title="Dialog confirmation title"icon={bell_medium}description="Some content describing the situation."onConfirm={({ close }) => close()}triggerAttributes={{text: 'Trigger button',}}/>
Deletion Dialog
A confirmType="warning"
will enhance the context by applying a red color to the icon, as in the deletion scenario.
<Dialogvariant="confirmation"confirmType="warning"title="Are you sure you want to delete this?"icon={trash_medium}description="This action cannot be undone."confirmText="Delete"declineText="Cancel"onConfirm={({ close }) => close()}triggerAttributes={{text: 'Delete record',icon: trash_medium,}}/>
Logged out Dialog
Use the openState
prop to automatically trigger the Dialog, here demonstrated with a button for simplicity. You can also change the default confirm text and hide the decline button when suited.
const DemoComponent = () => {const [open, setOpen] = React.useState(false)const loginHandler = () => nullreturn (<><Buttonid="custom-triggerer"text="Manually trigger"on_click={() => setOpen(true)}/><Dialogvariant="confirmation"title="Du har blitt logget ut"icon={log_out_medium}description="For å fortsette må du logge inn igjen."confirmText="Logg inn"hideDeclineopenState={open}onClose={() => {setOpen(false)}}onConfirm={() => {setOpen(false)loginHandler()}}labelledBy="custom-triggerer"/></>)}render(<DemoComponent />)
Cookie concent Dialog
Provide a custom set of buttons, like this cookie concent Dialog that has a tertiary
"Administrate" button. Notice that the close
function will be provided for every child of type Button given to Dialog.Action
.
<DialogtriggerAttributes={{text: 'Show cookie dialog',}}icon={cookie_medium}variant="confirmation"title="Informasjonskapsler (cookies)">Vi bruker cookies for å gi deg den beste opplevelsen i nettbanken vår.<br /><Anchor target="_blank" href="https://www.dnb.no/cookies">Les mer om cookies</Anchor><Dialog.Action><Buttonvariant="tertiary"text="Administrer"icon={edit}icon_position="left"on_click={({ close }) => {close()}}/><Buttontext="Jeg godtar"on_click={({ close }) => {close()}}/></Dialog.Action></Dialog>