diff --git a/public/App.jsx b/public/App.jsx
index 789d5a1..9bd9bd4 100644
--- a/public/App.jsx
+++ b/public/App.jsx
@@ -49,9 +49,14 @@ class App extends React.Component {
let clazz = "c-app";
if(this.props.menuOpen) clazz += " is-menu-open ";
+ let modal;
+ if(this.props.modal.open) clazz += " is-modal-open";
+ if(this.props.modal.modal) modal = this.props.modal.modal;
+
let children = (
+ { modal }
);
@@ -66,7 +71,8 @@ class App extends React.Component {
const mapStateToProps = function(state) {
return {
- menuOpen: state.menu.open
+ menuOpen: state.menu.open,
+ modal: state.modal
}
}
diff --git a/public/actions/ModalActions.js b/public/actions/ModalActions.js
new file mode 100644
index 0000000..dd98911
--- /dev/null
+++ b/public/actions/ModalActions.js
@@ -0,0 +1,38 @@
+// Copyright (c) 2018 Dominic Masters
+//
+// MIT License
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+//
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+export const OPEN_MODAL = "OPEN_MODAL";
+export const CLOSE_MODAL = "CLOSE_MODAL";
+
+export function openModal(modal) {
+ return {
+ type: OPEN_MODAL,
+ modal
+ };
+}
+
+export function closeModal() {
+ return {
+ type: CLOSE_MODAL
+ }
+}
diff --git a/public/modal/Modal.jsx b/public/modal/Modal.jsx
new file mode 100644
index 0000000..0049af5
--- /dev/null
+++ b/public/modal/Modal.jsx
@@ -0,0 +1,66 @@
+// Copyright (c) 2018 Dominic Masters
+//
+// MIT License
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+//
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+import React from 'react';
+import { Button } from './../input/Input';
+
+class Modal extends React.Component {
+ constructor(props) {
+ super(props);
+ }
+
+ render() {
+ let junk = [];
+ for(let x = 0; x < 1000; x++) {
+ junk.push(