Browse Source

feature(globalerror): clear error

renovate/lint-staged-8.x
Jack Mallers 7 years ago
parent
commit
a2e4e0ad7d
  1. 19
      app/components/GlobalError/GlobalError.js
  2. 18
      app/components/GlobalError/GlobalError.scss
  3. 3
      app/routes/app/components/App.js
  4. 6
      app/routes/app/containers/AppContainer.js

19
app/components/GlobalError/GlobalError.js

@ -1,18 +1,23 @@
import React from 'react'
import PropTypes from 'prop-types'
import { MdClose } from 'react-icons/lib/md'
import styles from './GlobalError.scss'
const GlobalError = ({ error }) => {
if (!error) { return null }
return (
<div className={styles.container}>
const GlobalError = ({ error, clearError }) => (
<div className={`${styles.container} ${!error && styles.closed}`}>
<div className={styles.content}>
<div className={styles.close} onClick={clearError}>
<MdClose />
</div>
<h2>{error}</h2>
</div>
)
}
</div>
)
GlobalError.propTypes = {
error: PropTypes.string
error: PropTypes.string,
clearError: PropTypes.func.isRequired
}
export default GlobalError

18
app/components/GlobalError/GlobalError.scss

@ -8,12 +8,21 @@
width: 100%;
text-align: center;
padding: 20px;
// height: 0;
transition: all 0.25s ease;
&.active {
height: 100%;
padding: 20px;
&.closed {
max-height: 0;
padding: 0;
}
.content {
position: relative;
.close {
position: absolute;
top: calc(50% - 8px);
right: 10%;
cursor: pointer;
}
h2 {
@ -21,4 +30,5 @@
letter-spacing: 1.5px;
font-weight: bold;
}
}
}

3
app/routes/app/components/App.js

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

6
app/routes/app/containers/AppContainer.js

@ -14,6 +14,8 @@ import { sendCoins } from 'reducers/transaction'
import { payInvoice } from 'reducers/payment'
import { createInvoice, fetchInvoice } from 'reducers/invoice'
import { clearError } from 'reducers/error'
import App from '../components/App'
@ -40,7 +42,9 @@ const mapDispatchToProps = {
sendCoins,
payInvoice,
createInvoice,
fetchInvoice
fetchInvoice,
clearError
}
const mapStateToProps = state => ({

Loading…
Cancel
Save