From 07ba3bd6717bde98c33c63e89f4b490d6fd45b7d Mon Sep 17 00:00:00 2001 From: Dominic Masters Date: Fri, 6 Jul 2018 12:45:23 +1000 Subject: [PATCH] Added transition to modal --- public/modal/Modal.jsx | 72 +++++++++++++++++++++++++------ public/styles/objects/_modal.scss | 66 +++++++++++++++++++++++----- 2 files changed, 114 insertions(+), 24 deletions(-) diff --git a/public/modal/Modal.jsx b/public/modal/Modal.jsx index 0049af5..549a43a 100644 --- a/public/modal/Modal.jsx +++ b/public/modal/Modal.jsx @@ -22,7 +22,11 @@ // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. import React from 'react'; +import { connect } from 'react-redux'; +import { bindActionCreators } from 'redux'; +import { CSSTransition, TransitionGroup } from 'react-transition-group'; import { Button } from './../input/Input'; +import { openModal, closeModal } from './../actions/ModalActions'; class Modal extends React.Component { constructor(props) { @@ -35,32 +39,72 @@ class Modal extends React.Component { junk.push(
Hello World
); } + //Add necessary buttons let buttons; - if(this.props.buttons || true) { - buttons = ( -
- -
- ); - } + if(this.props.buttons) buttons = this.props.button; - return ( + //Create our modal contents + let contents = (
-
+
+
-
-
- { junk } +
+
+
+ { junk } +
+
+ +
+ { buttons }
- { buttons }
); + + //Display? + let displayedContents =
; + + if(this.props.modal.open) { + displayedContents = ( + + { contents } + + ); + } + + //Wrap entire contents of modal in transitional container. + return ( + + { displayedContents } + + ); } } -module.exports = Modal; +const mapStateToProps = (state) => { + return { + modal: state.modal + }; +} + +const mapDispatchToProps = (dispatch) => { + return bindActionCreators({ + openModal: openModal, + closeModal: closeModal + },dispatch); +} + +export default connect(mapStateToProps, mapDispatchToProps)(Modal); diff --git a/public/styles/objects/_modal.scss b/public/styles/objects/_modal.scss index 66c3e7a..915d7b1 100644 --- a/public/styles/objects/_modal.scss +++ b/public/styles/objects/_modal.scss @@ -14,6 +14,8 @@ $o-modal--backdrop: rgba(0, 0, 0, 0.7); $o-modal--background: white; $o-modal--padding: 0.5em; +$o-modal--transition: 0.2s $s-animation--ease-out; + .o-modal { position: fixed; top: 0; @@ -35,26 +37,41 @@ $o-modal--padding: 0.5em; width: 100%; height: 100%; background: $o-modal--backdrop; + + //Transition Properties + transition: opacity #{$o-modal--transition}; + opacity: 0; } &__box { @include t-absolute-center-x-y(); - @extend %t-dp--shadow; - @extend %t-flexbox; - @include t-flex-wrap(wrap); - @include t-flex-direction(column); - @include t-align-items(flex-start); - @include t-align-content(flex-start); - background: $o-modal--background; width: 100%; height: 100%; max-width: 95%; max-height: 95%; - &-body { - width: 100%; - @include t-flex-grow(1); + &-inner { position: relative; + @extend %t-flexbox; + @include t-flex-wrap(wrap); + @include t-flex-direction(column); + @include t-align-items(flex-start); + @include t-align-content(flex-start); + @extend %t-dp--shadow; + width: 100%; + height: 100%; + background: $o-modal--background; + + //Transition properties + transition: all #{$o-modal--transition}; + @include t-scale(0.4); + opacity: 0; + } + + &-body { + position: relative; + @include t-flex-grow(1); + width: 100%; /* Unfortunately flex can only get us half way there */ &-inner {//Hacks our content so it will never overflow its container. @@ -80,4 +97,33 @@ $o-modal--padding: 0.5em; height: 600px; } } + + //Transition related + &__transition { + &-container {}//Top level container + + //Entry animation + &-enter { + &-active {} + &-done {} + + &-active,&-done { + .o-modal__backdrop { + opacity: 1; + } + + .o-modal__box-inner { + @include t-scale(1); + opacity: 1; + } + } + } + + //Exit animation + &-exit { + &-active {} + &-done { + } + } + } }