ref(dialog) Use new button component (#11922)
This commit is contained in:
parent
5ec6581d2e
commit
abc752635d
|
@ -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>
|
||||||
);
|
);
|
||||||
|
|
|
@ -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>
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue