2018-04-23 16:42:52 -04:00
|
|
|
import React from 'react';
|
|
|
|
import ReactDOM from 'react-dom';
|
2019-08-23 11:51:03 -04:00
|
|
|
import {TabContent, TabPane, Nav, NavItem, NavLink} from 'reactstrap';
|
|
|
|
import classnames from 'classnames';
|
2016-08-18 07:45:08 -04:00
|
|
|
|
2018-01-03 12:42:48 -05:00
|
|
|
import EmbarkJS from 'Embark/EmbarkJS';
|
2018-04-23 16:42:52 -04:00
|
|
|
import Blockchain from './components/blockchain';
|
|
|
|
import Whisper from './components/whisper';
|
2018-04-24 16:21:33 -04:00
|
|
|
import Storage from './components/storage';
|
2018-07-11 13:11:55 -04:00
|
|
|
import ENS from './components/ens';
|
2018-01-03 12:42:48 -05:00
|
|
|
|
2019-08-23 11:51:03 -04:00
|
|
|
import 'bootstrap/dist/css/bootstrap.css';
|
2018-01-12 16:33:16 -05:00
|
|
|
import './dapp.css';
|
|
|
|
|
2018-04-23 16:42:52 -04:00
|
|
|
class App extends React.Component {
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
2015-05-24 09:07:19 -04:00
|
|
|
|
2018-04-23 16:42:52 -04:00
|
|
|
this.state = {
|
2018-08-24 10:05:48 -04:00
|
|
|
error: null,
|
2019-08-23 11:51:03 -04:00
|
|
|
activeKey: '1',
|
2018-04-24 16:21:33 -04:00
|
|
|
whisperEnabled: false,
|
2018-09-11 09:11:22 +01:00
|
|
|
storageEnabled: false,
|
2018-10-23 11:39:14 -04:00
|
|
|
blockchainEnabled: false
|
2018-07-11 13:11:55 -04:00
|
|
|
};
|
2018-04-23 16:42:52 -04:00
|
|
|
}
|
2017-10-25 06:19:24 -04:00
|
|
|
|
2018-07-11 13:11:55 -04:00
|
|
|
componentDidMount() {
|
2019-02-22 14:10:53 -05:00
|
|
|
EmbarkJS.onReady((err) => {
|
2018-09-11 09:11:22 +01:00
|
|
|
this.setState({blockchainEnabled: true});
|
2018-08-23 16:09:47 -04:00
|
|
|
if (err) {
|
|
|
|
// If err is not null then it means something went wrong connecting to ethereum
|
|
|
|
// you can use this to ask the user to enable metamask for e.g
|
2018-09-11 17:10:36 -04:00
|
|
|
return this.setState({error: err.message || err});
|
2018-08-23 16:09:47 -04:00
|
|
|
}
|
2018-09-14 18:39:47 -04:00
|
|
|
|
2019-06-28 12:57:23 +02:00
|
|
|
EmbarkJS.Messages.isAvailable().then(result => {
|
|
|
|
this.setState({whisperEnabled: result});
|
2018-09-14 18:39:47 -04:00
|
|
|
});
|
2018-08-22 10:11:57 +01:00
|
|
|
|
|
|
|
EmbarkJS.Storage.isAvailable().then((result) => {
|
|
|
|
this.setState({storageEnabled: result});
|
|
|
|
}).catch(() => {
|
|
|
|
this.setState({storageEnabled: false});
|
|
|
|
});
|
2017-01-26 06:29:17 -05:00
|
|
|
});
|
2018-04-23 16:42:52 -04:00
|
|
|
}
|
2017-01-26 06:29:17 -05:00
|
|
|
|
2018-07-11 13:11:55 -04:00
|
|
|
_renderStatus(title, available) {
|
2018-04-23 16:42:52 -04:00
|
|
|
let className = available ? 'pull-right status-online' : 'pull-right status-offline';
|
|
|
|
return <React.Fragment>
|
2018-07-11 13:11:55 -04:00
|
|
|
{title}
|
2019-08-26 11:12:42 -04:00
|
|
|
<span className={className}/>
|
2018-04-23 16:42:52 -04:00
|
|
|
</React.Fragment>;
|
2017-10-25 06:19:24 -04:00
|
|
|
}
|
2017-01-26 06:29:17 -05:00
|
|
|
|
2018-07-30 12:49:03 +01:00
|
|
|
handleSelect(key) {
|
2019-08-23 11:51:03 -04:00
|
|
|
this.setState({activeKey: key});
|
2018-07-30 12:49:03 +01:00
|
|
|
}
|
|
|
|
|
2018-07-11 13:11:55 -04:00
|
|
|
render() {
|
2018-08-29 10:22:43 +01:00
|
|
|
const ensEnabled = EmbarkJS.Names.currentNameSystems && EmbarkJS.Names.isAvailable();
|
2018-08-23 16:09:47 -04:00
|
|
|
if (this.state.error) {
|
|
|
|
return (<div>
|
2019-08-23 11:51:03 -04:00
|
|
|
<div>Something went wrong connecting to ethereum. Please make sure you have a node running or are using metamask
|
|
|
|
to connect to the ethereum network:
|
|
|
|
</div>
|
2018-08-23 16:09:47 -04:00
|
|
|
<div>{this.state.error}</div>
|
|
|
|
</div>);
|
2018-08-23 16:23:00 -04:00
|
|
|
}
|
2018-08-23 16:09:47 -04:00
|
|
|
return (<div>
|
|
|
|
<h3>Embark - Usage Example</h3>
|
2019-08-23 11:51:03 -04:00
|
|
|
<Nav tabs>
|
|
|
|
<NavItem>
|
|
|
|
<NavLink onClick={() => this.handleSelect('1')} className={classnames({ active: this.state.activeKey === '1' })}>
|
|
|
|
{this._renderStatus('Blockchain', this.state.blockchainEnabled)}
|
|
|
|
</NavLink>
|
|
|
|
</NavItem>
|
|
|
|
<NavItem>
|
|
|
|
<NavLink onClick={() => this.handleSelect('2')} className={classnames({ active: this.state.activeKey === '2' })}>
|
|
|
|
{this._renderStatus('Decentralized Storage', this.state.storageEnabled)}
|
|
|
|
</NavLink>
|
|
|
|
</NavItem>
|
|
|
|
<NavItem>
|
|
|
|
<NavLink onClick={() => this.handleSelect('3')} className={classnames({ active: this.state.activeKey === '3' })}>
|
|
|
|
{this._renderStatus('P2P communication (Whisper)', this.state.whisperEnabled)}
|
|
|
|
</NavLink>
|
|
|
|
</NavItem>
|
|
|
|
<NavItem>
|
|
|
|
<NavLink onClick={() => this.handleSelect('4')} className={classnames({ active: this.state.activeKey === '4' })}>
|
|
|
|
{this._renderStatus('Naming (ENS)', ensEnabled)}
|
|
|
|
</NavLink>
|
|
|
|
</NavItem>
|
|
|
|
</Nav>
|
|
|
|
<TabContent activeTab={this.state.activeKey}>
|
|
|
|
<TabPane tabId="1">
|
2018-07-11 13:11:55 -04:00
|
|
|
<Blockchain/>
|
2019-08-23 11:51:03 -04:00
|
|
|
</TabPane>
|
|
|
|
<TabPane tabId="2">
|
2018-07-11 13:11:55 -04:00
|
|
|
<Storage enabled={this.state.storageEnabled}/>
|
2019-08-23 11:51:03 -04:00
|
|
|
</TabPane>
|
|
|
|
<TabPane tabId="3">
|
2018-07-11 13:11:55 -04:00
|
|
|
<Whisper enabled={this.state.whisperEnabled}/>
|
2019-08-23 11:51:03 -04:00
|
|
|
</TabPane>
|
|
|
|
<TabPane tabId="4">
|
2018-08-29 10:22:43 +01:00
|
|
|
<ENS enabled={ensEnabled}/>
|
2019-08-23 11:51:03 -04:00
|
|
|
</TabPane>
|
|
|
|
</TabContent>
|
2018-04-23 16:42:52 -04:00
|
|
|
</div>);
|
|
|
|
}
|
|
|
|
}
|
2017-01-26 06:29:17 -05:00
|
|
|
|
2019-08-23 11:51:03 -04:00
|
|
|
ReactDOM.render(<App/>, document.getElementById('app'));
|