create modal component

This commit is contained in:
Maren Süwer
2019-02-01 10:02:19 +01:00
parent 87ffe37cd6
commit 782cdb996f
3 changed files with 71 additions and 30 deletions

View File

@@ -1,6 +1,7 @@
// @flow
import * as React from "react";
import ReactDOM from "react-dom";
import Modal from "./Modal";
type ButtonType = {
label: string,
@@ -28,37 +29,32 @@ class ConfirmAlert extends React.Component<Props> {
render() {
const { title, message, buttons } = this.props;
return (
<div className="modal is-active">
<div className="modal-background" />
<div className="modal-card">
<header className="modal-card-head">
<p className="modal-card-title">
{title}
</p>
<button
className="delete"
aria-label="close"
onClick={() => this.close()}
/>
</header>
<section className="modal-card-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>
</section>
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>
</div>
</>
);
return (
<Modal title={title} closeButton={closeButton} body={body} active={true}/>
);
}
}

View File

@@ -0,0 +1,44 @@
// @flow
import * as React from "react";
import classNames from "classnames";
type Props = {
title: string,
closeButton: any,
body: any,
active: boolean
};
class Modal extends React.Component<Props> {
render() {
const { title, closeButton, body, active } = this.props;
const isActive = active ? "is-active" : null;
return (
<div className={classNames(
"modal",
isActive
)}>
<div className="modal-background" />
<div className="modal-card">
<header className="modal-card-head">
<p className="modal-card-title">
{title}
</p>
{closeButton}
</header>
<section className="modal-card-body">
{body}
</section>
</div>
</div>
);
}
}
export default Modal;

View File

@@ -1,4 +1,5 @@
// @create-index
export { default as ConfirmAlert, confirmAlert } from "./ConfirmAlert.js";
export { default as Modal } from "./Modal.js";