1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-13 13:17:13 +01:00
metamask-extension/ui/pages/swaps/select-quote-popover/select-quote-popover.js

135 lines
3.8 KiB
JavaScript
Raw Normal View History

import React, { useState, useCallback, useContext } from 'react';
import PropTypes from 'prop-types';
import { I18nContext } from '../../../contexts/i18n';
import Popover from '../../../components/ui/popover';
import Button from '../../../components/ui/button';
import QuoteDetails from './quote-details';
import SortList from './sort-list';
import { QUOTE_DATA_ROWS_PROPTYPES_SHAPE } from './select-quote-popover-constants';
2020-10-06 20:28:38 +02:00
const SelectQuotePopover = ({
quoteDataRows = [],
onClose = null,
onSubmit = null,
swapToSymbol,
initialAggId,
onQuoteDetailsIsOpened,
hideEstimatedGasFee,
2020-10-06 20:28:38 +02:00
}) => {
const t = useContext(I18nContext);
2020-10-06 20:28:38 +02:00
const [sortDirection, setSortDirection] = useState(1);
const [sortColumn, setSortColumn] = useState(null);
2020-10-06 20:28:38 +02:00
const [selectedAggId, setSelectedAggId] = useState(initialAggId);
const [contentView, setContentView] = useState('sortList');
const [viewingAgg, setViewingAgg] = useState(null);
2020-10-06 20:28:38 +02:00
const onSubmitClick = useCallback(() => {
onSubmit(selectedAggId);
onClose();
}, [selectedAggId, onClose, onSubmit]);
2020-10-06 20:28:38 +02:00
const closeQuoteDetails = useCallback(() => {
setViewingAgg(null);
setContentView('sortList');
}, []);
2020-10-06 20:28:38 +02:00
2022-07-31 20:26:40 +02:00
const onRowClick = useCallback(
(aggId) => setSelectedAggId(aggId),
[setSelectedAggId],
);
2020-10-06 20:28:38 +02:00
2020-11-03 00:41:28 +01:00
const onCaretClick = useCallback(
(aggId) => {
const agg = quoteDataRows.find((quote) => quote.aggId === aggId);
setContentView('quoteDetails');
onQuoteDetailsIsOpened();
setViewingAgg(agg);
2020-11-03 00:41:28 +01:00
},
[quoteDataRows, onQuoteDetailsIsOpened],
);
2020-10-06 20:28:38 +02:00
2020-11-03 00:41:28 +01:00
const CustomBackground = useCallback(
() => (
<div className="select-quote-popover__popover-bg" onClick={onClose} />
),
[onClose],
);
2020-10-06 20:28:38 +02:00
const footer = (
<>
<Button
type="secondary"
2020-10-06 20:28:38 +02:00
className="page-container__footer-button select-quote-popover__button"
onClick={onClose}
>
2020-11-03 00:41:28 +01:00
{t('close')}
2020-10-06 20:28:38 +02:00
</Button>
<Button
type="primary"
2020-10-06 20:28:38 +02:00
className="page-container__footer-button select-quote-popover__button"
onClick={onSubmitClick}
>
2020-11-03 00:41:28 +01:00
{t('swapSelect')}
2020-10-06 20:28:38 +02:00
</Button>
</>
);
2020-10-06 20:28:38 +02:00
return (
<div className="select-quote-popover">
<Popover
2020-11-03 00:41:28 +01:00
title={
contentView === 'quoteDetails'
? t('swapSelectAQuote')
: t('swapQuoteDetails')
}
subtitle={
contentView === 'sortList'
? t('swapSelectQuotePopoverDescription')
: null
}
2020-10-06 20:28:38 +02:00
onClose={onClose}
CustomBackground={CustomBackground}
className="select-quote-popover__popover-wrap"
footerClassName="swaps__footer"
footer={contentView === 'quoteDetails' ? null : footer}
onBack={contentView === 'quoteDetails' ? closeQuoteDetails : null}
>
{contentView === 'sortList' && (
<SortList
quoteDataRows={quoteDataRows}
selectedAggId={selectedAggId}
onSelect={onRowClick}
onCaretClick={onCaretClick}
swapToSymbol={swapToSymbol}
sortDirection={sortDirection}
setSortDirection={setSortDirection}
sortColumn={sortColumn}
setSortColumn={setSortColumn}
hideEstimatedGasFee={hideEstimatedGasFee}
2020-10-06 20:28:38 +02:00
/>
)}
{contentView === 'quoteDetails' && viewingAgg && (
<QuoteDetails
{...viewingAgg}
hideEstimatedGasFee={hideEstimatedGasFee}
/>
2020-10-06 20:28:38 +02:00
)}
</Popover>
</div>
);
};
2020-10-06 20:28:38 +02:00
SelectQuotePopover.propTypes = {
onClose: PropTypes.func,
onSubmit: PropTypes.func,
swapToSymbol: PropTypes.string,
quoteDataRows: PropTypes.arrayOf(QUOTE_DATA_ROWS_PROPTYPES_SHAPE),
initialAggId: PropTypes.string,
onQuoteDetailsIsOpened: PropTypes.func,
hideEstimatedGasFee: PropTypes.bool.isRequired,
};
2020-10-06 20:28:38 +02:00
export default SelectQuotePopover;