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,37 +29,32 @@ 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"> <button
<div className="modal-background" /> className="delete"
<div className="modal-card"> aria-label="close"
onClick={() => this.close()}
<header className="modal-card-head"> />
<p className="modal-card-title"> );
{title} const body= (
</p> <>
<button {message}
className="delete" <div className="buttons is-right">
aria-label="close" {buttons.map((button, i) => (
onClick={() => this.close()} <a className="button is-info is-right"
/> key={i}
</header> onClick={() => this.handleClickButton(button)}
<section className="modal-card-body"> >
{message} {button.label}
<div className="buttons is-right"> </a>
{buttons.map((button, i) => ( ))}
<a className="button is-info is-right"
key={i}
onClick={() => this.handleClickButton(button)}
>
{button.label}
</a>
))}
</div>
</section>
</div> </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";