import React, { Component } from "react"; import { withTranslation } from "react-i18next"; import { Badge, Tooltip, Stack, Paper, Button, FormControlLabel, Checkbox, RadioGroup, ListItemButton, Typography, Grid, Select, MenuItem, FormControl, FormHelperText, ListItemText, ListItemAvatar, IconButton, CircularProgress} from "@mui/material"; import { Link } from 'react-router-dom' import { DataGrid } from '@mui/x-data-grid'; import currencyDict from '../../static/assets/currencies.json'; import MediaQuery from 'react-responsive' import Image from 'material-ui-image' import FlagWithProps from './FlagWithProps' import { pn } from "../utils/prettyNumbers"; import PaymentText from './PaymentText' // Icons import RefreshIcon from '@mui/icons-material/Refresh'; import { SendReceiveIcon, BuySatsCheckedIcon, BuySatsIcon, SellSatsCheckedIcon, SellSatsIcon} from "./Icons"; class BookPage extends Component { constructor(props) { super(props); this.state = { pageSize: 6, }; if(this.props.bookOrders.length == 0){ this.getOrderDetails(2, 0) } } getOrderDetails(type, currency) { this.props.setAppState({bookLoading: true}); fetch('/api/book' + '?currency=' + currency + "&type=" + type) .then((response) => response.json()) .then((data) => (this.props.setAppState({ bookNotFound: data.not_found, bookLoading: false, bookOrders: data, }))); } handleRowClick=(e)=>{ this.props.history.push('/order/' + e); } handleCurrencyChange=(e)=>{ var currency = e.target.value; this.props.setAppState({ currency: currency, bookCurrencyCode: this.getCurrencyCode(currency), }) } getCurrencyCode(val){ const { t } = this.props; if (val){ return val == 0 ? t('ANY_currency') : currencyDict[val.toString()] }else{ return t('ANY_currency') } } // Colors for the status badges statusBadgeColor(status){ if(status=='Active'){return("success")} if(status=='Seen recently'){return("warning")} if(status=='Inactive'){return('error')} } amountToString = (amount,has_range,min_amount,max_amount) => { if (has_range){ return pn(parseFloat(Number(min_amount).toPrecision(2)))+'-'+pn(parseFloat(Number(max_amount).toPrecision(2))) }else{ return pn(parseFloat(Number(amount).toPrecision(3))) } } bookListTableDesktop=()=>{ const { t } = this.props; return (
order.type == this.props.type || this.props.type == 2) .filter(order => order.currency == this.props.currency || this.props.currency == 0) .map((order) => ({id: order.id, avatar: window.location.origin +'/static/assets/avatars/' + order.maker_nick + '.png', robot: order.maker_nick, robot_status: order.maker_status, type: order.type ? t("Seller"): t("Buyer"), amount: order.amount, has_range: order.has_range, min_amount: order.min_amount, max_amount: order.max_amount, currency: this.getCurrencyCode(order.currency), payment_method: order.payment_method, price: order.price, premium: order.premium, }) )} loading={this.props.bookLoading} columns={[ // { field: 'id', headerName: 'ID', width: 40 }, { field: 'robot', headerName: t("Robot"), width: 240, renderCell: (params) => {return ( {params.row.type == t("Buyer") ? : }
}>
{params.row.robot}
); } }, { field: 'type', headerName: t("Is"), width: 60 }, { field: 'amount', headerName: t("Amount"), type: 'number', width: 90, renderCell: (params) => {return (
{this.amountToString(params.row.amount,params.row.has_range, params.row.min_amount, params.row.max_amount)}
)}}, { field: 'currency', headerName: t("Currency"), width: 100, renderCell: (params) => {return (
{params.row.currency+" "}
) }}, { field: 'payment_method', headerName: t("Payment Method"), width: 180 , renderCell: (params) => {return (
)} }, { field: 'price', headerName: t("Price"), type: 'number', width: 140, renderCell: (params) => {return (
{pn(params.row.price) + " " +params.row.currency+ "/BTC" }
)} }, { field: 'premium', headerName: t("Premium"), type: 'number', width: 100, renderCell: (params) => {return (
{parseFloat(parseFloat(params.row.premium).toFixed(4))+"%" }
)} }, ]} components={{ NoRowsOverlay: () => (
{this.NoOrdersFound()} ), NoResultsOverlay: () => ( {t("Filter has no results")} ) }} pageSize={this.props.bookLoading ? 0 : this.state.pageSize} rowsPerPageOptions={[0,6,20,50]} onPageSizeChange={(newPageSize) => this.setState({pageSize:newPageSize})} onRowClick={(params) => this.handleRowClick(params.row.id)} // Whole row is clickable, but the mouse only looks clickly in some places. />
); } bookListTablePhone=()=>{ const { t } = this.props; return (
order.type == this.props.type || this.props.type == 2) .filter(order => order.currency == this.props.currency || this.props.currency == 0) .map((order) => ({id: order.id, avatar: window.location.origin +'/static/assets/avatars/' + order.maker_nick + '.png', robot: order.maker_nick, robot_status: order.maker_status, type: order.type ? t("Seller"): t("Buyer"), amount: order.amount, has_range: order.has_range, min_amount: order.min_amount, max_amount: order.max_amount, currency: this.getCurrencyCode(order.currency), payment_method: order.payment_method, price: order.price, premium: order.premium, }) )} columns={[ // { field: 'id', headerName: 'ID', width: 40 }, { field: 'robot', headerName: t("Robot"), width: 64, renderCell: (params) => {return (
{params.row.type == t("Buyer") ? : }
}>
{params.row.robot}
); } }, { field: 'type', headerName: t("Is"), width: 60, hide:'true'}, { field: 'amount', headerName: t("Amount"), type: 'number', width: 84, renderCell: (params) => {return (
{this.amountToString(params.row.amount,params.row.has_range, params.row.min_amount, params.row.max_amount)}
)} }, { field: 'currency', headerName: t("Currency"), width: 85, renderCell: (params) => {return ( //
{params.row.currency+" "}
//
)} }, { field: 'payment_method', headerName: t("Payment Method"), width: 180, hide:'true'}, { field: 'payment_icons', headerName: t("Pay"), width: 75 , renderCell: (params) => {return (
)} }, { field: 'price', headerName: t("Price"), type: 'number', width: 140, hide:'true', renderCell: (params) => {return (
{pn(params.row.price) + " " +params.row.currency+ "/BTC" }
)} }, { field: 'premium', headerName: t("Premium"), type: 'number', width: 85, renderCell: (params) => {return (
{parseFloat(parseFloat(params.row.premium).toFixed(4))+"%" }
)} }, ]} components={{ NoRowsOverlay: () => (
{this.NoOrdersFound()} ), NoResultsOverlay: () => ( {t("Local filter returns no result")} ) }} pageSize={this.props.bookLoading ? 0 : this.state.pageSize} rowsPerPageOptions={[0,6,20,50]} onPageSizeChange={(newPageSize) => this.setState({pageSize:newPageSize})} onRowClick={(params) => this.handleRowClick(params.row.id)} // Whole row is clickable, but the mouse only looks clickly in some places. />
); } handleTypeChange=(buyChecked, sellChecked)=>{ this.props.setAppState({buyChecked: buyChecked, sellChecked: sellChecked}) if (buyChecked & sellChecked || !buyChecked & !sellChecked) { var type = 2 } else if (buyChecked) { var type = 1 } else if (sellChecked) { var type = 0 } this.props.setAppState({type: type}) } handleClickBuy=(e)=>{ var buyChecked = e.target.checked var sellChecked = this.props.sellChecked this.handleTypeChange(buyChecked, sellChecked); } handleClickSell=(e)=>{ var buyChecked = this.props.buyChecked var sellChecked = e.target.checked this.handleTypeChange(buyChecked, sellChecked); } NoOrdersFound=()=>{ const { t } = this.props; return( {this.props.type == 0 ? t("No orders found to sell BTC for {{currencyCode}}",{currencyCode:this.props.bookCurrencyCode}) : t("No orders found to buy BTC for {{currencyCode}}",{currencyCode:this.props.bookCurrencyCode}) }
{t("Be the first one to create an order")}

) } render() { const { t } = this.props; return ( this.setState({loading: true}) & this.getOrderDetails(2, 0)}> {t("I want to")}
} checkedIcon={}/>} label={
{this.props.buyChecked ? {t("Buy")} : {t("Buy")} }
} labelPlacement="bottom" checked={this.props.buyChecked} onChange={this.handleClickBuy} />
} checkedIcon={}/>} label={
{this.props.sellChecked ? {t("Sell")} : {t("Sell")} }
} labelPlacement="bottom" checked={this.props.sellChecked} onChange={this.handleClickSell} />
{this.props.type == 0 ? t("and receive") : (this.props.type == 1 ? t("and pay with") : t("and use") )} { this.props.bookNotFound ? "" : {this.props.type == 0 ? t("You are SELLING BTC for {{currencyCode}}",{currencyCode:this.props.bookCurrencyCode}) : (this.props.type == 1 ? t("You are BUYING BTC for {{currencyCode}}",{currencyCode:this.props.bookCurrencyCode}) : t("You are looking at all") ) } } { this.props.bookNotFound ? this.NoOrdersFound() : {/* Desktop Book */} {this.bookListTableDesktop()} {/* Smartphone Book */} {this.bookListTablePhone()} } { !this.props.bookNotFound ? : null }
); } } export default withTranslation()(BookPage);