mirror of
https://github.com/RoboSats/robosats.git
synced 2025-01-05 14:00:09 +00:00
209 lines
6.2 KiB
TypeScript
209 lines
6.2 KiB
TypeScript
|
import React, { 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 } from '../../models';
|
||
|
import { apiClient } from '../../services/api';
|
||
|
|
||
|
interface OrderPageProps {
|
||
|
windowSize: { width: number; height: number };
|
||
|
order: Order;
|
||
|
setOrder: (state: Order) => void;
|
||
|
setCurrentOrder: (state: number) => void;
|
||
|
fetchOrder: () => void;
|
||
|
badOrder: string | undefined;
|
||
|
setBadOrder: (state: string | undefined) => void;
|
||
|
hasRobot: boolean;
|
||
|
setPage: (state: Page) => void;
|
||
|
baseUrl: string;
|
||
|
locationOrderId: number;
|
||
|
}
|
||
|
|
||
|
const OrderPage = ({
|
||
|
windowSize,
|
||
|
order,
|
||
|
setOrder,
|
||
|
setCurrentOrder,
|
||
|
badOrder,
|
||
|
setBadOrder,
|
||
|
setPage,
|
||
|
hasRobot = false,
|
||
|
baseUrl,
|
||
|
locationOrderId,
|
||
|
}: OrderPageProps): JSX.Element => {
|
||
|
const { t } = useTranslation();
|
||
|
const history = useHistory();
|
||
|
|
||
|
const doublePageWidth: number = 50;
|
||
|
const maxHeight: number = windowSize.height * 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 (
|
||
|
<Box>
|
||
|
{order == undefined && badOrder == undefined ? <CircularProgress /> : null}
|
||
|
{badOrder != undefined ? (
|
||
|
<Typography align='center' variant='subtitle2' color='secondary'>
|
||
|
{t(badOrder)}
|
||
|
</Typography>
|
||
|
) : null}
|
||
|
{order != undefined && badOrder == undefined ? (
|
||
|
order.is_participant ? (
|
||
|
windowSize.width > doublePageWidth ? (
|
||
|
// DOUBLE PAPER VIEW
|
||
|
<Grid
|
||
|
container
|
||
|
direction='row'
|
||
|
justifyContent='center'
|
||
|
alignItems='flex-start'
|
||
|
spacing={2}
|
||
|
style={{ width: '43em' }}
|
||
|
>
|
||
|
<Grid item xs={6} style={{ width: '21em' }}>
|
||
|
<Paper
|
||
|
elevation={12}
|
||
|
style={{
|
||
|
width: '21em',
|
||
|
maxHeight: `${maxHeight}em`,
|
||
|
overflow: 'auto',
|
||
|
}}
|
||
|
>
|
||
|
<OrderDetails
|
||
|
order={order}
|
||
|
setOrder={setOrder}
|
||
|
baseUrl={baseUrl}
|
||
|
setPage={setPage}
|
||
|
hasRobot={hasRobot}
|
||
|
/>
|
||
|
</Paper>
|
||
|
</Grid>
|
||
|
<Grid item xs={6} style={{ width: '21em' }}>
|
||
|
<Paper
|
||
|
elevation={12}
|
||
|
style={{
|
||
|
width: '21em',
|
||
|
maxHeight: `${maxHeight}em`,
|
||
|
overflow: 'auto',
|
||
|
}}
|
||
|
>
|
||
|
<TradeBox
|
||
|
order={order}
|
||
|
setOrder={setOrder}
|
||
|
setBadOrder={setBadOrder}
|
||
|
baseUrl={baseUrl}
|
||
|
onRenewOrder={renewOrder}
|
||
|
onStartAgain={startAgain}
|
||
|
/>
|
||
|
</Paper>
|
||
|
</Grid>
|
||
|
</Grid>
|
||
|
) : (
|
||
|
// SINGLE PAPER VIEW
|
||
|
<Box>
|
||
|
<Box sx={{ borderBottom: 1, borderColor: 'divider', width: '21em' }}>
|
||
|
<Tabs
|
||
|
value={tab}
|
||
|
onChange={(mouseEvent, value) => setTab(value)}
|
||
|
variant='fullWidth'
|
||
|
>
|
||
|
<Tab label={t('Order')} value='order' />
|
||
|
<Tab label={t('Contract')} value='contract' />
|
||
|
</Tabs>
|
||
|
</Box>
|
||
|
<Paper
|
||
|
elevation={12}
|
||
|
style={{
|
||
|
width: '21em',
|
||
|
maxHeight: `${maxHeight}em`,
|
||
|
overflow: 'auto',
|
||
|
}}
|
||
|
>
|
||
|
<div style={{ display: tab == 'order' ? '' : 'none' }}>
|
||
|
<OrderDetails
|
||
|
order={order}
|
||
|
setOrder={setOrder}
|
||
|
baseUrl={baseUrl}
|
||
|
setPage={setPage}
|
||
|
hasRobot={hasRobot}
|
||
|
/>
|
||
|
</div>
|
||
|
<div style={{ display: tab == 'contract' ? '' : 'none' }}>
|
||
|
<TradeBox
|
||
|
order={order}
|
||
|
setOrder={setOrder}
|
||
|
setBadOrder={setBadOrder}
|
||
|
baseUrl={baseUrl}
|
||
|
onRenewOrder={renewOrder}
|
||
|
onStartAgain={startAgain}
|
||
|
/>
|
||
|
</div>
|
||
|
</Paper>
|
||
|
</Box>
|
||
|
)
|
||
|
) : (
|
||
|
<Paper
|
||
|
elevation={12}
|
||
|
style={{
|
||
|
width: '21em',
|
||
|
maxHeight: `${maxHeight}em`,
|
||
|
overflow: 'auto',
|
||
|
}}
|
||
|
>
|
||
|
<OrderDetails
|
||
|
order={order}
|
||
|
setOrder={setOrder}
|
||
|
baseUrl={baseUrl}
|
||
|
setPage={setPage}
|
||
|
hasRobot={hasRobot}
|
||
|
/>
|
||
|
</Paper>
|
||
|
)
|
||
|
) : (
|
||
|
<></>
|
||
|
)}
|
||
|
</Box>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default OrderPage;
|