Browse Source

fix(onboarding): default state is false for onboarded

renovate/lint-staged-8.x
Jack Mallers 7 years ago
parent
commit
8d448708b7
  1. 16
      app/components/Onboarding/Alias.js
  2. 4
      app/components/Onboarding/FormContainer.js
  3. 10
      app/components/Onboarding/Onboarding.js
  4. 4
      app/components/Onboarding/Syncing.js
  5. 3
      app/components/Wallet/Wallet.js
  6. 26
      app/containers/Root.js
  7. 30
      app/main.dev.js
  8. 6
      app/reducers/ipc.js
  9. 44
      app/reducers/onboarding.js

16
app/components/Onboarding/Alias.js

@ -4,22 +4,22 @@ import Isvg from 'react-inlinesvg'
import zapLogo from 'icons/zap_logo.svg' import zapLogo from 'icons/zap_logo.svg'
import styles from './Alias.scss' import styles from './Alias.scss'
const Alias = ({ alias, setAlias }) => { const Alias = ({ alias, updateAlias }) => (
console.log('alias: ', alias)
console.log('setAlias: ', setAlias)
return (
<div className={styles.container}> <div className={styles.container}>
<input <input
type='text' type='text'
placeholder='Satoshi' placeholder='Satoshi'
className={styles.alias} className={styles.alias}
ref={input => input && input.focus()} ref={input => input && input.focus()}
value={alias}
onChange={event => updateAlias(event.target.value)}
/> />
</div> </div>
) )
}
Alias.propTypes = {} Alias.propTypes = {
alias: PropTypes.string.isRequired,
updateAlias: PropTypes.func.isRequired
}
export default Alias export default Alias

4
app/components/Onboarding/FormContainer.js

