* Move secureApi to shell
* Extract isTestnet test
* Use mobx + subscriptions for status
* Re-add status indicator
* Add lerna
* Move intial packages to js/packages
* Move 3rdparty/{email,sms}-verification to correct location
* Move package.json & README to library src
* Move tests for library packages
* Move views & dapps to packages
* Move i18n to root
* Move shell to actual src (main app)
* Remove ~ references
* Change ~ to root (explicit imports)
* Finalise convert of ~
* Move views into dapps as well
* Move dapps to packages/
* Fix references
* Update css
* Update test spec locations
* Update tests
* Case fix
* Skip flakey tests
* Update enzyme
* Skip previously ignored tests
* Allow empty api for hw
* Re-add theme for embed
		
	
			
		
			
				
	
	
		
			113 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Copyright 2015-2017 Parity Technologies (UK) Ltd.
 | |
| // This file is part of Parity.
 | |
| 
 | |
| // Parity is free software: you can redistribute it and/or modify
 | |
| // it under the terms of the GNU General Public License as published by
 | |
| // the Free Software Foundation, either version 3 of the License, or
 | |
| // (at your option) any later version.
 | |
| 
 | |
| // Parity is distributed in the hope that it will be useful,
 | |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| // GNU General Public License for more details.
 | |
| 
 | |
| // You should have received a copy of the GNU General Public License
 | |
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | |
| 
 | |
| import React, { Component } from 'react';
 | |
| import PropTypes from 'prop-types';
 | |
| import { FormattedMessage } from 'react-intl';
 | |
| import { connect } from 'react-redux';
 | |
| import { bindActionCreators } from 'redux';
 | |
| 
 | |
| import { Snackbar } from '../Snackbar';
 | |
| 
 | |
| import { closeErrors } from './actions';
 | |
| 
 | |
| import styles from './errors.css';
 | |
| 
 | |
| const ERROR_REGEX = /-(\d+): (.+)$/;
 | |
| const DURATION_OPEN = 60000;
 | |
| 
 | |
| const STYLE_CONTENT = {
 | |
|   backgroundColor: 'rgba(255, 71, 71, 0.75)'
 | |
| };
 | |
| 
 | |
| class Errors extends Component {
 | |
|   static propTypes = {
 | |
|     message: PropTypes.string,
 | |
|     error: PropTypes.object,
 | |
|     visible: PropTypes.bool,
 | |
|     onCloseErrors: PropTypes.func
 | |
|   };
 | |
| 
 | |
|   render () {
 | |
|     const { message, visible } = this.props;
 | |
| 
 | |
|     if (!message || !visible) {
 | |
|       return null;
 | |
|     }
 | |
| 
 | |
|     const text = this.getErrorMessage();
 | |
| 
 | |
|     return (
 | |
|       <Snackbar
 | |
|         className={ styles.container }
 | |
|         open
 | |
|         action={
 | |
|           <FormattedMessage
 | |
|             id='ui.errors.close'
 | |
|             defaultMessage='close'
 | |
|           />
 | |
|         }
 | |
|         autoHideDuration={ DURATION_OPEN }
 | |
|         message={ text }
 | |
|         onRequestClose={ this.onRequestClose }
 | |
|         bodyStyle={ STYLE_CONTENT }
 | |
|       />
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   getErrorMessage = () => {
 | |
|     const { message, error } = this.props;
 | |
| 
 | |
|     if (!error.text && !ERROR_REGEX.test(message)) {
 | |
|       return message;
 | |
|     }
 | |
| 
 | |
|     const matches = ERROR_REGEX.exec(message);
 | |
| 
 | |
|     const code = error.code || parseInt(matches[1]) * -1;
 | |
|     const text = error.text || matches[2];
 | |
| 
 | |
|     return `[${code}] ${text}`;
 | |
|   }
 | |
| 
 | |
|   onRequestClose = (reason) => {
 | |
|     if (reason === 'timeout') {
 | |
|       this.props.onCloseErrors();
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| function mapStateToProps (state) {
 | |
|   const { message, error, visible } = state.errors;
 | |
| 
 | |
|   return {
 | |
|     message,
 | |
|     error,
 | |
|     visible
 | |
|   };
 | |
| }
 | |
| 
 | |
| function mapDispatchToProps (dispatch) {
 | |
|   return bindActionCreators({
 | |
|     onCloseErrors: closeErrors
 | |
|   }, dispatch);
 | |
| }
 | |
| 
 | |
| export default connect(
 | |
|   mapStateToProps,
 | |
|   mapDispatchToProps
 | |
| )(Errors);
 |