import * as React from 'react'; import { Link, Stack, StackItem, MessageBar, MessageBarType, ChoiceGroup, IStackProps, MessageBarButton, Text, IChoiceGroupStyles, } from '@fluentui/react'; interface IExampleProps { resetChoice?: () => void; } const horizontalStackProps: IStackProps = { horizontal: true, tokens: { childrenGap: 16 }, }; const verticalStackProps: IStackProps = { styles: { root: { overflow: 'hidden', width: '100%' } }, tokens: { childrenGap: 20 }, }; const choiceGroupStyles: Partial = { label: { maxWidth: 250 } }; const DefaultExample = () => ( Info (default) MessageBar. Visit our website. ); const ErrorExample = (p: IExampleProps) => ( Error MessageBar with single line, with dismiss button. Visit our website. ); const BlockedExample = (p: IExampleProps) => ( Blocked MessageBar - single line, with dismiss button and truncated text. Truncation is not available if you use action buttons or multiline and should be used sparingly. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi luctus, purus a lobortis tristique, odio augue pharetra metus, ac placerat nunc mi nec dui. Vestibulum aliquam et nunc semper scelerisque. Curabitur vitae orci nec quam condimentum porttitor et sed lacus. Vivamus ac efficitur leo. Cras faucibus mauris libero, ac placerat erat euismod et. Donec pulvinar commodo odio sit amet faucibus. In hac habitasse platea dictumst. Duis eu ante commodo, condimentum nibh pellentesque, laoreet enim. Fusce massa lorem, ultrices eu mi a, fermentum suscipit magna. Integer porta purus pulvinar, hendrerit felis eget, condimentum mauris. ); const SevereExample = (p: IExampleProps) => ( Yes No } > SevereWarning MessageBar with action buttons which defaults to multiline. Visit our website. ); const SuccessExample = () => ( Yes No } messageBarType={MessageBarType.success} isMultiline={false} > Success MessageBar with single line and action buttons. Visit our website. ); const WarningExample = (p: IExampleProps) => ( Action } > Warning MessageBar content. Visit our website. ); const WarningExample2 = (p: IExampleProps) => ( Yes No } > Warning defaults to multiline. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi luctus, purus a lobortis tristique, odio augue pharetra metus, ac placerat nunc mi nec dui. Vestibulum aliquam et nunc semper scelerisque. Curabitur vitae orci nec quam condimentum porttitor et sed lacus. Vivamus ac efficitur leo. Cras faucibus mauris libero, ac placerat erat euismod et. Donec pulvinar commodo odio sit amet faucibus. In hac habitasse platea dictumst. Duis eu ante commodo, condimentum nibh pellentesque, laoreet enim. Fusce massa lorem, ultrices eu mi a, fermentum suscipit magna. Integer porta purus pulvinar, hendrerit felis eget, condimentum mauris. Visit our website. ); const choiceOptions = [ { key: 'all', text: 'Show all' }, { key: 'default', text: 'Info (default)' }, { key: 'error', text: 'Error' }, { key: 'blocked', text: 'Blocked' }, { key: 'severe', text: 'SevereWarning' }, { key: 'success', text: 'Success' }, { key: 'warning', text: 'Warning - single line' }, { key: 'warning2', text: 'Warning - multiline' }, ]; export const MessageBarBasicExample: React.FunctionComponent = () => { const [choice, setChoice] = React.useState(undefined); const showAll = choice === 'all'; const resetChoice = React.useCallback(() => setChoice(undefined), []); return (
Because screen readers will immediately read any MessageBar(s) on page load, the examples are hidden by default. Use the buttons below to choose an example to show.
setChoice(v!.key)} options={choiceOptions} /> {(choice === 'default' || showAll) && } {(choice === 'error' || showAll) && } {(choice === 'blocked' || showAll) && } {(choice === 'severe' || showAll) && } {(choice === 'success' || showAll) && } {(choice === 'warning' || showAll) && } {(choice === 'warning2' || showAll) && }
); };