import * as React from 'react'; import { useId, useBoolean } from '@fluentui/react-hooks'; import { Modal, getTheme, mergeStyleSets, FontWeights, IDragOptions, Toggle, ContextualMenu, IIconProps, } from '@fluentui/react'; import { DefaultButton, IconButton } from '@fluentui/react/lib/Button'; const dragOptions: IDragOptions = { moveMenuItemText: 'Move', closeMenuItemText: 'Close', menu: ContextualMenu, }; const cancelIcon: IIconProps = { iconName: 'Cancel' }; export const ModalModelessExample: React.FunctionComponent = () => { const [isModalOpen, { setTrue: showModal, setFalse: hideModal }] = useBoolean(false); const [isDraggable, { toggle: toggleIsDraggable }] = useBoolean(false); // Use useId() to ensure that the IDs are unique on the page. // (It's also okay to use plain strings and manually ensure uniqueness.) const titleId = useId('title'); return (
Lorem Ipsum

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas lorem nulla, malesuada ut sagittis sit amet, vulputate in leo. Maecenas vulputate congue sapien eu tincidunt. Etiam eu sem turpis. Fusce tempor sagittis nunc, ut interdum ipsum vestibulum non. Proin dolor elit, aliquam eget tincidunt non, vestibulum ut turpis. In hac habitasse platea dictumst. In a odio eget enim porttitor maximus. Aliquam nulla nibh, ullamcorper aliquam placerat eu, viverra et dui. Phasellus ex lectus, maximus in mollis ac, luctus vel eros. Vivamus ultrices, turpis sed malesuada gravida, eros ipsum venenatis elit, et volutpat eros dui et ante. Quisque ultricies mi nec leo ultricies mollis. Vivamus egestas volutpat lacinia. Quisque pharetra eleifend efficitur.{' '}

); }; const theme = getTheme(); const contentStyles = mergeStyleSets({ container: { display: 'flex', flexFlow: 'column nowrap', alignItems: 'stretch', }, header: [ // eslint-disable-next-line deprecation/deprecation theme.fonts.xLargePlus, { flex: '1 1 auto', borderTop: `4px solid ${theme.palette.themePrimary}`, color: theme.palette.neutralPrimary, display: 'flex', alignItems: 'center', fontWeight: FontWeights.semibold, padding: '12px 12px 14px 24px', }, ], body: { flex: '4 4 auto', padding: '0 24px 24px 24px', overflowY: 'hidden', selectors: { p: { margin: '14px 0' }, 'p:first-child': { marginTop: 0 }, 'p:last-child': { marginBottom: 0 }, }, }, }); const toggleStyles = { root: { marginBottom: '20px' } }; const iconButtonStyles = { root: { color: theme.palette.neutralPrimary, marginLeft: 'auto', marginTop: '4px', marginRight: '2px', }, rootHovered: { color: theme.palette.neutralDark, }, };