mirror of
https://github.com/RoboSats/robosats.git
synced 2025-08-14 05:37:16 +00:00
Merge branch 'main' into pre-release-fixes-v0.8.1
This commit is contained in:
@ -41,7 +41,7 @@ class WebAppInterface(private val context: MainActivity, private val webView: We
|
||||
|
||||
// Security patterns for input validation
|
||||
private val UUID_PATTERN = Pattern.compile("^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$", Pattern.CASE_INSENSITIVE)
|
||||
private val SAFE_STRING_PATTERN = Pattern.compile("^[a-zA-Z0-9\\s_\\-.,:;!?()\\[\\]{}]*$")
|
||||
private val SAFE_STRING_PATTERN = Pattern.compile("^[a-zA-Z0-9\s_\-.,:;!?()\[\]{}\"]*$")
|
||||
|
||||
// Maximum length for input strings
|
||||
private val MAX_INPUT_LENGTH = 1000
|
||||
|
@ -90,10 +90,10 @@ const BookControl = ({
|
||||
component = <SendReceiveIcon color='primary' />;
|
||||
text = t('Buy');
|
||||
} else if (value === 'swapin') {
|
||||
component = <SwapCalls color='secondary' />;
|
||||
component = <SwapCalls color='primary' />;
|
||||
text = t('Swap In');
|
||||
} else if (value === 'swapout') {
|
||||
component = <SwapCalls color='primary' />;
|
||||
component = <SwapCalls color='secondary' />;
|
||||
text = t('Swap Out');
|
||||
}
|
||||
|
||||
@ -159,14 +159,6 @@ const BookControl = ({
|
||||
</Typography>
|
||||
</div>
|
||||
</MenuItem>
|
||||
<MenuItem value='sell' style={{ width: '8em' }}>
|
||||
<div style={{ display: 'flex', alignItems: 'center', flexWrap: 'wrap' }}>
|
||||
<SendReceiveIcon color='secondary' sx={{ transform: 'scaleX(-1)' }} />
|
||||
<Typography sx={{ width: '2em' }} align='right' color='text.secondary'>
|
||||
{' ' + t('Sell')}
|
||||
</Typography>
|
||||
</div>
|
||||
</MenuItem>
|
||||
<MenuItem value='buy' style={{ width: '8em' }}>
|
||||
<div style={{ display: 'flex', alignItems: 'center', flexWrap: 'wrap' }}>
|
||||
<SendReceiveIcon color='primary' />
|
||||
@ -175,9 +167,17 @@ const BookControl = ({
|
||||
</Typography>
|
||||
</div>
|
||||
</MenuItem>
|
||||
<MenuItem value='sell' style={{ width: '8em' }}>
|
||||
<div style={{ display: 'flex', alignItems: 'center', flexWrap: 'wrap' }}>
|
||||
<SendReceiveIcon color='secondary' sx={{ transform: 'scaleX(-1)' }} />
|
||||
<Typography sx={{ width: '2em' }} align='right' color='text.secondary'>
|
||||
{' ' + t('Sell')}
|
||||
</Typography>
|
||||
</div>
|
||||
</MenuItem>
|
||||
<MenuItem value='swapin' style={{ width: '8em' }}>
|
||||
<div style={{ display: 'flex', alignItems: 'center', flexWrap: 'wrap' }}>
|
||||
<SwapCalls color='secondary' />
|
||||
<SwapCalls color='primary' />
|
||||
<Typography sx={{ width: '2em' }} align='right' color='text.secondary'>
|
||||
{' ' + t('Swap In')}
|
||||
</Typography>
|
||||
@ -185,7 +185,7 @@ const BookControl = ({
|
||||
</MenuItem>
|
||||
<MenuItem value='swapout' style={{ width: '8em' }}>
|
||||
<div style={{ display: 'flex', alignItems: 'center', flexWrap: 'wrap' }}>
|
||||
<SwapCalls color='primary' />
|
||||
<SwapCalls color='secondary' />
|
||||
<Typography sx={{ width: '2em' }} align='right' color='text.secondary'>
|
||||
{' ' + t('Swap Out')}
|
||||
</Typography>
|
||||
|
@ -423,6 +423,11 @@ const icons = {
|
||||
image:
|
||||
'',
|
||||
},
|
||||
usdc: {
|
||||
title: 'usdc',
|
||||
image:
|
||||
'',
|
||||
},
|
||||
venmo: {
|
||||
title: 'venmo',
|
||||
image:
|
||||
|
BIN
frontend/src/components/PaymentMethods/Icons/usdc.png
Normal file
BIN
frontend/src/components/PaymentMethods/Icons/usdc.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 146 KiB |
@ -60,6 +60,7 @@ export const fiatMethods: PaymentMethod[] = [
|
||||
{ name: 'Monero', icon: 'monero', reversible: false },
|
||||
{ name: 'USDT', icon: 'usdt', reversible: false },
|
||||
{ name: 'L-USDt', icon: 'usdtliquid', reversible: false },
|
||||
{ name: 'USDC', icon: 'usdc', reversible: false },
|
||||
{ name: 'Airtel Money', icon: 'airtel', reversible: false },
|
||||
{ name: 'MTN Money', icon: 'mtn', reversible: false },
|
||||
{ name: 'M-Pesa', icon: 'mpesa', reversible: false },
|
||||
|
@ -33,9 +33,9 @@ const StringAsIcons: React.FC<StringAsIconsProps> = ({
|
||||
|
||||
// Adds icons for each PaymentMethod that matches
|
||||
methods.forEach((method, i) => {
|
||||
const regex = new RegExp(`\\b${method.name}\\b`, 'g');
|
||||
const regex = new RegExp(`\\b${method.name.toLowerCase()}\\b`, 'g');
|
||||
|
||||
if (regex.test(customMethods)) {
|
||||
if (regex.test(customMethods.toLowerCase())) {
|
||||
customMethods = customMethods.replace(regex, '');
|
||||
rows.push(
|
||||
<Tooltip
|
||||
|
@ -1,5 +1,5 @@
|
||||
ruff==0.12.5
|
||||
coverage==7.10.0
|
||||
ruff==0.12.7
|
||||
coverage==7.10.1
|
||||
git+https://github.com/Reckless-Satoshi/drf-openapi-tester.git@soften-django-requirements
|
||||
pre-commit==4.2.0
|
||||
python-dotenv[cli]==1.1.1
|
||||
|
Reference in New Issue
Block a user