lbry-desktop/ui/js/component/reward-link.js

91 lines
2.2 KiB
JavaScript
Raw Normal View History

2017-05-02 12:31:51 +07:00
import React from 'react';
import lbry from 'lbry'
import {Icon} from 'component/common';
import Modal from 'component/modal';
import rewards from 'rewards';
import Link from 'component/link'
2017-05-17 04:10:25 -04:00
export class RewardLink extends React.Component {
static propTypes = {
2017-05-02 12:31:51 +07:00
type: React.PropTypes.string.isRequired,
claimed: React.PropTypes.bool,
onRewardClaim: React.PropTypes.func,
onRewardFailure: React.PropTypes.func
2017-05-17 04:10:25 -04:00
}
constructor(props) {
super(props);
this.state = {
claimable: true,
pending: false,
errorMessage: null
};
}
refreshClaimable() {
2017-05-02 12:31:51 +07:00
switch(this.props.type) {
case 'new_user':
this.setState({ claimable: true });
return;
case 'first_publish':
2017-05-21 10:42:34 -04:00
lbry.claim_list_mine().then((list) => {
2017-05-02 12:31:51 +07:00
this.setState({
claimable: list.length > 0
})
2017-05-21 10:42:34 -04:00
});
2017-05-02 12:31:51 +07:00
return;
}
2017-05-17 04:10:25 -04:00
}
componentWillMount() {
2017-05-02 12:31:51 +07:00
this.refreshClaimable();
2017-05-17 04:10:25 -04:00
}
claimReward() {
2017-05-02 12:31:51 +07:00
this.setState({
pending: true
})
2017-05-19 12:17:19 -04:00
2017-05-02 12:31:51 +07:00
rewards.claimReward(this.props.type).then((reward) => {
this.setState({
pending: false,
errorMessage: null
})
if (this.props.onRewardClaim) {
this.props.onRewardClaim(reward);
}
}).catch((error) => {
this.setState({
errorMessage: error.message,
pending: false
})
})
2017-05-17 04:10:25 -04:00
}
clearError() {
2017-05-02 12:31:51 +07:00
if (this.props.onRewardFailure) {
this.props.onRewardFailure()
}
this.setState({
errorMessage: null
})
2017-05-17 04:10:25 -04:00
}
render() {
2017-05-02 12:31:51 +07:00
return (
<div className="reward-link">
{this.props.claimed
? <span><Icon icon="icon-check" /> Reward claimed.</span>
: <Link button={this.props.button ? this.props.button : 'alt'} disabled={this.state.pending || !this.state.claimable }
label={ this.state.pending ? "Claiming..." : "Claim Reward"} onClick={() => { this.claimReward() }} />}
2017-05-02 12:31:51 +07:00
{this.state.errorMessage ?
<Modal isOpen={true} contentLabel="Reward Claim Error" className="error-modal" onConfirmed={() => { this.clearError() }}>
2017-05-02 12:31:51 +07:00
{this.state.errorMessage}
</Modal>
: ''}
</div>
);
}
2017-05-17 04:10:25 -04:00
}