/* global web3 */
import React from 'react';
import ReactDOM from 'react-dom';
import EmbarkJS from 'Embark/EmbarkJS';
import Ranking from '../embarkArtifacts/contracts/Ranking';
import Phoenix from 'phoenix';
import withObservables from '@nozbe/with-observables'
const {scan} = require('rxjs/operators');
import { of } from 'rxjs';
const phoenix = new Phoenix(web3);
const RankItem = ({votes, onUpvote, onDownvote}) => (
1 - 0x00000000000000000000000000001
Upvotes: {votes.upvotes} - Downvotes: {votes.downvotes}
|
);
const enhance = withObservables(['votes'], ({ votes }) => ({votes: votes || of({ /* default empty object */ })}));
const EnhancedRankItem = enhance(RankItem)
const observables = {};
class App extends React.Component {
state = {
ready: false,
observable: null
}
componentDidMount(){
EmbarkJS.onReady((err) => {
if(err){
console.error(err);
return;
}
phoenix.init(() => {
observables.votes = phoenix.trackEvent(Ranking, 'Rating', {filter: {}, fromBlock: 1}).pipe(
scan((acc, curr) => {
if(curr.rating >= 3){
acc.upvotes++;
} else {
acc.downvotes++;
}
return acc;
}, {upvotes: 0, downvotes: 0})
);
this.setState({ready: true});
});
});
}
upvote = () => {
Ranking.methods.rate("0x0000000000000000000000000000000000000001", 5).send();
}
downvote = () => {
Ranking.methods.rate("0x0000000000000000000000000000000000000001", 1).send();
}
render() {
const {ready, observable} = this.state;
if(!ready) return Loading...;
return ;
}
}
ReactDOM.render(, document.getElementById('content'));