@ -30,12 +30,12 @@ const FormContainer = ({ title, description, back, next, children }) => {
<div className={styles.buttonsContainer}> <div className={styles.buttonsContainer}>
<section> <section>
{ {
back && <div>Back</div> back && <div onClick={back}>Back</div>
} }
</section> </section>
<section> <section>
{ {
next && <div>Next</div> next && <div onClick={next}>Next</div>
} }
</section> </section>
</div> </div>

10
app/components/Onboarding/Onboarding.js

@ -13,13 +13,15 @@ class Onboarding extends Component {
render() { render() {
const { const {
onboarding: { onboarding: {
step step,
alias
}, },
submit,
aliasProps,
syncingProps syncingProps
} = this.props } = this.props
const renderStep = () => { const renderStep = () => {
console.log('step: ', step)
switch(step) { switch(step) {
case 1: case 1:
return ( return (
@ -27,9 +29,9 @@ class Onboarding extends Component {
title={'1. What should we call you?'} title={'1. What should we call you?'}
description={'Set your nickname to help others connect with you on the Lightning Network'} description={'Set your nickname to help others connect with you on the Lightning Network'}
back={null} back={null}
next={() => console.log('alias next')} next={() => submit(alias)}
> >
<Alias /> <Alias {...aliasProps} />
</FormContainer> </FormContainer>
) )
default: default:

4
app/components/Onboarding/Syncing.js

@ -24,9 +24,9 @@ class Syncing extends Component {
<section className={styles.progressContainer}> <section className={styles.progressContainer}>
<h1>Syncing to the blockchain...</h1> <h1>Syncing to the blockchain...</h1>
<div className={styles.progressBar}> <div className={styles.progressBar}>
<div className={styles.progress} style={{ width: syncPercentage }} /> <div className={styles.progress} style={{ width: isNaN(syncPercentage) ? 0 : `${syncPercentage}%` }} />
</div> </div>
<h4>{syncPercentage.toString().length > 0 && `${syncPercentage}%`}</h4> <h4>{isNaN(parseInt(syncPercentage)) || syncPercentage.toString().length === 0 ? '' : `${syncPercentage}%`}</h4>
</section> </section>
</div> </div>
</div> </div>

3
app/components/Wallet/Wallet.js

@ -32,7 +32,8 @@ class Wallet extends Component {
} = this.props } = this.props
const { modalOpen, qrCodeType } = this.state const { modalOpen, qrCodeType } = this.state
const usdAmount = parseFloat(btc.satoshisToUsd(balance.walletBalance, currentTicker.price_usd)) const usdAmount = btc.satoshisToUsd(balance.channelBalance, currentTicker.price_usd)
console.log('usdAmount: ', usdAmount)
const changeQrCode = () => { const changeQrCode = () => {
const qrCodeNum = this.state.qrCodeType === 1 ? 2 : 1 const qrCodeNum = this.state.qrCodeType === 1 ? 2 : 1

26
app/containers/Root.js

@ -7,10 +7,15 @@ import PropTypes from 'prop-types'
import LoadingBolt from '../components/LoadingBolt' import LoadingBolt from '../components/LoadingBolt'
import Onboarding from '../components/Onboarding' import Onboarding from '../components/Onboarding'
import Syncing from '../components/Onboarding/Syncing' import Syncing from '../components/Onboarding/Syncing'
import { updateAlias, changeStep, submit } from '../reducers/onboarding'
import { fetchBlockHeight, lndSelectors } from '../reducers/lnd' import { fetchBlockHeight, lndSelectors } from '../reducers/lnd'
import Routes from '../routes' import Routes from '../routes'
const mapDispatchToProps = { const mapDispatchToProps = {
updateAlias,
changeStep,
submit,
fetchBlockHeight fetchBlockHeight
} }
@ -27,11 +32,17 @@ const mergeProps = (stateProps, dispatchProps, ownProps) => {
syncPercentage: stateProps.syncPercentage syncPercentage: stateProps.syncPercentage
} }
const aliasProps = {
updateAlias: dispatchProps.updateAlias,
alias: stateProps.onboarding.alias
}
return { return {
...stateProps, ...stateProps,
...dispatchProps, ...dispatchProps,
...ownProps, ...ownProps,
aliasProps,
syncingProps syncingProps
} }
} }
@ -39,19 +50,32 @@ const mergeProps = (stateProps, dispatchProps, ownProps) => {
const Root = ({ const Root = ({
store, store,
history, history,
lnd,
onboarding, onboarding,
syncingProps submit,
aliasProps,
syncingProps,
updateAlias,
changeStep,
}) => { }) => {
// If we are syncing show the syncing screen // If we are syncing show the syncing screen
if (!onboarding.onboarded) { if (!onboarding.onboarded) {
return ( return (
<Onboarding <Onboarding
onboarding={onboarding} onboarding={onboarding}
submit={submit}
aliasProps={aliasProps}
syncingProps={syncingProps} syncingProps={syncingProps}
/> />
) )
} }
// If we are syncing show the syncing screen
if (lnd.syncing) {
return <Syncing {...syncingProps} />
}
// Don't launch the app without gRPC connection // Don't launch the app without gRPC connection
if (!lnd.grpcStarted) { return <LoadingBolt /> } if (!lnd.grpcStarted) { return <LoadingBolt /> }

30
app/main.dev.js

@ -83,6 +83,19 @@ const sendLndSyncing = () => {
}, 1000) }, 1000)
} }
const sendStartOnboarding = () => {
const sendStartOnboardingInterval = setInterval(() => {
if (didFinishLoad) {
clearInterval(sendStartOnboardingInterval)
if (mainWindow) {
console.log('STARTING ONBOARDING')
mainWindow.webContents.send('startOnboarding')
}
}
}, 1000)
}
// Send the front end event letting them know the gRPC connection has started // Send the front end event letting them know the gRPC connection has started
const sendGrpcConnected = () => { const sendGrpcConnected = () => {
const sendGrpcConnectedInterval = setInterval(() => { const sendGrpcConnectedInterval = setInterval(() => {
@ -126,7 +139,7 @@ const sendLndSynced = () => {
} }
// Starts the LND node // Starts the LND node
const startLnd = () => { const startLnd = (alias) => {
let lndPath let lndPath
if (process.env.NODE_ENV === 'development') { if (process.env.NODE_ENV === 'development') {
@ -146,7 +159,8 @@ const startLnd = () => {
'--neutrino.connect=127.0.0.1:18333', '--neutrino.connect=127.0.0.1:18333',
'--autopilot.active', '--autopilot.active',
'--debuglevel=debug', '--debuglevel=debug',
'--noencryptwallet' '--noencryptwallet',
`--alias=${alias}`
] ]
) )
.on('error', error => console.log(`lnd error: ${error}`)) .on('error', error => console.log(`lnd error: ${error}`))
@ -249,9 +263,10 @@ app.on('ready', async () => {
// No LND process was found // No LND process was found
if (!results.length) { if (!results.length) {
// Assign path to certs to certPath // let the application know onboarding has started
sendLndSyncing() sendStartOnboarding()
// Assign path to certs to certPath
switch (os.platform()) { switch (os.platform()) {
case 'darwin': case 'darwin':
certPath = path.join(homedir, 'Library/Application Support/Lnd/tls.cert') certPath = path.join(homedir, 'Library/Application Support/Lnd/tls.cert')
@ -267,7 +282,12 @@ app.on('ready', async () => {
} }
// Start LND // Start LND
startLnd() // startLnd()
// once the onboarding has finished we wanna let the application we have started syncing and start LND
ipcMain.on('onboardingFinished', (event, { alias }) => {
sendLndSyncing()
startLnd(alias)
})
} else { } else {
// An LND process was found, no need to start our own // An LND process was found, no need to start our own
console.log('LND ALREADY RUNNING') console.log('LND ALREADY RUNNING')

6
app/reducers/ipc.js

@ -35,6 +35,8 @@ import {
import { receiveDescribeNetwork, receiveQueryRoutes, receiveInvoiceAndQueryRoutes } from './network' import { receiveDescribeNetwork, receiveQueryRoutes, receiveInvoiceAndQueryRoutes } from './network'
import { startOnboarding } from './onboarding'
// Import all receiving IPC event handlers and pass them into createIpc // Import all receiving IPC event handlers and pass them into createIpc
const ipc = createIpc({ const ipc = createIpc({
lndSyncing, lndSyncing,
@ -91,7 +93,9 @@ const ipc = createIpc({
receiveDescribeNetwork, receiveDescribeNetwork,
receiveQueryRoutes, receiveQueryRoutes,
receiveInvoiceAndQueryRoutes receiveInvoiceAndQueryRoutes,
startOnboarding
}) })
export default ipc export default ipc

44
app/reducers/onboarding.js

@ -1,20 +1,60 @@
import { ipcRenderer } from 'electron'
// ------------------------------------ // ------------------------------------
// Constants // Constants
// ------------------------------------ // ------------------------------------
export const UPDATE_ALIAS = 'UPDATE_ALIAS'
export const CHANGE_STEP = 'CHANGE_STEP'
export const ONBOARDING_STARTED = 'ONBOARDING_STARTED'
export const ONBOARDING_FINISHED = 'ONBOARDING_FINISHED'
// ------------------------------------
// Actions
// ------------------------------------
export function updateAlias(alias) {
return {
type: UPDATE_ALIAS,
alias
}
}
export function changeStep(step) {
return {
type: CHANGE_STEP,
step
}
}
export function submit(alias) {
// alert the app we're done onboarding and it's cool to start LND
ipcRenderer.send('onboardingFinished', { alias })
return {
type: ONBOARDING_FINISHED
}
}
export const startOnboarding = () => (dispatch) => {
dispatch({ type: ONBOARDING_STARTED })
}
// ------------------------------------ // ------------------------------------
// Action Handlers // Action Handlers
// ------------------------------------ // ------------------------------------
const ACTION_HANDLERS = { const ACTION_HANDLERS = {
[UPDATE_ALIAS]: (state, { alias }) => ({ ...state, alias }),
[CHANGE_STEP]: (state, { step }) => ({ ...state, step }),
[ONBOARDING_STARTED]: state => ({ ...state, onboarded: false }),
[ONBOARDING_FINISHED]: state => ({ ...state, onboarded: true })
} }
// ------------------------------------ // ------------------------------------
// Reducer // Reducer
// ------------------------------------ // ------------------------------------
const initialState = { const initialState = {
onboarded: false, onboarded: true,
step: 1, step: 1,
alias: '' alias: ''
} }

Loading…
Cancel
Save