import React, { Component } from "react"; import { Paper, CircularProgress, Button , Grid, Typography, List, ListItem, ListItemText, ListItemAvatar, Avatar, Divider, Box, LinearProgress} from "@mui/material" import TradeBox from "./TradeBox"; function msToTime(duration) { var seconds = Math.floor((duration / 1000) % 60), minutes = Math.floor((duration / (1000 * 60)) % 60), hours = Math.floor((duration / (1000 * 60 * 60)) % 24); minutes = (minutes < 10) ? "0" + minutes : minutes; seconds = (seconds < 10) ? "0" + seconds : seconds; return hours + "h " + minutes + "m " + seconds + "s"; } // TO DO fix Progress bar to go from 100 to 0, from total_expiration time, showing time_left function LinearDeterminate() { const [progress, setProgress] = React.useState(0); React.useEffect(() => { const timer = setInterval(() => { setProgress((oldProgress) => { if (oldProgress === 0) { return 100; } const diff = 1; return Math.max(oldProgress - diff, 0); }); }, 500); return () => { clearInterval(timer); }; }, []); return ( ); } function getCookie(name) { let cookieValue = null; if (document.cookie && document.cookie !== '') { const cookies = document.cookie.split(';'); for (let i = 0; i < cookies.length; i++) { const cookie = cookies[i].trim(); // Does this cookie string begin with the name we want? if (cookie.substring(0, name.length + 1) === (name + '=')) { cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); break; } } } return cookieValue; } const csrftoken = getCookie('csrftoken'); // pretty numbers function pn(x) { return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ","); } export default class OrderPage extends Component { constructor(props) { super(props); this.state = { isExplicit: false, delay: 10000, // Refresh every 10 seconds currencies_dict: {"1":"USD"} }; this.orderId = this.props.match.params.orderId; this.getCurrencyDict(); this.getOrderDetails(); } getOrderDetails() { this.setState(null) fetch('/api/order' + '?order_id=' + this.orderId) .then((response) => response.json()) .then((data) => {console.log(data) & this.setState({ id: data.id, statusCode: data.status, statusText: data.status_message, type: data.type, currency: data.currency, currencyCode: this.getCurrencyCode(data.currency), amount: data.amount, paymentMethod: data.payment_method, isExplicit: data.is_explicit, premium: data.premium, satoshis: data.satoshis, makerId: data.maker, isParticipant: data.is_participant, makerNick: data.maker_nick, takerId: data.taker, takerNick: data.taker_nick, isMaker: data.is_maker, isTaker: data.is_taker, isBuyer: data.is_buyer, isSeller: data.is_seller, expiresAt: data.expires_at, badRequest: data.bad_request, bondInvoice: data.bond_invoice, bondSatoshis: data.bond_satoshis, escrowInvoice: data.escrow_invoice, escrowSatoshis: data.escrow_satoshis, invoiceAmount: data.invoice_amount, }); }); } // These are used to refresh the data componentDidMount() { this.interval = setInterval(this.tick, this.state.delay); } componentDidUpdate(prevProps, prevState) { if (prevState.delay !== this.state.delay) { clearInterval(this.interval); this.interval = setInterval(this.tick, this.state.delay); } } componentWillUnmount() { clearInterval(this.interval); } tick = () => { this.getOrderDetails(); } handleDelayChange = (e) => { this.setState({ delay: Number(e.target.value) }); } // Fix to use proper react props handleClickBackButton=()=>{ window.history.back(); } handleClickTakeOrderButton=()=>{ console.log(this.state) const requestOptions = { method: 'POST', headers: {'Content-Type':'application/json', 'X-CSRFToken': getCookie('csrftoken'),}, body: JSON.stringify({ 'action':'take', }), }; fetch('/api/order/' + '?order_id=' + this.orderId, requestOptions) .then((response) => response.json()) .then((data) => (console.log(data) & this.getOrderDetails(data.id))); } getCurrencyDict() { fetch('/static/assets/currencies.json') .then((response) => response.json()) .then((data) => this.setState({ currencies_dict: data })); } getCurrencyCode(val){ let code = val ? this.state.currencies_dict[val.toString()] : "" return code } handleClickCancelOrderButton=()=>{ console.log(this.state) const requestOptions = { method: 'POST', headers: {'Content-Type':'application/json', 'X-CSRFToken': getCookie('csrftoken'),}, body: JSON.stringify({ 'action':'cancel', }), }; fetch('/api/order/' + '?order_id=' + this.orderId, requestOptions) .then((response) => response.json()) .then((data) => (console.log(data) & this.getOrderDetails(data.id))); } orderBox=()=>{ return( {this.state.type ? "Sell " : "Buy "} Order Details {this.state.isParticipant ? <> {this.state.takerNick!='None' ? <> : "" } :"" } {this.state.isExplicit ? : } {/* Participants cannot see the Back or Take Order buttons */} {this.state.isParticipant ? "" : <> } {/* Makers can cancel before commiting the bond (status 0)*/} {this.state.isMaker & this.state.statusCode == 0 ? :""} {/* Takers can cancel before commiting the bond (status 3)*/} {this.state.isTaker & this.state.statusCode == 3 ? :""} ) } orderDetailsPage (){ return( this.state.badRequest ?
{this.state.badRequest}
: (this.state.isParticipant ? {this.orderBox()} : {this.orderBox()} ) ) } render (){ return ( // Only so nothing shows while requesting the first batch of data (this.state.statusCode == null & this.state.badRequest == null) ? : this.orderDetailsPage() ); } }