summaryrefslogtreecommitdiff
path: root/src/components/modals
diff options
context:
space:
mode:
authorGeorgios Andreadis <g.andreadis@student.tudelft.nl>2017-08-09 14:29:14 +0300
committerGeorgios Andreadis <g.andreadis@student.tudelft.nl>2017-09-23 10:05:18 +0200
commit67a771cbb02ec9da3c60704901f3150b46a7262b (patch)
treef5e8e28cc0b7539196e7cdc2f4f4e7cc2c165fbd /src/components/modals
parentd1194f0706789287b98996b629451042f62bf6eb (diff)
Create basic projects page with add-button
Diffstat (limited to 'src/components/modals')
-rw-r--r--src/components/modals/Modal.js82
-rw-r--r--src/components/modals/TextInputModal.js41
2 files changed, 123 insertions, 0 deletions
diff --git a/src/components/modals/Modal.js b/src/components/modals/Modal.js
new file mode 100644
index 00000000..e2d19fcb
--- /dev/null
+++ b/src/components/modals/Modal.js
@@ -0,0 +1,82 @@
+import PropTypes from "prop-types";
+import React from "react";
+
+class Modal extends React.Component {
+ static propTypes = {
+ title: PropTypes.string.isRequired,
+ show: PropTypes.bool.isRequired,
+ onSubmit: PropTypes.func.isRequired,
+ onCancel: PropTypes.func.isRequired,
+ };
+ static idCounter = 0;
+
+ constructor() {
+ super();
+ this.id = "modal-" + Modal.idCounter;
+ }
+
+ componentDidMount() {
+ this.openOrCloseModal();
+ }
+
+ componentDidUpdate() {
+ this.openOrCloseModal();
+ }
+
+ onSubmit() {
+ this.props.onSubmit();
+ this.closeModal();
+ }
+
+ onCancel() {
+ this.props.onCancel();
+ this.closeModal();
+ }
+
+ openModal() {
+ window["$"]("#" + this.id).modal("show");
+ }
+
+ closeModal() {
+ window["$"]("#" + this.id).modal("hide");
+ }
+
+ openOrCloseModal() {
+ if (this.props.show) {
+ this.openModal();
+ } else {
+ this.closeModal();
+ }
+ }
+
+ render() {
+ return (
+ <div className="modal" id={this.id} role="dialog">
+ <div className="modal-dialog" role="document">
+ <div className="modal-content">
+ <div className="modal-header">
+ <h5 className="modal-title">{this.props.title}</h5>
+ <button type="button" className="close" onClick={this.onCancel.bind(this)}
+ aria-label="Close">
+ <span aria-hidden="true">&times;</span>
+ </button>
+ </div>
+ <div className="modal-body">
+ {this.props.children}
+ </div>
+ <div className="modal-footer">
+ <button type="button" className="btn btn-secondary" onClick={this.onCancel.bind(this)}>
+ Close
+ </button>
+ <button type="button" className="btn btn-primary" onClick={this.onSubmit.bind(this)}>
+ Save
+ </button>
+ </div>
+ </div>
+ </div>
+ </div>
+ );
+ }
+}
+
+export default Modal;
diff --git a/src/components/modals/TextInputModal.js b/src/components/modals/TextInputModal.js
new file mode 100644
index 00000000..4acf25b3
--- /dev/null
+++ b/src/components/modals/TextInputModal.js
@@ -0,0 +1,41 @@
+import PropTypes from "prop-types";
+import React from "react";
+import Modal from "./Modal";
+
+class TextInputModal extends React.Component {
+ static propTypes = {
+ title: PropTypes.string.isRequired,
+ label: PropTypes.string.isRequired,
+ show: PropTypes.bool.isRequired,
+ callback: PropTypes.func.isRequired,
+ initialValue: PropTypes.string,
+ };
+
+ onSubmit() {
+ this.props.callback(this.refs.textInput.value);
+ this.refs.textInput.value = "";
+ }
+
+ onCancel() {
+ this.props.callback(undefined);
+ this.refs.textInput.value = "";
+ }
+
+ render() {
+ return (
+ <Modal title={this.props.title}
+ show={this.props.show}
+ onSubmit={this.onSubmit.bind(this)}
+ onCancel={this.onCancel.bind(this)}>
+ <form>
+ <div className="form-group">
+ <label className="form-control-label">{this.props.label}:</label>
+ <input type="text" className="form-control" ref="textInput" value={this.props.initialValue}/>
+ </div>
+ </form>
+ </Modal>
+ );
+ }
+}
+
+export default TextInputModal;