aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/components/pages/home
diff options
context:
space:
mode:
authorAlexander Tseung <alextsg@gmail.com>2018-07-25 02:40:05 +0800
committerAlexander Tseung <alextsg@gmail.com>2018-08-24 07:44:43 +0800
commit3b408715c745030aed6e720e6f19dc8f2aa511d1 (patch)
tree9dd80e685a533f673e7d3af7b70385240c011153 /ui/app/components/pages/home
parentdae07b32e50de8a3aa4c89d266c9272155beaaa4 (diff)
downloadtangerine-wallet-browser-3b408715c745030aed6e720e6f19dc8f2aa511d1.tar
tangerine-wallet-browser-3b408715c745030aed6e720e6f19dc8f2aa511d1.tar.gz
tangerine-wallet-browser-3b408715c745030aed6e720e6f19dc8f2aa511d1.tar.bz2
tangerine-wallet-browser-3b408715c745030aed6e720e6f19dc8f2aa511d1.tar.lz
tangerine-wallet-browser-3b408715c745030aed6e720e6f19dc8f2aa511d1.tar.xz
tangerine-wallet-browser-3b408715c745030aed6e720e6f19dc8f2aa511d1.tar.zst
tangerine-wallet-browser-3b408715c745030aed6e720e6f19dc8f2aa511d1.zip
Refactor home screen and remove unused files
Diffstat (limited to 'ui/app/components/pages/home')
-rw-r--r--ui/app/components/pages/home/home.component.js73
-rw-r--r--ui/app/components/pages/home/home.container.js34
-rw-r--r--ui/app/components/pages/home/index.js1
3 files changed, 108 insertions, 0 deletions
diff --git a/ui/app/components/pages/home/home.component.js b/ui/app/components/pages/home/home.component.js
new file mode 100644
index 000000000..0ab6f77f8
--- /dev/null
+++ b/ui/app/components/pages/home/home.component.js
@@ -0,0 +1,73 @@
+import React, { PureComponent } from 'react'
+import PropTypes from 'prop-types'
+import { Redirect } from 'react-router-dom'
+import WalletView from '../../wallet-view'
+import TxView from '../../tx-view'
+import {
+ INITIALIZE_BACKUP_PHRASE_ROUTE,
+ RESTORE_VAULT_ROUTE,
+ CONFIRM_TRANSACTION_ROUTE,
+ NOTICE_ROUTE,
+} from '../../../routes'
+
+export default class Home extends PureComponent {
+ static propTypes = {
+ history: PropTypes.object,
+ unapprovedTxs: PropTypes.object,
+ unapprovedMsgCount: PropTypes.number,
+ unapprovedPersonalMsgCount: PropTypes.number,
+ unapprovedTypedMessagesCount: PropTypes.number,
+ noActiveNotices: PropTypes.bool,
+ lostAccounts: PropTypes.array,
+ forgottenPassword: PropTypes.bool,
+ seedWords: PropTypes.string,
+ }
+
+ componentDidMount () {
+ const {
+ history,
+ unapprovedTxs = {},
+ unapprovedMsgCount = 0,
+ unapprovedPersonalMsgCount = 0,
+ unapprovedTypedMessagesCount = 0,
+ } = this.props
+
+ // unapprovedTxs and unapproved messages
+ if (Object.keys(unapprovedTxs).length ||
+ unapprovedTypedMessagesCount + unapprovedMsgCount + unapprovedPersonalMsgCount > 0) {
+ history.push(CONFIRM_TRANSACTION_ROUTE)
+ }
+ }
+
+ render () {
+ const {
+ noActiveNotices,
+ lostAccounts,
+ forgottenPassword,
+ seedWords,
+ } = this.props
+
+ // notices
+ if (!noActiveNotices || (lostAccounts && lostAccounts.length > 0)) {
+ return <Redirect to={{ pathname: NOTICE_ROUTE }} />
+ }
+
+ // seed words
+ if (seedWords) {
+ return <Redirect to={{ pathname: INITIALIZE_BACKUP_PHRASE_ROUTE }}/>
+ }
+
+ if (forgottenPassword) {
+ return <Redirect to={{ pathname: RESTORE_VAULT_ROUTE }} />
+ }
+
+ return (
+ <div className="main-container">
+ <div className="account-and-transaction-details">
+ <WalletView responsiveDisplayClassname="lap-visible" />
+ <TxView />
+ </div>
+ </div>
+ )
+ }
+}
diff --git a/ui/app/components/pages/home/home.container.js b/ui/app/components/pages/home/home.container.js
new file mode 100644
index 000000000..96a45a69b
--- /dev/null
+++ b/ui/app/components/pages/home/home.container.js
@@ -0,0 +1,34 @@
+import Home from './home.component'
+import { compose } from 'recompose'
+import { connect } from 'react-redux'
+import { withRouter } from 'react-router-dom'
+
+const mapStateToProps = state => {
+ const { metamask, appState } = state
+ const {
+ unapprovedTxs = {},
+ unapprovedMsgCount = 0,
+ unapprovedPersonalMsgCount = 0,
+ unapprovedTypedMessagesCount = 0,
+ noActiveNotices,
+ lostAccounts,
+ seedWords,
+ } = metamask
+ const { forgottenPassword } = appState
+
+ return {
+ unapprovedTxs,
+ unapprovedMsgCount,
+ unapprovedPersonalMsgCount,
+ unapprovedTypedMessagesCount,
+ noActiveNotices,
+ lostAccounts,
+ forgottenPassword,
+ seedWords,
+ }
+}
+
+export default compose(
+ withRouter,
+ connect(mapStateToProps)
+)(Home)
diff --git a/ui/app/components/pages/home/index.js b/ui/app/components/pages/home/index.js
new file mode 100644
index 000000000..4474ba5b8
--- /dev/null
+++ b/ui/app/components/pages/home/index.js
@@ -0,0 +1 @@
+export { default } from './home.container'