Browse Source

feature(global-errors): hook up global errors reducer to component and set error on transaction fail

renovate/lint-staged-8.x
Jack Mallers 7 years ago
parent
commit
d61bc585cf
  1. 7
      app/components/GlobalError/GlobalError.js
  2. 24
      app/components/GlobalError/GlobalError.scss
  3. 5
      app/lnd/methods/index.js
  4. 45
      app/reducers/error.js
  5. 4
      app/reducers/index.js
  6. 4
      app/reducers/transaction.js
  7. 4
      app/routes/app/components/App.js
  8. 2
      app/routes/app/containers/AppContainer.js

7
app/components/GlobalError/GlobalError.js

@ -1,12 +1,13 @@
import React from 'react'
import PropTypes from 'prop-types'
import styles from './GlobalError'
import styles from './GlobalError.scss'
const GlobalError = ({ error }) => {
console.log('error: ', error)
if (!error) { return null }
return (
<div>
yo global error mf
<div className={styles.container}>
<h2>{error}</h2>
</div>
)
}

24
app/components/GlobalError/GlobalError.scss

@ -0,0 +1,24 @@
@import '../../variables.scss';
.container {
position: absolute;
z-index: 1001;
background: $red;
color: $white;
width: 100%;
text-align: center;
padding: 20px;
// height: 0;
transition: all 0.25s ease;
&.active {
height: 100%;
padding: 20px;
}
h2 {
font-size: 20px;
letter-spacing: 1.5px;
font-weight: bold;
}
}

5
app/lnd/methods/index.js

@ -119,7 +119,10 @@ export default function (lnd, event, msg, data) {
// { amount, addr } = data
walletController.sendCoins(lnd, data)
.then(({ txid }) => event.sender.send('transactionSuccessful', { amount: data.amount, addr: data.addr, txid }))
.catch(error => event.sender.send('transactionError', { error }))
.catch(error => {
console.log('error: ', error)
event.sender.send('transactionError', { error: error.toString() })
})
break
case 'openChannel':
// Response is empty. Streaming updates on channel status and updates

45
app/reducers/error.js

@ -0,0 +1,45 @@
// ------------------------------------
// Initial State
// ------------------------------------
const initialState = {
error: null
}
// ------------------------------------
// Constants
// ------------------------------------
export const SET_ERROR = 'SET_ERROR'
export const CLEAR_ERROR = 'CLEAR_ERROR'
// ------------------------------------
// Actions
// ------------------------------------
export function setError(error) {
return {
type: SET_ERROR,
error
}
}
export function clearError() {
return {
type: CLEAR_ERROR
}
}
// ------------------------------------
// Action Handlers
// ------------------------------------
const ACTION_HANDLERS = {
[SET_ERROR]: (state, { error }) => ({ ...state, error }),
[CLEAR_ERROR]: () => (initialState)
}
// ------------------------------------
// Reducer
// ------------------------------------
export default function errorReducer(state = initialState, action) {
const handler = ACTION_HANDLERS[action.type]
return handler ? handler(state, action) : state
}

4
app/reducers/index.js

@ -18,6 +18,7 @@ import modal from './modal'
import address from './address'
import transaction from './transaction'
import activity from './activity'
import error from './error'
const rootReducer = combineReducers({
router,
@ -37,7 +38,8 @@ const rootReducer = combineReducers({
modal,
address,
transaction,
activity
activity,
error
})
export default rootReducer

4
app/reducers/transaction.js

@ -5,6 +5,7 @@ import { fetchBalance } from './balance'
import { setFormType } from './form'
import { resetPayForm } from './payform'
import { showModal } from './modal'
import { setError } from './error'
// ------------------------------------
// Constants
@ -67,8 +68,9 @@ export const transactionSuccessful = (event, { amount, addr, txid }) => (dispatc
dispatch(resetPayForm())
}
export const transactionError = () => (dispatch) => {
export const transactionError = (event, { error }) => (dispatch) => {
dispatch({ type: TRANSACTION_FAILED })
dispatch(setError(error))
}
// Listener for when a new transaction is pushed from the subscriber

4
app/routes/app/components/App.js

@ -41,6 +41,8 @@ class App extends Component {
formProps,
closeForm,
error: { error },
children
} = this.props
@ -58,7 +60,7 @@ class App extends Component {
return (
<div>
<GlobalError />
<GlobalError error={error} />
<ModalRoot
modalType={modalType}
modalProps={modalProps}

2
app/routes/app/containers/AppContainer.js

@ -67,6 +67,8 @@ const mapStateToProps = state => ({
invoice: state.invoice,
modal: state.modal,
error: state.error,
currentTicker: tickerSelectors.currentTicker(state),
isOnchain: payFormSelectors.isOnchain(state),
isLn: payFormSelectors.isLn(state),

Loading…
Cancel
Save