Files
SCM-Manager/scm-ui-components/packages/ui-components/src/modals/ConfirmAlert.js
2019-02-01 10:02:19 +01:00

70 lines
1.4 KiB
JavaScript

// @flow
import * as React from "react";
import ReactDOM from "react-dom";
import Modal from "./Modal";
type ButtonType = {
label: string,
onClick: () => void | null
};
type Props = {
title: string,
message: string,
buttons: ButtonType[]
};
class ConfirmAlert extends React.Component<Props> {
handleClickButton = (button: ButtonType) => {
if (button.onClick) {
button.onClick();
}
this.close();
};
close = () => {
ReactDOM.unmountComponentAtNode(document.getElementById("modalRoot"));
};
render() {
const { title, message, buttons } = this.props;
const closeButton = (
<button
className="delete"
aria-label="close"
onClick={() => this.close()}
/>
);
const body= (
<>
{message}
<div className="buttons is-right">
{buttons.map((button, i) => (
<a className="button is-info is-right"
key={i}
onClick={() => this.handleClickButton(button)}
>
{button.label}
</a>
))}
</div>
</>
);
return (
<Modal title={title} closeButton={closeButton} body={body} active={true}/>
);
}
}
export function confirmAlert(properties: Props) {
const root = document.getElementById("modalRoot");
if(root){
ReactDOM.render(<ConfirmAlert {...properties}/>, root);
}
}
export default ConfirmAlert;