mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-12 03:54:13 +00:00
9ef1920fe0
* Align footer to bottom * Fix request payment offset padding * Update request payment padding * Add new Input and Dropdown components * Fix offset margins in equiv vals * Update all send tx inputs & dropdowns * Update generate wallet dropdowns * Update inputs & dropdowns for contracts tab * Add inputs & dropdowns for all but swap tab * amend * Fix imports * inputs are invalid when not disabled or readonly * Fix offset refresh button * Add togglable password back to wallet generation * Update swap inputs, textareas, and dropdowns * Update any outstanding inputs * Make UnitDropDown searchable * unitdropdown searchanble if options > 10 * Fix css issues * Reset before setting currentTo
99 lines
3.0 KiB
TypeScript
99 lines
3.0 KiB
TypeScript
import React from 'react';
|
|
import './SupportFooter.scss';
|
|
import { SwapInput } from 'actions/swap';
|
|
import { NormalizedBityRates, NormalizedShapeshiftRates } from 'reducers/swap/types';
|
|
import { TextArea } from 'components/ui';
|
|
|
|
interface Props {
|
|
origin: SwapInput;
|
|
destination: SwapInput;
|
|
destinationAddress: string | null;
|
|
paymentAddress: string | null;
|
|
reference: string | null;
|
|
provider: string;
|
|
shapeshiftRates: NormalizedShapeshiftRates;
|
|
bityRates: NormalizedBityRates;
|
|
}
|
|
|
|
class SupportFooter extends React.PureComponent<Props, {}> {
|
|
public state = {
|
|
open: false
|
|
};
|
|
public render() {
|
|
const { open } = this.state;
|
|
const {
|
|
origin,
|
|
destination,
|
|
destinationAddress,
|
|
paymentAddress,
|
|
reference,
|
|
provider,
|
|
shapeshiftRates,
|
|
bityRates
|
|
} = this.props;
|
|
const pair = origin && destination ? origin.label + destination.label : 'BTCETH';
|
|
const rates = provider === 'shapeshift' ? shapeshiftRates.byId : bityRates.byId;
|
|
const emailTo =
|
|
provider === 'shapeshift' ? 'support@mycrypto.com' : 'support@mycrypto.com,mew@bity.com';
|
|
const mailSubject = encodeURI('Issue regarding my Swap via MyCrypto');
|
|
const serviceProvider = provider.charAt(0).toUpperCase() + provider.slice(1);
|
|
let mailBody;
|
|
let fallbackBody;
|
|
if (pair && rates && rates[pair]) {
|
|
mailBody = encodeURI(`Please include the below if this issue is regarding your order.
|
|
|
|
Provider: ${serviceProvider}
|
|
|
|
REF ID#: ${reference || ''}
|
|
|
|
Amount to send: ${origin.amount || ''} ${origin.label}
|
|
|
|
Amount to receive: ${destination.amount || ''} ${destination.label}
|
|
|
|
Payment Address: ${paymentAddress || ''}
|
|
|
|
Receiving Address: ${destinationAddress || ''}
|
|
|
|
Rate: ${rates[pair].rate} ${origin.label}/${destination.label}
|
|
`);
|
|
fallbackBody = `To: ${emailTo}
|
|
Subject: Issue regarding my Swap via MyCrypto
|
|
Message:
|
|
Provider: ${serviceProvider}
|
|
REF ID#: ${reference || ''}
|
|
Amount to send: ${origin.amount || ''} ${origin.label}
|
|
Amount to receive: ${destination.amount || ''} ${destination.label}
|
|
Payment Address: ${paymentAddress || ''}
|
|
Receiving Address: ${destinationAddress || ''}
|
|
Rate: ${rates[pair].rate} ${origin.label}/${destination.label}`;
|
|
}
|
|
return (
|
|
<section className="SupportFooter">
|
|
<a
|
|
className="btn-warning btn-sm"
|
|
href={`mailto:${emailTo}?Subject=${mailSubject}&Body=${mailBody}`}
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
>
|
|
Issue with your Swap? Contact support
|
|
</a>
|
|
<div className="SupportFooter-fallback">
|
|
<p onClick={this.toggleFallback}>
|
|
<small>Click here if link doesn't work</small>
|
|
</p>
|
|
{open ? (
|
|
<TextArea defaultValue={fallbackBody} className="form-control input-sm" rows={9} />
|
|
) : null}
|
|
</div>
|
|
</section>
|
|
);
|
|
}
|
|
private toggleFallback = () => {
|
|
this.setState({
|
|
open: !this.state.open
|
|
});
|
|
};
|
|
}
|
|
|
|
export default SupportFooter;
|