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 // @flow
import * as React from "react"; import * as React from "react";
import ReactDOM from "react-dom"; import ReactDOM from "react-dom";
import Modal from "./Modal";
type ButtonType = { type ButtonType = {
label: string, label: string,
@@ -28,22 +29,15 @@ class ConfirmAlert extends React.Component<Props> {
render() { render() {
const { title, message, buttons } = this.props; const { title, message, buttons } = this.props;
return ( const closeButton = (
<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 <button
className="delete" className="delete"
aria-label="close" aria-label="close"
onClick={() => this.close()} onClick={() => this.close()}
/> />
</header> );
<section className="modal-card-body"> const body= (
<>
{message} {message}
<div className="buttons is-right"> <div className="buttons is-right">
{buttons.map((button, i) => ( {buttons.map((button, i) => (
@@ -55,10 +49,12 @@ class ConfirmAlert extends React.Component<Props> {
</a> </a>
))} ))}
</div> </div>
</section> </>
);
</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 // @create-index
export { default as ConfirmAlert, confirmAlert } from "./ConfirmAlert.js"; export { default as ConfirmAlert, confirmAlert } from "./ConfirmAlert.js";
export { default as Modal } from "./Modal.js";