2021-02-22 17:20:42 +01:00
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
2022-12-01 16:46:06 +01:00
|
|
|
import classnames from 'classnames';
|
2021-02-22 17:20:42 +01:00
|
|
|
import Button from '../../../../components/ui/button';
|
|
|
|
|
|
|
|
export default function ConfirmationFooter({
|
2022-12-01 16:46:06 +01:00
|
|
|
onSubmit,
|
2021-02-22 17:20:42 +01:00
|
|
|
onCancel,
|
2022-12-01 16:46:06 +01:00
|
|
|
submitText,
|
2021-02-22 17:20:42 +01:00
|
|
|
cancelText,
|
2023-03-08 17:33:27 +01:00
|
|
|
loadingText,
|
2021-02-22 17:20:42 +01:00
|
|
|
alerts,
|
2023-03-08 17:33:27 +01:00
|
|
|
loading,
|
|
|
|
submitAlerts,
|
2023-06-07 15:18:49 +02:00
|
|
|
actionsStyle,
|
|
|
|
style,
|
2021-02-22 17:20:42 +01:00
|
|
|
}) {
|
|
|
|
return (
|
2023-06-07 15:18:49 +02:00
|
|
|
<div className="confirmation-footer" style={style}>
|
2021-02-22 17:20:42 +01:00
|
|
|
{alerts}
|
2023-03-08 17:33:27 +01:00
|
|
|
{submitAlerts}
|
2023-06-07 15:18:49 +02:00
|
|
|
<div className="confirmation-footer__actions" style={actionsStyle}>
|
2022-12-01 16:46:06 +01:00
|
|
|
{onCancel ? (
|
|
|
|
<Button type="secondary" onClick={onCancel}>
|
|
|
|
{cancelText}
|
|
|
|
</Button>
|
|
|
|
) : null}
|
|
|
|
<Button
|
2023-03-08 17:33:27 +01:00
|
|
|
disabled={Boolean(loading)}
|
2022-12-01 16:46:06 +01:00
|
|
|
type="primary"
|
|
|
|
onClick={onSubmit}
|
|
|
|
className={classnames({
|
|
|
|
centered: !onCancel,
|
|
|
|
})}
|
|
|
|
>
|
2023-03-08 17:33:27 +01:00
|
|
|
{loading ? loadingText : submitText}
|
2021-02-22 17:20:42 +01:00
|
|
|
</Button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
ConfirmationFooter.propTypes = {
|
|
|
|
alerts: PropTypes.node,
|
2022-12-01 16:46:06 +01:00
|
|
|
onCancel: PropTypes.func,
|
|
|
|
cancelText: PropTypes.string,
|
|
|
|
onSubmit: PropTypes.func.isRequired,
|
|
|
|
submitText: PropTypes.string.isRequired,
|
2023-03-08 17:33:27 +01:00
|
|
|
loadingText: PropTypes.string,
|
|
|
|
loading: PropTypes.bool,
|
|
|
|
submitAlerts: PropTypes.node,
|
2023-06-07 15:18:49 +02:00
|
|
|
style: PropTypes.object,
|
|
|
|
actionsStyle: PropTypes.object,
|
2021-02-22 17:20:42 +01:00
|
|
|
};
|