import React, { useContext, useEffect, useState } from 'react'; import { useTranslation } from 'react-i18next'; import { Tab, Tabs, Paper, CircularProgress, Grid, Typography, Box } from '@mui/material'; import { useHistory } from 'react-router-dom'; import TradeBox from '../../components/TradeBox'; import OrderDetails from '../../components/OrderDetails'; import { Page } from '../NavBar'; import { Order, Settings } from '../../models'; import { apiClient } from '../../services/api'; import { AppContext, AppContextProps } from '../../contexts/AppContext'; interface OrderPageProps { hasRobot: boolean; locationOrderId: number; } const OrderPage = ({ hasRobot = false, locationOrderId }: OrderPageProps): JSX.Element => { const { windowSize, order, settings, setOrder, setCurrentOrder, badOrder, setBadOrder, setPage, baseUrl, navbarHeight, } = useContext(AppContext); const { t } = useTranslation(); const history = useHistory(); const doublePageWidth: number = 50; const maxHeight: number = (windowSize.height - navbarHeight) * 0.85 - 3; const [tab, setTab] = useState<'order' | 'contract'>('contract'); useEffect(() => setCurrentOrder(locationOrderId), []); const renewOrder = function () { if (order != undefined) { const body = { type: order.type, currency: order.currency, amount: order.has_range ? null : order.amount, has_range: order.has_range, min_amount: order.min_amount, max_amount: order.max_amount, payment_method: order.payment_method, is_explicit: order.is_explicit, premium: order.is_explicit ? null : order.premium, satoshis: order.is_explicit ? order.satoshis : null, public_duration: order.public_duration, escrow_duration: order.escrow_duration, bond_size: order.bond_size, bondless_taker: order.bondless_taker, }; apiClient.post(baseUrl, '/api/make/', body).then((data: any) => { if (data.bad_request) { setBadOrder(data.bad_request); } else if (data.id) { history.push('/order/' + data.id); setCurrentOrder(data.id); } }); } }; const startAgain = function () { history.push('/robot'); setPage('robot'); }; return ( {order == undefined && badOrder == undefined ? : null} {badOrder != undefined ? ( {t(badOrder)} ) : null} {order != undefined && badOrder == undefined ? ( order.is_participant ? ( windowSize.width > doublePageWidth ? ( // DOUBLE PAPER VIEW ) : ( // SINGLE PAPER VIEW setTab(value)} variant='fullWidth' >
) ) : ( ) ) : ( <> )}
); }; export default OrderPage;