blob: 0b4ba136e5419960e5dc969b8f6c9f38fb7dc4b6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
import React from 'react'
import { Button, Glyphicon, Alert } from 'react-bootstrap'
import SectionLayout from './section_layout'
import Login from 'components/login'
import Spinner from 'components/spinner'
import Account from 'models/account'
import bitmask from 'lib/bitmask'
export default class UserSection extends React.Component {
static get defaultProps() {return{
account: null,
onLogout: null,
onLogin: null
}}
constructor(props) {
super(props)
this.state = {
error: null,
loading: false
}
this.logout = this.logout.bind(this)
}
logout() {
this.setState({loading: true})
this.props.account.logout().then(
account => {
this.setState({error: null, loading: false})
if (this.props.onLogout) {
this.props.onLogout(account)
}
}, error => {
this.setState({error: error, loading: false})
}
)
}
render () {
let message = null
if (this.state.error) {
// style may be: success, warning, danger, info
message = (
<Alert bsStyle="danger">{this.state.error}</Alert>
)
}
if (this.props.account.authenticated) {
let button = null
if (this.state.loading) {
button = <Button disabled={true}><Spinner /></Button>
} else {
button = <Button onClick={this.logout}>Log Out</Button>
}
return (
<SectionLayout icon="user" buttons={button} status="on">
<h1>{this.props.account.address}</h1>
{message}
</SectionLayout>
)
} else {
return (
<SectionLayout icon="user" className="wide-margin">
<Login onLogin={this.props.onLogin} domain={this.props.account.domain} />
</SectionLayout>
)
}
}
}
|