93 lines
2.7 KiB
JavaScript
Raw Normal View History

import React from 'react';
import ReactDOM from 'react-dom';
2018-07-11 13:11:55 -04:00
import {Tabs, Tab} from 'react-bootstrap';
2018-01-03 12:42:48 -05:00
import EmbarkJS from 'Embark/EmbarkJS';
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
2018-01-12 16:33:16 -05:00
import './dapp.css';
class App extends React.Component {
constructor(props) {
super(props);
2015-05-24 09:07:19 -04:00
2018-07-30 12:49:03 +01:00
this.handleSelect = this.handleSelect.bind(this);
this.state = {
2018-07-30 12:49:03 +01:00
activeKey: 1,
2018-04-24 16:21:33 -04:00
whisperEnabled: false,
2018-07-11 13:11:55 -04:00
storageEnabled: false,
2018-07-30 12:52:48 +01:00
ensEnabled: false
2018-07-11 13:11:55 -04:00
};
}
2017-10-25 06:19:24 -04:00
2018-07-11 13:11:55 -04:00
componentDidMount() {
EmbarkJS.onReady(() => {
2018-04-25 20:11:15 -04:00
if (EmbarkJS.isNewWeb3()) {
2018-07-11 13:11:55 -04:00
EmbarkJS.Messages.Providers.whisper.getWhisperVersion((err, _version) => {
if (err) {
return console.log(err);
}
this.setState({whisperEnabled: true});
2018-04-25 20:11:15 -04:00
});
} else {
if (EmbarkJS.Messages.providerName === 'whisper') {
2018-07-11 13:11:55 -04:00
EmbarkJS.Messages.getWhisperVersion((err, _version) => {
if (err) {
return console.log(err);
}
this.setState({whisperEnabled: true});
2018-04-25 20:11:15 -04:00
});
}
}
2018-04-27 11:47:35 -04:00
this.setState({
2018-07-30 12:49:03 +01:00
storageEnabled: EmbarkJS.Storage.isAvailable(),
ensEnabled: EmbarkJS.Names.isAvailable(),
ensNameSystems: EmbarkJS.Names.currentNameSystems
2018-04-27 11:47:35 -04:00
});
2017-01-26 06:29:17 -05:00
});
}
2017-01-26 06:29:17 -05:00
2018-07-11 13:11:55 -04:00
_renderStatus(title, available) {
let className = available ? 'pull-right status-online' : 'pull-right status-offline';
return <React.Fragment>
2018-07-11 13:11:55 -04:00
{title}
<span className={className}></span>
</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) {
2018-07-30 17:06:20 +01:00
if (key === 2) {
2018-07-30 12:49:03 +01:00
EmbarkJS.Names.setProvider('ipns', {server: 'localhost', port: '5001'});
2018-07-30 17:06:20 +01:00
} else if (key === 4) {
2018-07-30 12:49:03 +01:00
EmbarkJS.Names.currentNameSystems = this.state.ensNameSystems
}
this.setState({ activeKey: key });
}
2018-07-11 13:11:55 -04:00
render() {
return (<div><h3>Embark - Usage Example</h3>
2018-07-30 12:49:03 +01:00
<Tabs onSelect={this.handleSelect} activeKey={this.state.activeKey} id="uncontrolled-tab-example">
<Tab eventKey={1} title="Blockchain">
2018-07-11 13:11:55 -04:00
<Blockchain/>
</Tab>
2018-04-24 16:21:33 -04:00
<Tab eventKey={2} title={this._renderStatus('Decentralized Storage', this.state.storageEnabled)}>
2018-07-11 13:11:55 -04:00
<Storage enabled={this.state.storageEnabled}/>
</Tab>
2018-07-11 13:11:55 -04:00
<Tab eventKey={3} title={this._renderStatus('P2P communication (Whisper)', this.state.whisperEnabled)}>
<Whisper enabled={this.state.whisperEnabled}/>
</Tab>
<Tab eventKey={4} title={this._renderStatus('Naming (ENS)', this.state.ensEnabled)}>
<ENS enabled={this.state.ensEnabled}/>
</Tab>
</Tabs>
</div>);
}
}
2017-01-26 06:29:17 -05:00
ReactDOM.render(<App></App>, document.getElementById('app'));