ref(dialog) Use new button component (#11922)

This commit is contained in:
Robert Pintilii 2022-07-28 16:09:38 +03:00 committed by GitHub
parent 5ec6581d2e
commit abc752635d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 32 additions and 32 deletions

View File

@ -12,8 +12,10 @@ import { withStyles } from '@material-ui/core/styles';
import React from 'react'; import React from 'react';
import { translate } from '../../../i18n'; import { translate } from '../../../i18n';
import { Icon, IconClose } from '../../../icons'; import { IconClose } from '../../../icons/svg/index';
import { withPixelLineHeight } from '../../../styles/functions'; import { withPixelLineHeight } from '../../../styles/functions';
import Button from '../../../ui/components/web/Button';
import { BUTTON_TYPES } from '../../../ui/constants';
const TitleIcon = ({ appearance }: { appearance?: 'danger' | 'warning' }) => { const TitleIcon = ({ appearance }: { appearance?: 'danger' | 'warning' }) => {
if (!appearance) { if (!appearance) {
@ -155,18 +157,13 @@ class ModalHeader extends React.Component<Props> {
</Title> </Title>
{ {
!hideCloseIconButton !hideCloseIconButton && <Button
&& <div accessibilityLabel = { t('dialog.close') }
className = { classes.closeButton } icon = { IconClose }
id = 'modal-header-close-button' id = 'modal-header-close-button'
onClick = { onClose }> onClick = { onClose }
<Icon size = 'large'
ariaLabel = { t('dialog.close') } type = { BUTTON_TYPES.TERTIARY } />
onKeyPress = { this._onKeyPress }
role = 'button'
src = { IconClose }
tabIndex = { 0 } />
</div>
} }
</Header> </Header>
); );

View File

@ -1,13 +1,13 @@
// @flow // @flow
import ButtonGroup from '@atlaskit/button/button-group';
import Button from '@atlaskit/button/standard-button';
import Modal, { ModalFooter } from '@atlaskit/modal-dialog'; import Modal, { ModalFooter } from '@atlaskit/modal-dialog';
import { withStyles } from '@material-ui/core/styles'; import { withStyles } from '@material-ui/core/styles';
import _ from 'lodash'; import _ from 'lodash';
import React, { Component } from 'react'; import React, { Component } from 'react';
import { translate } from '../../../i18n/functions'; import { translate } from '../../../i18n/functions';
import Button from '../../../ui/components/web/Button';
import { BUTTON_TYPES } from '../../../ui/constants';
import type { DialogProps } from '../../constants'; import type { DialogProps } from '../../constants';
import ModalHeader from './ModalHeader'; import ModalHeader from './ModalHeader';
@ -112,12 +112,21 @@ type Props = DialogProps & {
/** /**
* Creates the styles for the component. * Creates the styles for the component.
* *
* @param {Object} theme - The theme.
* @returns {Object} * @returns {Object}
*/ */
const styles = () => { const styles = theme => {
return { return {
footer: { footer: {
boxShadow: 'none' boxShadow: 'none'
},
buttonContainer: {
display: 'flex',
'& > button:first-child': {
marginRight: `${theme.spacing(2)}px`
}
} }
}; };
}; };
@ -217,8 +226,8 @@ class StatelessDialog extends Component<Props> {
// Filter out falsy (null) values because {@code ButtonGroup} will error // Filter out falsy (null) values because {@code ButtonGroup} will error
// if passed in anything but buttons with valid type props. // if passed in anything but buttons with valid type props.
const buttons = [ const buttons = [
this._renderOKButton(), this._renderCancelButton(),
this._renderCancelButton() this._renderOKButton()
].filter(Boolean); ].filter(Boolean);
if (this.props.disableFooter) { if (this.props.disableFooter) {
@ -236,9 +245,9 @@ class StatelessDialog extends Component<Props> {
*/ */
} }
<span /> <span />
<ButtonGroup> <div className = { this.props.classes.buttonContainer }>
{ buttons } { buttons }
</ButtonGroup> </div>
</ModalFooter> </ModalFooter>
); );
} }
@ -307,13 +316,11 @@ class StatelessDialog extends Component<Props> {
return ( return (
<Button <Button
appearance = 'subtle'
id = { CANCEL_BUTTON_ID } id = { CANCEL_BUTTON_ID }
key = 'cancel' label = { t(this.props.cancelKey || 'dialog.Cancel') }
onClick = { onDecline || this._onCancel } onClick = { onDecline || this._onCancel }
type = 'button'> size = 'small'
{ t(this.props.cancelKey || 'dialog.Cancel') } type = { BUTTON_TYPES.TERTIARY } />
</Button>
); );
} }
@ -334,15 +341,11 @@ class StatelessDialog extends Component<Props> {
return ( return (
<Button <Button
appearance = 'primary' disabled = { this.props.okDisabled }
form = 'modal-dialog-form'
id = { OK_BUTTON_ID } id = { OK_BUTTON_ID }
isDisabled = { this.props.okDisabled } label = { t(this.props.okKey || 'dialog.Ok') }
key = 'submit'
onClick = { this._onSubmit } onClick = { this._onSubmit }
type = 'button'> size = 'small' />
{ t(this.props.okKey || 'dialog.Ok') }
</Button>
); );
} }