2022-01-14 16:21:42 +00:00
|
|
|
import React, { Component } from 'react'
|
2022-02-01 22:05:49 +00:00
|
|
|
import {Badge, Tooltip, TextField, ListItemAvatar, Avatar,Paper, Grid, IconButton, Typography, Select, MenuItem, List, ListItemText, ListItem, ListItemIcon, ListItemButton, Divider, Dialog, DialogContent} from "@mui/material";
|
2022-01-28 14:30:45 +00:00
|
|
|
import MediaQuery from 'react-responsive'
|
2022-01-31 12:53:20 +00:00
|
|
|
import { Link } from 'react-router-dom'
|
2022-01-14 16:21:42 +00:00
|
|
|
|
|
|
|
// Icons
|
|
|
|
import SettingsIcon from '@mui/icons-material/Settings';
|
2022-01-15 10:21:36 +00:00
|
|
|
import PeopleIcon from '@mui/icons-material/People';
|
2022-01-14 16:21:42 +00:00
|
|
|
import InventoryIcon from '@mui/icons-material/Inventory';
|
|
|
|
import SellIcon from '@mui/icons-material/Sell';
|
|
|
|
import SmartToyIcon from '@mui/icons-material/SmartToy';
|
|
|
|
import PercentIcon from '@mui/icons-material/Percent';
|
2022-01-14 17:35:27 +00:00
|
|
|
import PriceChangeIcon from '@mui/icons-material/PriceChange';
|
2022-01-15 00:28:19 +00:00
|
|
|
import BoltIcon from '@mui/icons-material/Bolt';
|
|
|
|
import GitHubIcon from '@mui/icons-material/GitHub';
|
|
|
|
import EqualizerIcon from '@mui/icons-material/Equalizer';
|
2022-01-15 10:21:36 +00:00
|
|
|
import SendIcon from '@mui/icons-material/Send';
|
2022-01-15 15:45:44 +00:00
|
|
|
import PublicIcon from '@mui/icons-material/Public';
|
2022-01-29 19:51:26 +00:00
|
|
|
import NumbersIcon from '@mui/icons-material/Numbers';
|
2022-01-29 20:17:30 +00:00
|
|
|
import PasswordIcon from '@mui/icons-material/Password';
|
2022-01-30 15:18:03 +00:00
|
|
|
import ContentCopy from "@mui/icons-material/ContentCopy";
|
2022-01-14 16:21:42 +00:00
|
|
|
|
2022-01-26 18:45:24 +00:00
|
|
|
// pretty numbers
|
|
|
|
function pn(x) {
|
|
|
|
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
|
|
|
|
}
|
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
export default class BottomBar extends Component {
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
this.state = {
|
2022-01-15 00:28:19 +00:00
|
|
|
openStatsForNerds: false,
|
2022-01-15 10:21:36 +00:00
|
|
|
openCommuniy: false,
|
2022-01-28 14:30:45 +00:00
|
|
|
openExchangeSummary:false,
|
2022-01-18 17:52:48 +00:00
|
|
|
num_public_buy_orders: 0,
|
|
|
|
num_public_sell_orders: 0,
|
|
|
|
active_robots_today: 0,
|
|
|
|
fee: 0,
|
|
|
|
today_avg_nonkyc_btc_premium: 0,
|
|
|
|
today_total_volume: 0,
|
2022-01-26 18:45:24 +00:00
|
|
|
lifetime_satoshis_settled: 0,
|
2022-01-27 22:51:57 +00:00
|
|
|
robosats_running_commit_hash: '000000000000000',
|
2022-01-29 19:51:26 +00:00
|
|
|
openProfile: false,
|
|
|
|
profileShown: false,
|
2022-01-14 16:21:42 +00:00
|
|
|
};
|
|
|
|
this.getInfo();
|
|
|
|
}
|
2022-01-29 19:51:26 +00:00
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
handleClickSuppport = () => {
|
|
|
|
window.open("https://t.me/robosats");
|
|
|
|
};
|
|
|
|
|
|
|
|
getInfo() {
|
|
|
|
this.setState(null)
|
|
|
|
fetch('/api/info/')
|
|
|
|
.then((response) => response.json())
|
2022-01-29 19:51:26 +00:00
|
|
|
.then((data) => this.setState(data) &
|
2022-02-01 19:43:33 +00:00
|
|
|
this.props.setAppState({nickname:data.nickname, loading:false}));
|
2022-01-14 16:21:42 +00:00
|
|
|
}
|
|
|
|
|
2022-01-15 00:28:19 +00:00
|
|
|
handleClickOpenStatsForNerds = () => {
|
2022-01-15 10:21:36 +00:00
|
|
|
this.setState({openStatsForNerds: true});
|
2022-01-15 00:28:19 +00:00
|
|
|
};
|
2022-01-27 22:51:57 +00:00
|
|
|
|
2022-01-15 00:28:19 +00:00
|
|
|
handleClickCloseStatsForNerds = () => {
|
2022-01-15 10:21:36 +00:00
|
|
|
this.setState({openStatsForNerds: false});
|
2022-01-15 00:28:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
StatsDialog =() =>{
|
2022-01-28 14:30:45 +00:00
|
|
|
|
2022-01-15 00:28:19 +00:00
|
|
|
return(
|
|
|
|
<Dialog
|
|
|
|
open={this.state.openStatsForNerds}
|
|
|
|
onClose={this.handleClickCloseStatsForNerds}
|
|
|
|
aria-labelledby="stats-for-nerds-dialog-title"
|
|
|
|
aria-describedby="stats-for-nerds-description"
|
|
|
|
>
|
|
|
|
<DialogContent>
|
|
|
|
<Typography component="h5" variant="h5">Stats For Nerds</Typography>
|
2022-01-26 18:45:24 +00:00
|
|
|
<List dense>
|
2022-01-15 00:28:19 +00:00
|
|
|
<Divider/>
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon><BoltIcon/></ListItemIcon>
|
|
|
|
<ListItemText primary={this.state.lnd_version} secondary="LND version"/>
|
|
|
|
</ListItem>
|
2022-01-15 15:45:44 +00:00
|
|
|
|
2022-01-15 00:28:19 +00:00
|
|
|
<Divider/>
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon><GitHubIcon/></ListItemIcon>
|
2022-01-25 14:46:02 +00:00
|
|
|
<ListItemText secondary="Currently running commit hash">
|
2022-01-15 00:28:19 +00:00
|
|
|
<a href={"https://github.com/Reckless-Satoshi/robosats/tree/"
|
2022-01-27 22:51:57 +00:00
|
|
|
+ this.state.robosats_running_commit_hash}>{this.state.robosats_running_commit_hash.slice(0, 12)+"..."}
|
2022-01-15 00:28:19 +00:00
|
|
|
</a>
|
|
|
|
</ListItemText>
|
|
|
|
</ListItem>
|
2022-01-15 15:45:44 +00:00
|
|
|
|
2022-01-15 00:28:19 +00:00
|
|
|
<Divider/>
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon><EqualizerIcon/></ListItemIcon>
|
2022-01-15 14:22:07 +00:00
|
|
|
<ListItemText primary={this.state.today_total_volume+" BTC"} secondary="Today traded volume"/>
|
2022-01-15 00:28:19 +00:00
|
|
|
</ListItem>
|
2022-01-15 15:45:44 +00:00
|
|
|
|
2022-01-26 18:45:24 +00:00
|
|
|
<Divider/>
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon><EqualizerIcon/></ListItemIcon>
|
|
|
|
<ListItemText primary={pn(this.state.lifetime_satoshis_settled)+" Sats"} secondary="Lifetime settled volume"/>
|
|
|
|
</ListItem>
|
|
|
|
|
2022-01-15 15:45:44 +00:00
|
|
|
<Divider/>
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon><PublicIcon/></ListItemIcon>
|
|
|
|
<ListItemText primary="Made with ❤️ and ⚡" secondary="... somewhere on Earth!"/>
|
|
|
|
</ListItem>
|
2022-01-15 00:28:19 +00:00
|
|
|
</List>
|
2022-01-15 15:45:44 +00:00
|
|
|
|
2022-01-15 00:28:19 +00:00
|
|
|
</DialogContent>
|
|
|
|
</Dialog>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-01-15 10:21:36 +00:00
|
|
|
handleClickOpenCommunity = () => {
|
|
|
|
this.setState({openCommuniy: true});
|
|
|
|
};
|
|
|
|
handleClickCloseCommunity = () => {
|
|
|
|
this.setState({openCommuniy: false});
|
|
|
|
};
|
|
|
|
|
|
|
|
CommunityDialog =() =>{
|
2022-01-28 14:30:45 +00:00
|
|
|
|
2022-01-15 10:21:36 +00:00
|
|
|
return(
|
|
|
|
<Dialog
|
|
|
|
open={this.state.openCommuniy}
|
|
|
|
onClose={this.handleClickCloseCommunity}
|
|
|
|
aria-labelledby="community-dialog-title"
|
|
|
|
aria-describedby="community-description"
|
|
|
|
>
|
|
|
|
<DialogContent>
|
|
|
|
<Typography component="h5" variant="h5">Community</Typography>
|
|
|
|
<Typography component="body2" variant="body2">
|
|
|
|
<p> Support is only offered via public channels.
|
2022-01-17 16:41:55 +00:00
|
|
|
Join our Telegram community if you have
|
2022-01-15 15:45:44 +00:00
|
|
|
questions or want to hang out with other cool robots.
|
2022-01-17 16:41:55 +00:00
|
|
|
Please, use our Github Issues if you find a bug or want
|
|
|
|
to see new features!
|
2022-01-15 10:21:36 +00:00
|
|
|
</p>
|
|
|
|
</Typography>
|
|
|
|
<List>
|
|
|
|
<Divider/>
|
|
|
|
|
|
|
|
<ListItemButton component="a" href="https://t.me/robosats">
|
|
|
|
<ListItemIcon><SendIcon/></ListItemIcon>
|
|
|
|
<ListItemText primary="Join the RoboSats group"
|
|
|
|
secondary="Telegram (English / Main)"/>
|
|
|
|
</ListItemButton>
|
|
|
|
<Divider/>
|
|
|
|
|
|
|
|
<ListItemButton component="a" href="https://t.me/robosats_es">
|
|
|
|
<ListItemIcon><SendIcon/></ListItemIcon>
|
|
|
|
<ListItemText primary="Unase al grupo RoboSats"
|
|
|
|
secondary="Telegram (Español)"/>
|
|
|
|
</ListItemButton>
|
|
|
|
<Divider/>
|
|
|
|
|
|
|
|
<ListItemButton component="a" href="https://github.com/Reckless-Satoshi/robosats/issues">
|
|
|
|
<ListItemIcon><GitHubIcon/></ListItemIcon>
|
|
|
|
<ListItemText primary="Tell us about a new feature or a bug"
|
|
|
|
secondary="Github Issues - The Robotic Satoshis Open Source Project"/>
|
|
|
|
</ListItemButton>
|
|
|
|
|
|
|
|
</List>
|
|
|
|
</DialogContent>
|
|
|
|
</Dialog>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
handleClickOpenProfile = () => {
|
|
|
|
this.getInfo();
|
|
|
|
this.setState({openProfile: true, profileShown: true});
|
|
|
|
};
|
|
|
|
handleClickCloseProfile = () => {
|
|
|
|
this.setState({openProfile: false});
|
|
|
|
};
|
|
|
|
|
|
|
|
dialogProfile =() =>{
|
|
|
|
return(
|
|
|
|
<Dialog
|
|
|
|
open={this.state.openProfile}
|
|
|
|
onClose={this.handleClickCloseProfile}
|
|
|
|
aria-labelledby="profile-title"
|
|
|
|
aria-describedby="profile-description"
|
|
|
|
>
|
|
|
|
<DialogContent>
|
|
|
|
<Typography component="h5" variant="h5">Your Profile</Typography>
|
|
|
|
<List>
|
|
|
|
<Divider/>
|
|
|
|
<ListItem className="profileNickname">
|
2022-01-29 20:17:30 +00:00
|
|
|
<ListItemText secondary="Your robot">
|
2022-01-29 19:51:26 +00:00
|
|
|
<Typography component="h6" variant="h6">
|
|
|
|
{this.props.nickname ? "⚡"+this.props.nickname+"⚡" : ""}
|
|
|
|
</Typography>
|
|
|
|
</ListItemText>
|
|
|
|
<ListItemAvatar>
|
2022-01-30 15:18:03 +00:00
|
|
|
<Avatar className='profileAvatar'
|
2022-01-29 19:51:26 +00:00
|
|
|
sx={{ width: 65, height:65 }}
|
2022-02-01 19:43:33 +00:00
|
|
|
alt={this.props.nickname}
|
2022-01-29 19:51:26 +00:00
|
|
|
src={this.props.nickname ? window.location.origin +'/static/assets/avatars/' + this.props.nickname + '.png' : null}
|
|
|
|
/>
|
|
|
|
</ListItemAvatar>
|
|
|
|
</ListItem>
|
|
|
|
<Divider/>
|
|
|
|
{this.state.active_order_id ?
|
|
|
|
// TODO Link to router and do this.props.history.push
|
2022-01-31 12:53:20 +00:00
|
|
|
<ListItemButton onClick={this.handleClickCloseProfile} to={'/order/'+this.state.active_order_id} component={Link}>
|
2022-01-29 19:51:26 +00:00
|
|
|
<ListItemIcon>
|
2022-01-30 13:18:32 +00:00
|
|
|
<Badge badgeContent="" color="primary">
|
|
|
|
<NumbersIcon color="primary"/>
|
|
|
|
</Badge>
|
2022-01-29 19:51:26 +00:00
|
|
|
</ListItemIcon>
|
2022-01-29 20:17:30 +00:00
|
|
|
<ListItemText primary={'One active order #'+this.state.active_order_id} secondary="Your current order"/>
|
2022-01-29 19:51:26 +00:00
|
|
|
</ListItemButton>
|
|
|
|
:
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon><NumbersIcon/></ListItemIcon>
|
2022-01-29 20:29:33 +00:00
|
|
|
<ListItemText primary="No active orders" secondary="Your current order"/>
|
2022-01-29 19:51:26 +00:00
|
|
|
</ListItem>
|
|
|
|
}
|
2022-01-29 20:17:30 +00:00
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon>
|
|
|
|
<PasswordIcon/>
|
|
|
|
</ListItemIcon>
|
2022-01-30 15:18:03 +00:00
|
|
|
<ListItemText secondary="Your token">
|
2022-01-29 20:17:30 +00:00
|
|
|
{this.props.token ?
|
|
|
|
<TextField
|
|
|
|
disabled
|
|
|
|
label='Store safely'
|
|
|
|
value={this.props.token }
|
|
|
|
variant='filled'
|
2022-01-30 15:18:03 +00:00
|
|
|
size='small'
|
|
|
|
InputProps={{
|
|
|
|
endAdornment:
|
|
|
|
<IconButton onClick= {()=>navigator.clipboard.writeText(this.props.token)}>
|
|
|
|
<ContentCopy />
|
|
|
|
</IconButton>,
|
|
|
|
}}
|
|
|
|
/>
|
2022-01-29 20:17:30 +00:00
|
|
|
:
|
|
|
|
'Cannot remember'}
|
|
|
|
</ListItemText>
|
|
|
|
</ListItem>
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
</List>
|
|
|
|
</DialogContent>
|
|
|
|
|
|
|
|
</Dialog>
|
|
|
|
)
|
|
|
|
}
|
2022-01-15 10:21:36 +00:00
|
|
|
|
2022-01-28 14:30:45 +00:00
|
|
|
bottomBarDesktop =()=>{
|
|
|
|
return(
|
|
|
|
<Paper elevation={6} style={{height:40}}>
|
2022-01-15 00:28:19 +00:00
|
|
|
<this.StatsDialog/>
|
2022-01-15 10:21:36 +00:00
|
|
|
<this.CommunityDialog/>
|
2022-01-29 19:51:26 +00:00
|
|
|
<this.dialogProfile/>
|
2022-01-14 16:21:42 +00:00
|
|
|
<Grid container xs={12}>
|
2022-01-14 17:35:27 +00:00
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={2}>
|
2022-02-01 22:05:49 +00:00
|
|
|
<div style={{display: this.props.avatarLoaded ? '':'none'}}>
|
2022-01-29 19:51:26 +00:00
|
|
|
<ListItemButton onClick={this.handleClickOpenProfile} >
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip open={(this.state.active_order_id > 0 & !this.state.profileShown & this.props.avatarLoaded) ? true: false}
|
|
|
|
title="You have an active order">
|
2022-01-29 19:51:26 +00:00
|
|
|
<ListItemAvatar sx={{ width: 30, height: 30 }} >
|
2022-01-30 13:18:32 +00:00
|
|
|
<Badge badgeContent={(this.state.active_order_id > 0 & !this.state.profileShown) ? "": null} color="primary">
|
2022-01-30 15:18:03 +00:00
|
|
|
<Avatar className='flippedSmallAvatar' sx={{margin: 0, top: -13}}
|
2022-01-29 19:51:26 +00:00
|
|
|
alt={this.props.nickname}
|
2022-02-01 22:05:49 +00:00
|
|
|
imgProps={{
|
|
|
|
onLoad:() => this.props.setAppState({avatarLoaded: true}),
|
|
|
|
}}
|
|
|
|
src={this.props.nickname ? window.location.origin +'/static/assets/avatars/' + this.props.nickname + '.png' : null}
|
2022-01-29 19:51:26 +00:00
|
|
|
/>
|
|
|
|
</Badge>
|
|
|
|
</ListItemAvatar>
|
2022-02-01 22:05:49 +00:00
|
|
|
</Tooltip>
|
|
|
|
<ListItemText primary={this.props.nickname}/>
|
|
|
|
</ListItemButton>
|
|
|
|
</div>
|
2022-01-14 16:21:42 +00:00
|
|
|
</Grid>
|
2022-01-14 17:35:27 +00:00
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
<Grid item xs={2}>
|
|
|
|
<ListItem className="bottomItem">
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<InventoryIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.num_public_buy_orders}
|
|
|
|
secondary="Public Buy Orders" />
|
|
|
|
</ListItem>
|
|
|
|
</Grid>
|
2022-01-14 17:35:27 +00:00
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
<Grid item xs={2}>
|
|
|
|
<ListItem className="bottomItem">
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<SellIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.num_public_sell_orders}
|
|
|
|
secondary="Public Sell Orders" />
|
|
|
|
</ListItem>
|
|
|
|
</Grid>
|
2022-01-14 17:35:27 +00:00
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
<Grid item xs={2}>
|
|
|
|
<ListItem className="bottomItem">
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<SmartToyIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
2022-01-18 17:52:48 +00:00
|
|
|
primary={this.state.active_robots_today}
|
|
|
|
secondary="Today Active Robots" />
|
2022-01-14 16:21:42 +00:00
|
|
|
</ListItem>
|
|
|
|
</Grid>
|
2022-01-14 17:35:27 +00:00
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
<Grid item xs={2}>
|
|
|
|
<ListItem className="bottomItem">
|
|
|
|
<ListItemIcon size="small">
|
2022-01-14 17:35:27 +00:00
|
|
|
<PriceChangeIcon/>
|
2022-01-14 16:21:42 +00:00
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
2022-01-15 14:22:07 +00:00
|
|
|
primary={this.state.today_avg_nonkyc_btc_premium+"%"}
|
2022-01-28 14:30:45 +00:00
|
|
|
secondary="Today Avg Premium" />
|
2022-01-14 16:21:42 +00:00
|
|
|
</ListItem>
|
|
|
|
</Grid>
|
2022-01-14 17:35:27 +00:00
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={1}>
|
2022-01-14 17:35:27 +00:00
|
|
|
<ListItem className="bottomItem">
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<PercentIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.fee*100}
|
2022-01-29 19:51:26 +00:00
|
|
|
secondary="Trade Fee" />
|
2022-01-14 17:35:27 +00:00
|
|
|
</ListItem>
|
|
|
|
</Grid>
|
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
<Grid container item xs={1}>
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={6}>
|
2022-01-14 16:21:42 +00:00
|
|
|
<Select
|
|
|
|
size = 'small'
|
|
|
|
defaultValue={1}
|
|
|
|
inputProps={{
|
|
|
|
style: {textAlign:"center"}
|
|
|
|
}}>
|
|
|
|
<MenuItem value={1}>EN</MenuItem>
|
|
|
|
</Select>
|
|
|
|
</Grid>
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={3}>
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip enterTouchDelay="250" title="Show community and support links">
|
2022-01-15 10:21:36 +00:00
|
|
|
<IconButton
|
|
|
|
color="primary"
|
2022-01-29 19:51:26 +00:00
|
|
|
aria-label="Community"
|
2022-01-15 10:21:36 +00:00
|
|
|
onClick={this.handleClickOpenCommunity} >
|
|
|
|
<PeopleIcon />
|
2022-01-14 16:21:42 +00:00
|
|
|
</IconButton>
|
2022-02-01 22:05:49 +00:00
|
|
|
</Tooltip>
|
2022-01-14 16:21:42 +00:00
|
|
|
</Grid>
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={3}>
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip enterTouchDelay="250" title="Show stats for nerds">
|
|
|
|
<IconButton color="primary"
|
|
|
|
aria-label="Stats for Nerds"
|
|
|
|
onClick={this.handleClickOpenStatsForNerds} >
|
|
|
|
<SettingsIcon />
|
|
|
|
</IconButton>
|
|
|
|
</Tooltip>
|
2022-01-29 19:51:26 +00:00
|
|
|
</Grid>
|
2022-01-14 17:35:27 +00:00
|
|
|
|
2022-01-14 16:21:42 +00:00
|
|
|
</Grid>
|
|
|
|
</Grid>
|
|
|
|
</Paper>
|
2022-01-28 14:30:45 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
handleClickOpenExchangeSummary = () => {
|
2022-01-29 19:51:26 +00:00
|
|
|
this.getInfo();
|
2022-01-28 14:30:45 +00:00
|
|
|
this.setState({openExchangeSummary: true});
|
|
|
|
};
|
|
|
|
handleClickCloseExchangeSummary = () => {
|
|
|
|
this.setState({openExchangeSummary: false});
|
|
|
|
};
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
exchangeSummaryDialogPhone =() =>{
|
2022-01-28 14:30:45 +00:00
|
|
|
return(
|
|
|
|
<Dialog
|
|
|
|
open={this.state.openExchangeSummary}
|
|
|
|
onClose={this.handleClickCloseExchangeSummary}
|
|
|
|
aria-labelledby="exchange-summary-title"
|
|
|
|
aria-describedby="exchange-summary-description"
|
|
|
|
>
|
|
|
|
<DialogContent>
|
|
|
|
<Typography component="h5" variant="h5">Exchange Summary</Typography>
|
|
|
|
<List dense>
|
|
|
|
<ListItem >
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<InventoryIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.num_public_buy_orders}
|
|
|
|
secondary="Public buy orders" />
|
|
|
|
</ListItem>
|
|
|
|
<Divider/>
|
|
|
|
|
|
|
|
<ListItem >
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<SellIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.num_public_sell_orders}
|
|
|
|
secondary="Public sell orders" />
|
|
|
|
</ListItem>
|
|
|
|
<Divider/>
|
|
|
|
|
|
|
|
<ListItem >
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<SmartToyIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.active_robots_today}
|
|
|
|
secondary="Today active robots" />
|
|
|
|
</ListItem>
|
|
|
|
<Divider/>
|
|
|
|
|
|
|
|
<ListItem >
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<PriceChangeIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.today_avg_nonkyc_btc_premium+"%"}
|
|
|
|
secondary="Today non-KYC average premium" />
|
|
|
|
</ListItem>
|
|
|
|
<Divider/>
|
|
|
|
|
|
|
|
<ListItem >
|
|
|
|
<ListItemIcon size="small">
|
|
|
|
<PercentIcon/>
|
|
|
|
</ListItemIcon>
|
|
|
|
<ListItemText
|
|
|
|
primaryTypographyProps={{fontSize: '14px'}}
|
|
|
|
secondaryTypographyProps={{fontSize: '12px'}}
|
|
|
|
primary={this.state.fee*100+"%"}
|
|
|
|
secondary="Trading fee" />
|
|
|
|
</ListItem>
|
|
|
|
</List>
|
|
|
|
|
|
|
|
</DialogContent>
|
|
|
|
</Dialog>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
bottomBarPhone =()=>{
|
|
|
|
return(
|
|
|
|
<Paper elevation={6} style={{height:40}}>
|
|
|
|
<this.StatsDialog/>
|
|
|
|
<this.CommunityDialog/>
|
2022-01-29 19:51:26 +00:00
|
|
|
<this.exchangeSummaryDialogPhone/>
|
|
|
|
<this.dialogProfile/>
|
2022-01-28 14:30:45 +00:00
|
|
|
<Grid container xs={12}>
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={1.6}>
|
2022-02-01 19:43:33 +00:00
|
|
|
<div style={{display: this.props.avatarLoaded ? '':'none'}}>
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip open={(this.state.active_order_id > 0 & !this.state.profileShown & this.props.avatarLoaded) ? true: false}
|
|
|
|
title="You have an active order">
|
2022-02-02 09:29:05 +00:00
|
|
|
<IconButton onClick={this.handleClickOpenProfile} sx={{margin: 0, bottom: 17, right: 8}} >
|
2022-02-01 22:05:49 +00:00
|
|
|
<Badge badgeContent={(this.state.active_order_id >0 & !this.state.profileShown) ? "": null} color="primary">
|
|
|
|
<Avatar className='phoneFlippedSmallAvatar'
|
2022-02-02 09:29:05 +00:00
|
|
|
sx={{ width: 55, height:55 }}
|
2022-02-01 22:05:49 +00:00
|
|
|
alt={this.props.nickname}
|
|
|
|
imgProps={{
|
|
|
|
onLoad:() => this.props.setAppState({avatarLoaded: true}),
|
|
|
|
}}
|
|
|
|
src={this.props.nickname ? window.location.origin +'/static/assets/avatars/' + this.props.nickname + '.png' : null}
|
|
|
|
/>
|
|
|
|
</Badge>
|
|
|
|
</IconButton>
|
|
|
|
</Tooltip>
|
2022-02-01 19:43:33 +00:00
|
|
|
</div>
|
2022-01-28 14:30:45 +00:00
|
|
|
</Grid>
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={1.6} align="center">
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip enterTouchDelay="300" title="Number of public BUY orders">
|
|
|
|
<IconButton onClick={this.handleClickOpenExchangeSummary} >
|
|
|
|
<Badge badgeContent={this.state.num_public_buy_orders} color="action">
|
|
|
|
<InventoryIcon />
|
|
|
|
</Badge>
|
|
|
|
</IconButton>
|
|
|
|
</Tooltip>
|
2022-01-28 14:30:45 +00:00
|
|
|
</Grid>
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={1.6} align="center">
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip enterTouchDelay="300" title="Number of public SELL orders">
|
|
|
|
<IconButton onClick={this.handleClickOpenExchangeSummary} >
|
|
|
|
<Badge badgeContent={this.state.num_public_sell_orders} color="action">
|
|
|
|
<SellIcon />
|
|
|
|
</Badge>
|
|
|
|
</IconButton>
|
|
|
|
</Tooltip>
|
2022-01-28 14:30:45 +00:00
|
|
|
</Grid>
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={1.6} align="center">
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip enterTouchDelay="300" title="Today active robots">
|
|
|
|
<IconButton onClick={this.handleClickOpenExchangeSummary} >
|
|
|
|
<Badge badgeContent={this.state.active_robots_today} color="action">
|
|
|
|
<SmartToyIcon />
|
|
|
|
</Badge>
|
|
|
|
</IconButton>
|
|
|
|
</Tooltip>
|
2022-01-28 14:30:45 +00:00
|
|
|
</Grid>
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={1.8} align="center">
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip enterTouchDelay="300" title="Today non-KYC bitcoin premium">
|
|
|
|
<IconButton onClick={this.handleClickOpenExchangeSummary} >
|
|
|
|
<Badge badgeContent={this.state.today_avg_nonkyc_btc_premium+"%"} color="action">
|
|
|
|
<PriceChangeIcon />
|
|
|
|
</Badge>
|
|
|
|
</IconButton>
|
|
|
|
</Tooltip>
|
2022-01-28 14:30:45 +00:00
|
|
|
</Grid>
|
|
|
|
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid container item xs={3.8}>
|
|
|
|
<Grid item xs={6}>
|
2022-01-28 14:30:45 +00:00
|
|
|
<Select
|
|
|
|
size = 'small'
|
|
|
|
defaultValue={1}
|
|
|
|
inputProps={{
|
|
|
|
style: {textAlign:"center"}
|
|
|
|
}}>
|
|
|
|
<MenuItem value={1}>EN</MenuItem>
|
|
|
|
</Select>
|
|
|
|
</Grid>
|
2022-01-29 19:51:26 +00:00
|
|
|
<Grid item xs={3}>
|
2022-02-01 22:05:49 +00:00
|
|
|
<Tooltip enterTouchDelay="250" title="Show community and support links">
|
2022-01-28 14:30:45 +00:00
|
|
|
<IconButton
|
|
|
|
color="primary"
|
2022-01-29 19:51:26 +00:00
|
|
|
aria-label="Community"
|
2022-01-28 14:30:45 +00:00
|
|
|
onClick={this.handleClickOpenCommunity} >
|
|
|
|
<PeopleIcon />
|
|
|
|
</IconButton>
|
2022-02-01 22:05:49 +00:00
|
|
|
</Tooltip>
|
|
|
|
</Grid>
|
|
|
|
<Grid item xs={3}>
|
|
|
|
<Tooltip enterTouchDelay="250" title="Show stats for nerds">
|
|
|
|
<IconButton color="primary"
|
|
|
|
aria-label="Stats for Nerds"
|
|
|
|
onClick={this.handleClickOpenStatsForNerds} >
|
|
|
|
<SettingsIcon />
|
|
|
|
</IconButton>
|
|
|
|
</Tooltip>
|
2022-01-28 14:30:45 +00:00
|
|
|
</Grid>
|
|
|
|
|
|
|
|
</Grid>
|
|
|
|
</Grid>
|
|
|
|
</Paper>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
<MediaQuery minWidth={1200}>
|
|
|
|
<this.bottomBarDesktop/>
|
|
|
|
</MediaQuery>
|
|
|
|
|
|
|
|
<MediaQuery maxWidth={1199}>
|
|
|
|
<this.bottomBarPhone/>
|
|
|
|
</MediaQuery>
|
|
|
|
</div>
|
2022-01-14 16:21:42 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|