lbry-desktop/js/component/load_screen.js

48 lines
1.3 KiB
JavaScript
Raw Normal View History

2016-11-22 14:19:08 -06:00
import React from 'react';
import lbry from '../lbry.js';
import {BusyMessage, Icon} from './common.js';
import {Link} from '../component/link.js'
2016-11-22 14:19:08 -06:00
var LoadScreen = React.createClass({
propTypes: {
message: React.PropTypes.string.isRequired,
details: React.PropTypes.string,
isWarning: React.PropTypes.bool,
},
handleCancelClick: function() {
history.back();
},
getDefaultProps: function() {
return {
isWarning: false,
}
},
getInitialState: function() {
return {
message: null,
details: null,
isLagging: false,
}
},
render: function() {
const imgSrc = lbry.imagePath('lbry-white-485x160.png');
return (
2017-01-31 01:58:25 -05:00
<div className="load-screen">
<img src={imgSrc} alt="LBRY"/>
2017-01-31 01:58:25 -05:00
<div className="load-screen__message">
<h3>
<BusyMessage message={this.props.message} />
</h3>
{this.props.isWarning ? <Icon icon="icon-warning" /> : null} <span className={'load-screen__details ' + (this.props.isWarning ? 'load-screen__details--warning' : '')}>{this.props.details}</span>
{this.props.isWarning
? <div><Link label="Cancel" onClick={this.handleCancelClick} className='load-screen__cancel-link button-text' /></div>
: null}
</div>
</div>
);
}
2016-11-22 14:19:08 -06:00
});
export default LoadScreen;