diff --git a/client/less/drawers.less b/client/less/drawers.less new file mode 100644 index 0000000000..7a1cf51c05 --- /dev/null +++ b/client/less/drawers.less @@ -0,0 +1,108 @@ +/* + * based off of https://github.com/gitterHQ/sidecar + * license: MIT + */ +.drawer { + width:500px; + + z-index: 20000; + position: fixed; + top: 0; + bottom: 0; + right: 0; + + display: -webkit-flex; + display: flex; + -webkit-flex-direction: row; + flex-direction: row; + background-color: @body-bg; + border-left: 1px solid #ddd; + box-shadow: -12px 0 18px 0 rgba(50, 50, 50, 0.1); + + transition: transform 0.3s cubic-bezier(0.16, 0.22, 0.22, 1.7); + + &.is-collapsed:not(.is-loading) { + -webkit-transform: translateX(110%); + transform: translateX(110%); + } + + /* Add some "extension" so that there isn't a gap + * when we translate(via animation) more than 100% */ + &:after { + content: ''; + + z-index: -1; + position: absolute; + top: 0; + left: 100%; + bottom: 0; + right: -100%; + + background-color: @body-bg; + } + iframe { + width: 100%; + height: 100%; + } +} + +.drawer-action-bar { + position: absolute; + top: 0; + right: 0; + + display: -webkit-flex; + display: flex; + justify-content: flex-end; + + padding-bottom: 5px; + padding-right:10px; + padding-top:5px; + z-index: 100; +} + +.drawer-action-item { + display: -webkit-flex; + display: flex; + /* main axis */ + justify-content: center; + /* cross axis */ + align-items: center; + + width: 40px; + height: 40px; + + padding-left: 0; + padding-right: 0; + + opacity: 0.65; + background: none; + background-position: center center; + background-repeat: no-repeat; + background-size: 22px 22px; + border: 0; + outline: none; + + cursor: pointer; + cursor: hand; + + transition: all 0.2s ease; + + &:hover, + &:focus { + opacity: 1; + } + + &:active { + filter: hue-rotate(80deg) saturate(150); + } +} + +.drawer-action-pop-out { + margin-right: -4px; + background-image: url() +} + +.drawer-action-collapse { + background-image: url() +} diff --git a/client/less/main.less b/client/less/main.less index 49ee08fe87..aefcae1a09 100644 --- a/client/less/main.less +++ b/client/less/main.less @@ -1,4 +1,4 @@ - @import "lib/bootstrap/bootstrap"; +@import "lib/bootstrap/bootstrap"; @import "lib/bootstrap-social/bootstrap-social"; @import "lib/ionicons/ionicons"; @import "lib/animate.min.less"; @@ -1171,7 +1171,4 @@ and (max-width : 400px) { @import "challenge.less"; @import "toastr.less"; @import "map.less"; - -ul > li { - list-style-type: disc; -} +@import "drawers.less"; diff --git a/client/less/map.less b/client/less/map.less index beddce7d86..b16fcda7ce 100644 --- a/client/less/map.less +++ b/client/less/map.less @@ -63,7 +63,7 @@ } .map-fixed-header { - position: fixed; + position: absolute; background: white; padding-top: 5px; width: 100%; @@ -158,7 +158,6 @@ } .map-wrapper { - position: absolute; display: block; height: 100%; width: 100%; diff --git a/common/app/App.jsx b/common/app/App.jsx index 0b16145fbb..ab67446dd3 100644 --- a/common/app/App.jsx +++ b/common/app/App.jsx @@ -6,10 +6,12 @@ import { connect } from 'react-redux'; import { contain } from 'redux-epic'; import { createSelector } from 'reselect'; +import MapDrawer from './components/Map-Drawer.jsx'; import { fetchUser, initWindowHeight, - updateNavHeight + updateNavHeight, + toggleMapDrawer } from './redux/actions'; import { submitChallenge } from './routes/challenges/redux/actions'; @@ -24,18 +26,24 @@ const mapStateToProps = createSelector( state => state.app.points, state => state.app.picture, state => state.app.toast, + state => state.app.isMapDrawerOpen, + state => state.app.isMapAlreadyLoaded, state => state.challengesApp.toast, ( username, points, picture, toast, + isMapDrawerOpen, + isMapAlreadyLoaded, showChallengeComplete ) => ({ username, points, picture, toast, + isMapDrawerOpen, + isMapAlreadyLoaded, showChallengeComplete }) ); @@ -44,7 +52,8 @@ const bindableActions = { initWindowHeight, updateNavHeight, fetchUser, - submitChallenge + submitChallenge, + toggleMapDrawer }; const fetchContainerOptions = { @@ -67,7 +76,10 @@ export class FreeCodeCamp extends React.Component { updateNavHeight: PropTypes.func, initWindowHeight: PropTypes.func, showChallengeComplete: PropTypes.number, - submitChallenge: PropTypes.func + submitChallenge: PropTypes.func, + isMapDrawerOpen: PropTypes.bool, + isMapAlreadyLoaded: PropTypes.bool, + toggleMapDrawer: PropTypes.func }; componentWillReceiveProps({ @@ -122,8 +134,22 @@ export class FreeCodeCamp extends React.Component { } render() { - const { username, points, picture, updateNavHeight } = this.props; - const navProps = { username, points, picture, updateNavHeight }; + const { + username, + points, + picture, + updateNavHeight, + isMapDrawerOpen, + isMapAlreadyLoaded, + toggleMapDrawer + } = this.props; + const navProps = { + username, + points, + picture, + updateNavHeight, + toggleMapDrawer + }; return (