aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/components/sidebars/sidebar.component.js
diff options
context:
space:
mode:
authorDan Miller <danjm.com@gmail.com>2018-08-23 10:27:35 +0800
committerDan Miller <danjm.com@gmail.com>2018-08-29 08:38:15 +0800
commit40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5 (patch)
tree47d6b83438cdc7e0cd3e7f0b5825de90d50a1136 /ui/app/components/sidebars/sidebar.component.js
parent4560df6e739b97caf95ef5bc5bc93f91e8c890bb (diff)
downloadtangerine-wallet-browser-40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5.tar
tangerine-wallet-browser-40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5.tar.gz
tangerine-wallet-browser-40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5.tar.bz2
tangerine-wallet-browser-40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5.tar.lz
tangerine-wallet-browser-40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5.tar.xz
tangerine-wallet-browser-40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5.tar.zst
tangerine-wallet-browser-40e0d92f572d4fff14bfac9a2b0a64ffae8ec7c5.zip
Adds sidebar component and refactors slide in wallet view sidebar to use it.
Diffstat (limited to 'ui/app/components/sidebars/sidebar.component.js')
-rw-r--r--ui/app/components/sidebars/sidebar.component.js49
1 files changed, 49 insertions, 0 deletions
diff --git a/ui/app/components/sidebars/sidebar.component.js b/ui/app/components/sidebars/sidebar.component.js
new file mode 100644
index 000000000..57cdd7111
--- /dev/null
+++ b/ui/app/components/sidebars/sidebar.component.js
@@ -0,0 +1,49 @@
+import React, { Component } from 'react'
+import PropTypes from 'prop-types'
+import ReactCSSTransitionGroup from 'react-addons-css-transition-group'
+import WalletView from '../wallet-view'
+import { WALLET_VIEW_SIDEBAR } from './sidebar.constants'
+
+export default class Sidebar extends Component {
+
+ static propTypes = {
+ sidebarOpen: PropTypes.bool,
+ hideSidebar: PropTypes.func,
+ transitionName: PropTypes.string,
+ type: PropTypes.string,
+ };
+
+ renderOverlay () {
+ return <div className="sidebar-overlay" onClick={() => this.props.hideSidebar()} />
+ }
+
+ renderSidebarContent () {
+ const { type } = this.props
+
+ switch (type) {
+ case WALLET_VIEW_SIDEBAR:
+ return <WalletView responsiveDisplayClassname={'sidebar-right' } />
+ default:
+ return null
+ }
+
+ }
+
+ render () {
+ const { transitionName, sidebarOpen } = this.props
+
+ return (
+ <div>
+ <ReactCSSTransitionGroup
+ transitionName={transitionName}
+ transitionEnterTimeout={300}
+ transitionLeaveTimeout={200}
+ >
+ { sidebarOpen ? this.renderSidebarContent() : null }
+ </ReactCSSTransitionGroup>
+ { sidebarOpen ? this.renderOverlay() : null }
+ </div>
+ )
+ }
+
+}