2017-08-08 22:37:41 +02:00
|
|
|
const Component = require('react').Component
|
|
|
|
const h = require('react-hyperscript')
|
|
|
|
const inherits = require('util').inherits
|
|
|
|
const connect = require('react-redux').connect
|
|
|
|
const FadeModal = require('boron').FadeModal
|
2017-08-13 19:24:51 +02:00
|
|
|
const actions = require('../../actions')
|
|
|
|
const isMobileView = require('../../../lib/is-mobile-view')
|
|
|
|
const isPopupOrNotification = require('../../../../app/scripts/lib/is-popup-or-notification')
|
2017-08-21 04:10:49 +02:00
|
|
|
|
|
|
|
// Modal Components
|
|
|
|
const BuyOptions = require('./buy-options-modal')
|
|
|
|
const AccountDetailsModal = require('./account-details-modal')
|
|
|
|
const EditAccountNameModal = require('./edit-account-name-modal')
|
2017-09-20 10:05:27 +02:00
|
|
|
const ExportPrivateKeyModal = require('./export-private-key-modal')
|
2017-08-21 04:28:20 +02:00
|
|
|
const NewAccountModal = require('./new-account-modal')
|
2017-09-29 17:40:57 +02:00
|
|
|
const ShapeshiftDepositTxModal = require('./shapeshift-deposit-tx-modal.js')
|
2017-09-29 21:03:29 +02:00
|
|
|
const HideTokenConfirmationModal = require('./hide-token-confirmation-modal')
|
2017-10-13 22:19:22 +02:00
|
|
|
const CustomizeGasModal = require('../customize-gas-modal')
|
2017-08-21 03:32:58 +02:00
|
|
|
|
2017-09-20 10:05:27 +02:00
|
|
|
const accountModalStyle = {
|
|
|
|
mobileModalStyle: {
|
|
|
|
width: '95%',
|
2017-09-29 01:34:42 +02:00
|
|
|
// top: isPopupOrNotification() === 'popup' ? '52vh' : '36.5vh',
|
2017-09-20 10:05:27 +02:00
|
|
|
boxShadow: 'rgba(0, 0, 0, 0.15) 0px 2px 2px 2px',
|
|
|
|
borderRadius: '4px',
|
2017-09-29 01:34:42 +02:00
|
|
|
top: '10%',
|
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-09-20 10:05:27 +02:00
|
|
|
},
|
|
|
|
laptopModalStyle: {
|
|
|
|
width: '360px',
|
2017-09-29 01:34:42 +02:00
|
|
|
// top: 'calc(33% + 45px)',
|
2017-09-20 10:05:27 +02:00
|
|
|
boxShadow: 'rgba(0, 0, 0, 0.15) 0px 2px 2px 2px',
|
|
|
|
borderRadius: '4px',
|
2017-09-29 01:34:42 +02:00
|
|
|
top: '10%',
|
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-09-20 10:05:27 +02:00
|
|
|
},
|
|
|
|
contentStyle: {
|
|
|
|
borderRadius: '4px',
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2017-08-21 03:32:58 +02:00
|
|
|
const MODALS = {
|
2017-08-21 12:53:01 +02:00
|
|
|
BUY: {
|
|
|
|
contents: [
|
|
|
|
h(BuyOptions, {}, []),
|
|
|
|
],
|
|
|
|
mobileModalStyle: {
|
|
|
|
width: '95%',
|
2017-09-29 01:34:42 +02:00
|
|
|
// top: isPopupOrNotification() === 'popup' ? '48vh' : '36.5vh',
|
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-09-20 03:49:35 +02:00
|
|
|
boxShadow: '0 0 7px 0 rgba(0,0,0,0.08)',
|
2017-09-29 01:34:42 +02:00
|
|
|
top: '10%',
|
2017-08-21 12:53:01 +02:00
|
|
|
},
|
|
|
|
laptopModalStyle: {
|
|
|
|
width: '66%',
|
2017-09-20 03:49:35 +02:00
|
|
|
maxWidth: '550px',
|
2017-09-29 01:34:42 +02:00
|
|
|
top: 'calc(10% + 10px)',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-09-20 03:49:35 +02:00
|
|
|
boxShadow: '0 0 7px 0 rgba(0,0,0,0.08)',
|
2017-09-29 01:34:42 +02:00
|
|
|
transform: 'none',
|
2017-08-21 12:53:01 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
EDIT_ACCOUNT_NAME: {
|
|
|
|
contents: [
|
|
|
|
h(EditAccountNameModal, {}, []),
|
|
|
|
],
|
|
|
|
mobileModalStyle: {
|
|
|
|
width: '95%',
|
2017-09-29 01:34:42 +02:00
|
|
|
// top: isPopupOrNotification() === 'popup' ? '48vh' : '36.5vh',
|
|
|
|
top: '10%',
|
2017-08-21 12:53:01 +02:00
|
|
|
boxShadow: 'rgba(0, 0, 0, 0.15) 0px 2px 2px 2px',
|
2017-09-29 01:34:42 +02:00
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-08-21 12:53:01 +02:00
|
|
|
},
|
|
|
|
laptopModalStyle: {
|
2017-08-21 14:58:30 +02:00
|
|
|
width: '375px',
|
2017-09-29 01:34:42 +02:00
|
|
|
// top: 'calc(30% + 10px)',
|
|
|
|
top: '10%',
|
2017-08-21 12:53:01 +02:00
|
|
|
boxShadow: 'rgba(0, 0, 0, 0.15) 0px 2px 2px 2px',
|
2017-09-29 01:34:42 +02:00
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-08-21 12:53:01 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
ACCOUNT_DETAILS: {
|
|
|
|
contents: [
|
|
|
|
h(AccountDetailsModal, {}, []),
|
|
|
|
],
|
2017-09-20 10:05:27 +02:00
|
|
|
...accountModalStyle,
|
|
|
|
},
|
|
|
|
|
|
|
|
EXPORT_PRIVATE_KEY: {
|
|
|
|
contents: [
|
|
|
|
h(ExportPrivateKeyModal, {}, []),
|
|
|
|
],
|
|
|
|
...accountModalStyle,
|
2017-08-21 12:53:01 +02:00
|
|
|
},
|
|
|
|
|
2017-09-29 17:40:57 +02:00
|
|
|
SHAPESHIFT_DEPOSIT_TX: {
|
|
|
|
contents: [
|
|
|
|
h(ShapeshiftDepositTxModal),
|
|
|
|
],
|
|
|
|
...accountModalStyle,
|
|
|
|
},
|
|
|
|
|
2017-09-29 21:03:29 +02:00
|
|
|
HIDE_TOKEN_CONFIRMATION: {
|
|
|
|
contents: [
|
|
|
|
h(HideTokenConfirmationModal, {}, []),
|
|
|
|
],
|
|
|
|
mobileModalStyle: {
|
|
|
|
width: '95%',
|
|
|
|
top: isPopupOrNotification() === 'popup' ? '52vh' : '36.5vh',
|
|
|
|
},
|
|
|
|
laptopModalStyle: {
|
|
|
|
width: '449px',
|
|
|
|
top: 'calc(33% + 45px)',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
2017-08-21 12:53:01 +02:00
|
|
|
NEW_ACCOUNT: {
|
|
|
|
contents: [
|
|
|
|
h(NewAccountModal, {}, []),
|
|
|
|
],
|
2017-08-25 02:31:01 +02:00
|
|
|
mobileModalStyle: {
|
|
|
|
width: '95%',
|
2017-09-29 01:34:42 +02:00
|
|
|
// top: isPopupOrNotification() === 'popup' ? '52vh' : '36.5vh',
|
|
|
|
top: '10%',
|
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-08-25 02:31:01 +02:00
|
|
|
},
|
|
|
|
laptopModalStyle: {
|
|
|
|
width: '449px',
|
2017-09-29 01:34:42 +02:00
|
|
|
// top: 'calc(33% + 45px)',
|
|
|
|
top: '10%',
|
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
2017-08-25 02:31:01 +02:00
|
|
|
},
|
2017-08-21 12:53:01 +02:00
|
|
|
},
|
|
|
|
|
2017-10-13 22:19:22 +02:00
|
|
|
CUSTOMIZE_GAS: {
|
|
|
|
contents: [
|
|
|
|
h(CustomizeGasModal, {}, []),
|
|
|
|
],
|
|
|
|
mobileModalStyle: {
|
2017-10-25 10:08:14 +02:00
|
|
|
width: '100vw',
|
|
|
|
height: '100vh',
|
|
|
|
top: '0',
|
2017-10-13 22:19:22 +02:00
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
|
|
|
},
|
|
|
|
laptopModalStyle: {
|
|
|
|
width: '720px',
|
|
|
|
height: '377px',
|
|
|
|
top: '80px',
|
|
|
|
transform: 'none',
|
|
|
|
left: '0',
|
|
|
|
right: '0',
|
|
|
|
margin: '0 auto',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
2017-08-21 12:53:01 +02:00
|
|
|
DEFAULT: {
|
|
|
|
contents: [],
|
|
|
|
mobileModalStyle: {},
|
|
|
|
laptopModalStyle: {},
|
2017-08-29 16:50:48 +02:00
|
|
|
},
|
2017-08-21 12:53:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const BACKDROPSTYLE = {
|
|
|
|
backgroundColor: 'rgba(245, 245, 245, 0.85)',
|
2017-08-21 03:32:58 +02:00
|
|
|
}
|
2017-08-08 22:37:41 +02:00
|
|
|
|
|
|
|
function mapStateToProps (state) {
|
|
|
|
return {
|
2017-08-21 03:32:58 +02:00
|
|
|
active: state.appState.modal.open,
|
|
|
|
modalState: state.appState.modal.modalState,
|
2017-08-08 22:37:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function mapDispatchToProps (dispatch) {
|
|
|
|
return {
|
|
|
|
hideModal: () => {
|
|
|
|
dispatch(actions.hideModal())
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-13 19:24:51 +02:00
|
|
|
// Global Modal Component
|
2017-08-08 22:37:41 +02:00
|
|
|
inherits(Modal, Component)
|
|
|
|
function Modal () {
|
|
|
|
Component.call(this)
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = connect(mapStateToProps, mapDispatchToProps)(Modal)
|
|
|
|
|
2017-08-09 03:44:20 +02:00
|
|
|
Modal.prototype.render = function () {
|
2017-08-21 12:53:01 +02:00
|
|
|
const modal = MODALS[this.props.modalState.name || 'DEFAULT']
|
2017-08-09 02:51:06 +02:00
|
|
|
|
2017-08-21 12:53:01 +02:00
|
|
|
const children = modal.contents
|
|
|
|
const modalStyle = modal[isMobileView() ? 'mobileModalStyle' : 'laptopModalStyle']
|
2017-09-11 09:45:06 +02:00
|
|
|
const contentStyle = modal.contentStyle || {};
|
2017-08-21 03:32:58 +02:00
|
|
|
|
2017-08-08 22:37:41 +02:00
|
|
|
return h(FadeModal,
|
|
|
|
{
|
2017-08-08 23:05:19 +02:00
|
|
|
className: 'modal',
|
2017-08-08 22:37:41 +02:00
|
|
|
keyboard: false,
|
2017-08-29 16:50:48 +02:00
|
|
|
onHide: () => { this.onHide() },
|
2017-08-08 22:37:41 +02:00
|
|
|
ref: (ref) => {
|
|
|
|
this.modalRef = ref
|
|
|
|
},
|
2017-08-21 12:53:01 +02:00
|
|
|
modalStyle,
|
2017-09-11 09:45:06 +02:00
|
|
|
contentStyle,
|
2017-08-21 12:53:01 +02:00
|
|
|
backdropStyle: BACKDROPSTYLE,
|
2017-08-08 22:37:41 +02:00
|
|
|
},
|
2017-08-21 03:32:58 +02:00
|
|
|
children,
|
2017-08-08 22:37:41 +02:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-08-29 16:50:48 +02:00
|
|
|
Modal.prototype.componentWillReceiveProps = function (nextProps) {
|
2017-08-08 22:37:41 +02:00
|
|
|
if (nextProps.active) {
|
|
|
|
this.show()
|
|
|
|
} else if (this.props.active) {
|
|
|
|
this.hide()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-29 16:50:48 +02:00
|
|
|
Modal.prototype.onHide = function () {
|
2017-08-08 22:37:41 +02:00
|
|
|
if (this.props.onHideCallback) {
|
|
|
|
this.props.onHideCallback()
|
|
|
|
}
|
|
|
|
this.props.hideModal()
|
|
|
|
}
|
|
|
|
|
2017-08-29 16:50:48 +02:00
|
|
|
Modal.prototype.hide = function () {
|
2017-08-08 22:37:41 +02:00
|
|
|
this.modalRef.hide()
|
|
|
|
}
|
|
|
|
|
2017-08-29 16:50:48 +02:00
|
|
|
Modal.prototype.show = function () {
|
2017-08-08 22:37:41 +02:00
|
|
|
this.modalRef.show()
|
|
|
|
}
|