mirror of
https://github.com/RoboSats/robosats.git
synced 2025-01-18 20:21:35 +00:00
Migrate ProfileDialog to Dialogs folder
Convert ProfileDialog component to Typescript and co-locate it inside the dialogs folder
This commit is contained in:
parent
5ff6e1e78d
commit
04e13d50fd
@ -22,13 +22,16 @@ import PasswordIcon from '@mui/icons-material/Password';
|
|||||||
import ContentCopy from "@mui/icons-material/ContentCopy";
|
import ContentCopy from "@mui/icons-material/ContentCopy";
|
||||||
import DnsIcon from '@mui/icons-material/Dns';
|
import DnsIcon from '@mui/icons-material/Dns';
|
||||||
import WebIcon from '@mui/icons-material/Web';
|
import WebIcon from '@mui/icons-material/Web';
|
||||||
import BookIcon from '@mui/icons-material/Book';
|
|
||||||
import PersonAddAltIcon from '@mui/icons-material/PersonAddAlt';
|
import PersonAddAltIcon from '@mui/icons-material/PersonAddAlt';
|
||||||
import EmojiEventsIcon from '@mui/icons-material/EmojiEvents';
|
import EmojiEventsIcon from '@mui/icons-material/EmojiEvents';
|
||||||
import FavoriteIcon from '@mui/icons-material/Favorite';
|
import FavoriteIcon from '@mui/icons-material/Favorite';
|
||||||
import { AmbossIcon , BitcoinSignIcon} from "./Icons";
|
import { AmbossIcon , BitcoinSignIcon} from "./Icons";
|
||||||
|
|
||||||
import { CommunityDialog, ExchangeSummaryDialog } from './Dialogs';
|
import {
|
||||||
|
CommunityDialog,
|
||||||
|
ExchangeSummaryDialog,
|
||||||
|
ProfileDialog,
|
||||||
|
} from './Dialogs';
|
||||||
|
|
||||||
import { getCookie } from "../utils/cookies";
|
import { getCookie } from "../utils/cookies";
|
||||||
import { pn } from "../utils/prettyNumbers";
|
import { pn } from "../utils/prettyNumbers";
|
||||||
@ -201,7 +204,7 @@ class BottomBar extends Component {
|
|||||||
this.setState({openProfile: false});
|
this.setState({openProfile: false});
|
||||||
};
|
};
|
||||||
|
|
||||||
handleSubmitInvoiceClicked=()=>{
|
handleSubmitInvoiceClicked=(rewardInvoice)=>{
|
||||||
this.setState({
|
this.setState({
|
||||||
badInvoice:false,
|
badInvoice:false,
|
||||||
showRewardsSpinner: true,
|
showRewardsSpinner: true,
|
||||||
@ -211,7 +214,7 @@ class BottomBar extends Component {
|
|||||||
method: 'POST',
|
method: 'POST',
|
||||||
headers: {'Content-Type':'application/json', 'X-CSRFToken': getCookie('csrftoken'),},
|
headers: {'Content-Type':'application/json', 'X-CSRFToken': getCookie('csrftoken'),},
|
||||||
body: JSON.stringify({
|
body: JSON.stringify({
|
||||||
'invoice': this.state.rewardInvoice,
|
'invoice': rewardInvoice,
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
fetch('/api/reward/', requestOptions)
|
fetch('/api/reward/', requestOptions)
|
||||||
@ -230,186 +233,6 @@ class BottomBar extends Component {
|
|||||||
return url.split('/')[2]
|
return url.split('/')[2]
|
||||||
}
|
}
|
||||||
|
|
||||||
dialogProfile =() =>{
|
|
||||||
const { t } = this.props;
|
|
||||||
return(
|
|
||||||
<Dialog
|
|
||||||
open={this.state.openProfile}
|
|
||||||
onClose={this.handleClickCloseProfile}
|
|
||||||
aria-labelledby="profile-title"
|
|
||||||
aria-describedby="profile-description"
|
|
||||||
>
|
|
||||||
<DialogContent>
|
|
||||||
<Typography component="h5" variant="h5">{t("Your Profile")}</Typography>
|
|
||||||
<List>
|
|
||||||
<Divider/>
|
|
||||||
<ListItem className="profileNickname">
|
|
||||||
<ListItemText secondary={t("Your robot")}>
|
|
||||||
<Typography component="h6" variant="h6">
|
|
||||||
{this.props.nickname ?
|
|
||||||
<div style={{position:'relative',left:'-7px'}}>
|
|
||||||
<div style={{display:'flex', alignItems:'center', justifyContent:'left', flexWrap:'wrap', width:300}}>
|
|
||||||
<BoltIcon sx={{ color: "#fcba03", height: '28px',width: '24px'}}/><a>{this.props.nickname}</a><BoltIcon sx={{ color: "#fcba03", height: '28px',width: '24px'}}/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
: ""}
|
|
||||||
</Typography>
|
|
||||||
</ListItemText>
|
|
||||||
<ListItemAvatar>
|
|
||||||
<Avatar className='profileAvatar'
|
|
||||||
sx={{ width: 65, height:65 }}
|
|
||||||
alt={this.props.nickname}
|
|
||||||
src={this.props.nickname ? window.location.origin +'/static/assets/avatars/' + this.props.nickname + '.png' : null}
|
|
||||||
/>
|
|
||||||
</ListItemAvatar>
|
|
||||||
</ListItem>
|
|
||||||
|
|
||||||
<Divider/>
|
|
||||||
|
|
||||||
{this.state.active_order_id ?
|
|
||||||
<ListItemButton onClick={this.handleClickCloseProfile} to={'/order/'+this.state.active_order_id} component={LinkRouter}>
|
|
||||||
<ListItemIcon>
|
|
||||||
<Badge badgeContent="" color="primary">
|
|
||||||
<NumbersIcon color="primary"/>
|
|
||||||
</Badge>
|
|
||||||
</ListItemIcon>
|
|
||||||
<ListItemText primary={t("One active order #{{orderID}}",{orderID: this.state.active_order_id})} secondary={t("Your current order")}/>
|
|
||||||
</ListItemButton>
|
|
||||||
:
|
|
||||||
|
|
||||||
this.state.last_order_id ?
|
|
||||||
<ListItemButton onClick={this.handleClickCloseProfile} to={'/order/'+this.state.last_order_id} component={LinkRouter}>
|
|
||||||
<ListItemIcon>
|
|
||||||
<NumbersIcon color="primary"/>
|
|
||||||
</ListItemIcon>
|
|
||||||
<ListItemText primary={t("Your last order #{{orderID}}",{orderID: this.state.last_order_id})} secondary={t("Inactive order")}/>
|
|
||||||
</ListItemButton>
|
|
||||||
:
|
|
||||||
<ListItem>
|
|
||||||
<ListItemIcon><NumbersIcon/></ListItemIcon>
|
|
||||||
<ListItemText primary={t("No active orders")} secondary={t("You do not have previous orders")}/>
|
|
||||||
</ListItem>
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
<ListItem>
|
|
||||||
<ListItemIcon>
|
|
||||||
<PasswordIcon/>
|
|
||||||
</ListItemIcon>
|
|
||||||
<ListItemText secondary={t("Your token (will not remain here)")}>
|
|
||||||
{getCookie("robot_token") ?
|
|
||||||
<TextField
|
|
||||||
disabled
|
|
||||||
sx={{width:"100%", maxWidth:"450px"}}
|
|
||||||
label={t("Back it up!")}
|
|
||||||
value={getCookie("robot_token") }
|
|
||||||
variant='filled'
|
|
||||||
size='small'
|
|
||||||
InputProps={{
|
|
||||||
endAdornment:
|
|
||||||
<Tooltip disableHoverListener enterTouchDelay={0} title={t("Copied!")}>
|
|
||||||
<IconButton onClick= {()=> (navigator.clipboard.writeText(getCookie("robot_token")) & this.props.setAppState({copiedToken:true}))}>
|
|
||||||
<ContentCopy color={this.props.copiedToken ? "inherit" : "primary"}/>
|
|
||||||
</IconButton>
|
|
||||||
</Tooltip>,
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
:
|
|
||||||
t("Cannot remember")}
|
|
||||||
</ListItemText>
|
|
||||||
</ListItem>
|
|
||||||
|
|
||||||
<Divider/>
|
|
||||||
|
|
||||||
<Grid item align="center">
|
|
||||||
<FormControlLabel labelPlacement="start"control={
|
|
||||||
<Switch
|
|
||||||
checked={this.state.showRewards}
|
|
||||||
onChange={()=> this.setState({showRewards: !this.state.showRewards})}/>}
|
|
||||||
label={t("Rewards and compensations")}
|
|
||||||
/>
|
|
||||||
</Grid>
|
|
||||||
|
|
||||||
<div style={{ display: this.state.showRewards ? '':'none'}}>
|
|
||||||
<ListItem>
|
|
||||||
<ListItemIcon>
|
|
||||||
<PersonAddAltIcon/>
|
|
||||||
</ListItemIcon>
|
|
||||||
<ListItemText secondary={t("Share to earn 100 Sats per trade")}>
|
|
||||||
<TextField
|
|
||||||
label={t("Your referral link")}
|
|
||||||
value={this.getHost()+'/ref/'+this.state.referral_code}
|
|
||||||
size='small'
|
|
||||||
InputProps={{
|
|
||||||
endAdornment:
|
|
||||||
<Tooltip disableHoverListener enterTouchDelay={0} title={t("Copied!")}>
|
|
||||||
<IconButton onClick= {()=>navigator.clipboard.writeText('http://'+this.getHost()+'/ref/'+this.state.referral_code)}>
|
|
||||||
<ContentCopy />
|
|
||||||
</IconButton>
|
|
||||||
</Tooltip>,
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
</ListItemText>
|
|
||||||
</ListItem>
|
|
||||||
|
|
||||||
<ListItem>
|
|
||||||
<ListItemIcon>
|
|
||||||
<EmojiEventsIcon/>
|
|
||||||
</ListItemIcon>
|
|
||||||
{!this.state.openClaimRewards ?
|
|
||||||
<ListItemText secondary={t("Your earned rewards")}>
|
|
||||||
<Grid container>
|
|
||||||
<Grid item xs={9}>
|
|
||||||
<Typography>{this.state.earned_rewards+" Sats"}</Typography>
|
|
||||||
</Grid>
|
|
||||||
<Grid item xs={3}>
|
|
||||||
<Button disabled={this.state.earned_rewards==0? true : false} onClick={() => this.setState({openClaimRewards:true})} variant="contained" size="small">{t("Claim")}</Button>
|
|
||||||
</Grid>
|
|
||||||
</Grid>
|
|
||||||
</ListItemText>
|
|
||||||
:
|
|
||||||
<form style={{maxWidth: 270}}>
|
|
||||||
<Grid alignItems="stretch" style={{ display: "flex"}} align="center">
|
|
||||||
<Grid item alignItems="stretch" style={{ display: "flex" }} align="center">
|
|
||||||
<TextField
|
|
||||||
error={this.state.badInvoice}
|
|
||||||
helperText={this.state.badInvoice ? this.state.badInvoice : "" }
|
|
||||||
label={t("Invoice for {{amountSats}} Sats", {amountSats: this.state.earned_rewards})}
|
|
||||||
size="small"
|
|
||||||
value={this.state.rewardInvoice}
|
|
||||||
onChange={e => {
|
|
||||||
this.setState({ rewardInvoice: e.target.value });
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
</Grid>
|
|
||||||
<Grid item alignItems="stretch" style={{ display: "flex" }}>
|
|
||||||
<Button sx={{maxHeight:38}} onClick={this.handleSubmitInvoiceClicked} variant="contained" color="primary" size="small">{t("Submit")}</Button>
|
|
||||||
</Grid>
|
|
||||||
</Grid>
|
|
||||||
</form>
|
|
||||||
}
|
|
||||||
</ListItem>
|
|
||||||
|
|
||||||
{this.state.showRewardsSpinner?
|
|
||||||
<div style={{display: 'flex', justifyContent: 'center'}}>
|
|
||||||
<CircularProgress/>
|
|
||||||
</div>
|
|
||||||
:""}
|
|
||||||
|
|
||||||
{this.state.withdrawn?
|
|
||||||
<div style={{display: 'flex', justifyContent: 'center'}}>
|
|
||||||
<Typography color="primary" variant="body2"><b>{t("There it goes, thank you!🥇")}</b></Typography>
|
|
||||||
</div>
|
|
||||||
:""}
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</List>
|
|
||||||
</DialogContent>
|
|
||||||
|
|
||||||
</Dialog>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
bottomBarDesktop =()=>{
|
bottomBarDesktop =()=>{
|
||||||
const { t } = this.props;
|
const { t } = this.props;
|
||||||
var hasRewards = this.state.earned_rewards > 0 ? true: false;
|
var hasRewards = this.state.earned_rewards > 0 ? true: false;
|
||||||
@ -418,7 +241,6 @@ bottomBarDesktop =()=>{
|
|||||||
return(
|
return(
|
||||||
<Paper elevation={6} style={{height:40}}>
|
<Paper elevation={6} style={{height:40}}>
|
||||||
{this.StatsDialog()}
|
{this.StatsDialog()}
|
||||||
{this.dialogProfile()}
|
|
||||||
<Grid container>
|
<Grid container>
|
||||||
|
|
||||||
<Grid item xs={1.9}>
|
<Grid item xs={1.9}>
|
||||||
@ -582,7 +404,6 @@ bottomBarPhone =()=>{
|
|||||||
return(
|
return(
|
||||||
<Paper elevation={6} style={{height:40}}>
|
<Paper elevation={6} style={{height:40}}>
|
||||||
{this.StatsDialog()}
|
{this.StatsDialog()}
|
||||||
{this.dialogProfile()}
|
|
||||||
<Grid container>
|
<Grid container>
|
||||||
|
|
||||||
<Grid item xs={1.6}>
|
<Grid item xs={1.6}>
|
||||||
@ -696,6 +517,22 @@ bottomBarPhone =()=>{
|
|||||||
takerFee={this.state.taker_fee}
|
takerFee={this.state.taker_fee}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
<ProfileDialog
|
||||||
|
isOpen={this.state.openProfile}
|
||||||
|
handleClickCloseProfile={this.handleClickCloseProfile}
|
||||||
|
nickname={this.props.nickname}
|
||||||
|
activeOrderId={this.state.active_order_id}
|
||||||
|
lastOrderId={this.state.last_order_id}
|
||||||
|
referralCode={this.state.referral_code}
|
||||||
|
handleSubmitInvoiceClicked={this.handleSubmitInvoiceClicked}
|
||||||
|
host={this.getHost()}
|
||||||
|
showRewardsSpinner={this.state.showRewardsSpinner}
|
||||||
|
withdrawn={this.state.withdrawn}
|
||||||
|
badInvoice={this.state.badInvoice}
|
||||||
|
earnedRewards={this.state.earned_rewards}
|
||||||
|
setAppState={this.props.setAppState}
|
||||||
|
/>
|
||||||
|
|
||||||
<MediaQuery minWidth={1200}>
|
<MediaQuery minWidth={1200}>
|
||||||
{this.bottomBarDesktop()}
|
{this.bottomBarDesktop()}
|
||||||
</MediaQuery>
|
</MediaQuery>
|
||||||
|
328
frontend/src/components/Dialogs/ProfileDialog.tsx
Normal file
328
frontend/src/components/Dialogs/ProfileDialog.tsx
Normal file
@ -0,0 +1,328 @@
|
|||||||
|
import React, { useState } from "react";
|
||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
import { Link as LinkRouter } from "react-router-dom";
|
||||||
|
|
||||||
|
import {
|
||||||
|
Avatar,
|
||||||
|
Badge,
|
||||||
|
Button,
|
||||||
|
CircularProgress,
|
||||||
|
Dialog,
|
||||||
|
DialogContent,
|
||||||
|
Divider,
|
||||||
|
FormControlLabel,
|
||||||
|
Grid,
|
||||||
|
IconButton,
|
||||||
|
List,
|
||||||
|
ListItemAvatar,
|
||||||
|
ListItemButton,
|
||||||
|
ListItemText,
|
||||||
|
ListItem,
|
||||||
|
ListItemIcon,
|
||||||
|
Switch,
|
||||||
|
TextField,
|
||||||
|
Tooltip,
|
||||||
|
Typography,
|
||||||
|
} from "@mui/material";
|
||||||
|
|
||||||
|
import BoltIcon from "@mui/icons-material/Bolt";
|
||||||
|
import NumbersIcon from "@mui/icons-material/Numbers";
|
||||||
|
import PasswordIcon from "@mui/icons-material/Password";
|
||||||
|
import ContentCopy from "@mui/icons-material/ContentCopy";
|
||||||
|
import PersonAddAltIcon from "@mui/icons-material/PersonAddAlt";
|
||||||
|
import EmojiEventsIcon from "@mui/icons-material/EmojiEvents";
|
||||||
|
|
||||||
|
import { getCookie } from "../../utils/cookies";
|
||||||
|
|
||||||
|
type Props = {
|
||||||
|
isOpen: boolean;
|
||||||
|
handleClickCloseProfile: () => void;
|
||||||
|
nickname: string;
|
||||||
|
activeOrderId: string | number;
|
||||||
|
lastOrderId: string | number;
|
||||||
|
referralCode: string;
|
||||||
|
handleSubmitInvoiceClicked: (invoice: string) => void;
|
||||||
|
host: string;
|
||||||
|
showRewardsSpinner: boolean;
|
||||||
|
withdrawn: boolean;
|
||||||
|
badInvoice: boolean | string;
|
||||||
|
earnedRewards: number;
|
||||||
|
setAppState: (state: any) => void; // TODO: move to a ContextProvider
|
||||||
|
}
|
||||||
|
|
||||||
|
const ProfileDialog = ({
|
||||||
|
isOpen,
|
||||||
|
handleClickCloseProfile,
|
||||||
|
nickname,
|
||||||
|
activeOrderId,
|
||||||
|
lastOrderId,
|
||||||
|
referralCode,
|
||||||
|
handleSubmitInvoiceClicked,
|
||||||
|
host,
|
||||||
|
showRewardsSpinner,
|
||||||
|
withdrawn,
|
||||||
|
badInvoice,
|
||||||
|
earnedRewards,
|
||||||
|
setAppState,
|
||||||
|
}: Props): JSX.Element => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const [rewardInvoice, setRewardInvoice] = useState<string>("");
|
||||||
|
const [showRewards, setShowRewards] = useState<boolean>(false);
|
||||||
|
const [openClaimRewards, setOpenClaimRewards] = useState<boolean>(false);
|
||||||
|
|
||||||
|
const copyTokenHandler = () => {
|
||||||
|
const robotToken = getCookie("robot_token");
|
||||||
|
|
||||||
|
if (robotToken) {
|
||||||
|
navigator.clipboard.writeText(robotToken);
|
||||||
|
setAppState({copiedToken:true});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const copyReferralCodeHandler = () => {
|
||||||
|
navigator.clipboard.writeText(`http://${host}/ref/${referralCode}`);
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Dialog
|
||||||
|
open={isOpen}
|
||||||
|
onClose={handleClickCloseProfile}
|
||||||
|
aria-labelledby="profile-title"
|
||||||
|
aria-describedby="profile-description"
|
||||||
|
>
|
||||||
|
<DialogContent>
|
||||||
|
<Typography component="h5" variant="h5">{t("Your Profile")}</Typography>
|
||||||
|
|
||||||
|
<List>
|
||||||
|
<Divider/>
|
||||||
|
|
||||||
|
<ListItem className="profileNickname">
|
||||||
|
<ListItemText secondary={t("Your robot")}>
|
||||||
|
<Typography component="h6" variant="h6">
|
||||||
|
{nickname ? (
|
||||||
|
<div style={{position:"relative", left:"-7px"}}>
|
||||||
|
<div style={{display:"flex", alignItems:"center", justifyContent:"left", flexWrap:"wrap", width:300}}>
|
||||||
|
<BoltIcon sx={{ color: "#fcba03", height: "28px", width: "24px"}} />
|
||||||
|
|
||||||
|
<a>{nickname}</a>
|
||||||
|
|
||||||
|
<BoltIcon sx={{ color: "#fcba03", height: "28px", width: "24px"}} />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
: null}
|
||||||
|
</Typography>
|
||||||
|
</ListItemText>
|
||||||
|
|
||||||
|
<ListItemAvatar>
|
||||||
|
<Avatar className="profileAvatar"
|
||||||
|
sx={{ width: 65, height:65 }}
|
||||||
|
alt={nickname}
|
||||||
|
src={nickname ? `${window.location.origin}/static/assets/avatars/${nickname}.png` : ""}
|
||||||
|
/>
|
||||||
|
</ListItemAvatar>
|
||||||
|
</ListItem>
|
||||||
|
|
||||||
|
<Divider/>
|
||||||
|
|
||||||
|
{activeOrderId ? (
|
||||||
|
<ListItemButton
|
||||||
|
onClick={handleClickCloseProfile}
|
||||||
|
to={`/order/${activeOrderId}`}
|
||||||
|
component={LinkRouter}
|
||||||
|
>
|
||||||
|
<ListItemIcon>
|
||||||
|
<Badge badgeContent="" color="primary">
|
||||||
|
<NumbersIcon color="primary" />
|
||||||
|
</Badge>
|
||||||
|
</ListItemIcon>
|
||||||
|
<ListItemText
|
||||||
|
primary={t("One active order #{{orderID}}", { orderID: activeOrderId })}
|
||||||
|
secondary={t("Your current order")}
|
||||||
|
/>
|
||||||
|
</ListItemButton>
|
||||||
|
) :
|
||||||
|
lastOrderId ? (
|
||||||
|
<ListItemButton
|
||||||
|
onClick={handleClickCloseProfile}
|
||||||
|
to={`/order/${lastOrderId}`}
|
||||||
|
component={LinkRouter}
|
||||||
|
>
|
||||||
|
<ListItemIcon>
|
||||||
|
<NumbersIcon color="primary" />
|
||||||
|
</ListItemIcon>
|
||||||
|
<ListItemText
|
||||||
|
primary={t("Your last order #{{orderID}}", { orderID: lastOrderId })}
|
||||||
|
secondary={t("Inactive order")}
|
||||||
|
/>
|
||||||
|
</ListItemButton>
|
||||||
|
) : (
|
||||||
|
<ListItem>
|
||||||
|
<ListItemIcon>
|
||||||
|
<NumbersIcon />
|
||||||
|
</ListItemIcon>
|
||||||
|
<ListItemText
|
||||||
|
primary={t("No active orders")}
|
||||||
|
secondary={t("You do not have previous orders")}
|
||||||
|
/>
|
||||||
|
</ListItem>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
<ListItem>
|
||||||
|
<ListItemIcon>
|
||||||
|
<PasswordIcon />
|
||||||
|
</ListItemIcon>
|
||||||
|
|
||||||
|
<ListItemText secondary={t("Your token (will not remain here)")}>
|
||||||
|
{getCookie("robot_token") ? (
|
||||||
|
<TextField
|
||||||
|
disabled
|
||||||
|
sx={{width:"100%", maxWidth:"450px"}}
|
||||||
|
label={t("Back it up!")}
|
||||||
|
value={getCookie("robot_token") }
|
||||||
|
variant="filled"
|
||||||
|
size="small"
|
||||||
|
InputProps={{
|
||||||
|
endAdornment:
|
||||||
|
<Tooltip
|
||||||
|
disableHoverListener
|
||||||
|
enterTouchDelay={0}
|
||||||
|
title={t("Copied!") || ""}
|
||||||
|
>
|
||||||
|
<IconButton onClick={copyTokenHandler}>
|
||||||
|
<ContentCopy color="inherit" />
|
||||||
|
</IconButton>
|
||||||
|
</Tooltip>,
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
) :
|
||||||
|
t("Cannot remember")
|
||||||
|
}
|
||||||
|
</ListItemText>
|
||||||
|
</ListItem>
|
||||||
|
|
||||||
|
<Divider/>
|
||||||
|
|
||||||
|
<Grid container>
|
||||||
|
<Grid item>
|
||||||
|
<FormControlLabel
|
||||||
|
labelPlacement="start"
|
||||||
|
label={`${t("Rewards and compensations")}`}
|
||||||
|
control={
|
||||||
|
<Switch
|
||||||
|
checked={showRewards}
|
||||||
|
onChange={()=> setShowRewards(!showRewards)}
|
||||||
|
/>
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
{showRewards && (
|
||||||
|
<>
|
||||||
|
<ListItem>
|
||||||
|
<ListItemIcon>
|
||||||
|
<PersonAddAltIcon />
|
||||||
|
</ListItemIcon>
|
||||||
|
|
||||||
|
<ListItemText secondary={t("Share to earn 100 Sats per trade")}>
|
||||||
|
<TextField
|
||||||
|
label={t("Your referral link")}
|
||||||
|
value={host+'/ref/'+referralCode}
|
||||||
|
size="small"
|
||||||
|
InputProps={{
|
||||||
|
endAdornment:
|
||||||
|
<Tooltip
|
||||||
|
disableHoverListener
|
||||||
|
enterTouchDelay={0}
|
||||||
|
title={t("Copied!") || ""}
|
||||||
|
>
|
||||||
|
<IconButton onClick={copyReferralCodeHandler}>
|
||||||
|
<ContentCopy />
|
||||||
|
</IconButton>
|
||||||
|
</Tooltip>,
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</ListItemText>
|
||||||
|
</ListItem>
|
||||||
|
|
||||||
|
<ListItem>
|
||||||
|
<ListItemIcon>
|
||||||
|
<EmojiEventsIcon />
|
||||||
|
</ListItemIcon>
|
||||||
|
|
||||||
|
{!openClaimRewards ? (
|
||||||
|
<ListItemText secondary={t("Your earned rewards")}>
|
||||||
|
<Grid container>
|
||||||
|
<Grid item xs={9}>
|
||||||
|
<Typography>{`${earnedRewards} Sats`}</Typography>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<Grid item xs={3}>
|
||||||
|
<Button
|
||||||
|
disabled={earnedRewards === 0 ? true : false}
|
||||||
|
onClick={() => setOpenClaimRewards(true)}
|
||||||
|
variant="contained"
|
||||||
|
size="small"
|
||||||
|
>
|
||||||
|
{t("Claim")}
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
|
</ListItemText>
|
||||||
|
) : (
|
||||||
|
<form style={{maxWidth: 270}}>
|
||||||
|
<Grid container alignItems="stretch" style={{ display: "flex"}}>
|
||||||
|
<Grid item style={{ display: "flex" }}>
|
||||||
|
<TextField
|
||||||
|
error={badInvoice ? true : false}
|
||||||
|
helperText={badInvoice ? badInvoice : "" }
|
||||||
|
label={t("Invoice for {{amountSats}} Sats", { amountSats: earnedRewards })}
|
||||||
|
size="small"
|
||||||
|
value={rewardInvoice}
|
||||||
|
onChange={e => {
|
||||||
|
setRewardInvoice(e.target.value);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<Grid item alignItems="stretch" style={{ display: "flex" }}>
|
||||||
|
<Button
|
||||||
|
sx={{maxHeight:38}}
|
||||||
|
onClick={() => handleSubmitInvoiceClicked(rewardInvoice)}
|
||||||
|
variant="contained"
|
||||||
|
color="primary"
|
||||||
|
size="small"
|
||||||
|
>
|
||||||
|
{t("Submit")}
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
|
</form>
|
||||||
|
)}
|
||||||
|
</ListItem>
|
||||||
|
|
||||||
|
{showRewardsSpinner && (
|
||||||
|
<div style={{display: "flex", justifyContent: "center"}}>
|
||||||
|
<CircularProgress />
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{withdrawn && (
|
||||||
|
<div style={{display: "flex", justifyContent: "center"}}>
|
||||||
|
<Typography color="primary" variant="body2">
|
||||||
|
<b>{t("There it goes, thank you!🥇")}</b>
|
||||||
|
</Typography>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
</List>
|
||||||
|
</DialogContent>
|
||||||
|
</Dialog>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default ProfileDialog;
|
@ -4,4 +4,5 @@ export { default as LearnDialog } from "./Learn";
|
|||||||
export { default as NoRobotDialog } from "./NoRobot";
|
export { default as NoRobotDialog } from "./NoRobot";
|
||||||
export { default as StoreTokenDialog } from "./StoreToken";
|
export { default as StoreTokenDialog } from "./StoreToken";
|
||||||
export { default as ExchangeSummaryDialog } from "./ExchangeSummaryDialog";
|
export { default as ExchangeSummaryDialog } from "./ExchangeSummaryDialog";
|
||||||
|
export { default as ProfileDialog } from "./ProfileDialog";
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user