Как отцентрировать кнопку в компоненте Fluent UI Dialog?
Компонент диалога в пользовательском интерфейсе Fluent имеет DialogFooter. Я хочу разместить кнопку внутри этого нижнего колонтитула, и я хочу, чтобы она была в центре. Как этого достичь? Я не могу переместить его из места по умолчанию.
Пример кода (взят из [официальных документов][https://developer.microsoft.com/en-us/fluentui#/controls/web/dialog#IDialogStyles], с небольшими изменениями). Самая важная часть должна быть внизу кода:
import * as React from 'react';
import { Dialog, DialogFooter } from 'office-ui-fabric-react/lib/Dialog';
import { DefaultButton, PrimaryButton } from 'office-ui-fabric-react/lib/Button';
import { ChoiceGroup } from 'office-ui-fabric-react/lib/ChoiceGroup';
import { useBoolean } from '@uifabric/react-hooks';
const modelProps = {
isBlocking: true,
topOffsetFixed: true,
};
const options = [
{
key: 'A',
iconProps: { iconName: 'CalendarDay' },
text: 'Day',
},
{
key: 'B',
iconProps: { iconName: 'CalendarWeek' },
text: 'Week',
},
{
key: 'C',
iconProps: { iconName: 'Calendar' },
text: 'Month',
},
];
export const DialogTopOffsetFixedExample: React.FunctionComponent = () => {
const [hideDialog, { toggle: toggleHideDialog }] = useBoolean(true);
const [optionSelected, setOptionSelected] = React.useState('A');
const onChange = (ev: React.FormEvent<HTMLInputElement>, option: any): void => {
setOptionSelected(option.key);
};
return (
<>
<DefaultButton secondaryText="Opens the Sample Dialog" onClick={toggleHideDialog} text="Open Dialog" />
<Dialog hidden={hideDialog} onDismiss={toggleHideDialog} modalProps={modelProps}>
<ChoiceGroup
label="Pick one icon"
options={options}
// eslint-disable-next-line react/jsx-no-bind
onChange={onChange}
required
/>
{optionSelected === 'A' && (
<div>
<h1>Description</h1>
<div>
{' '}
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex
ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu
fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt
mollit anim id est laborum.{' '}
</div>
</div>
)}
{optionSelected === 'B' && (
<div>
<h1>Description</h1>
<div>
{' '}
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex
ea commodo consequat.{' '}
</div>
</div>
)}
{optionSelected === 'C' && (
<div>
<h1>Description</h1>
</div>
)}
<DialogFooter>
<PrimaryButton onClick={toggleHideDialog} text="Save" />
</DialogFooter>
</Dialog>
</>
);
};
Это выглядит так:
Как можно переместить кнопку в центр, где я рисую синий «кружок»?
1 ответ
Решение
Вы можете поместить гибкий контейнер в свой
DialogFooter
и начните центрировать кнопки внутри.
Вот пример:
<DialogFooter>
<div style={{display: "flex", justifyContent: "center"}}>
<PrimaryButton onClick={toggleHideDialog} text="Save" />
</div>
</DialogFooter>