Merge branch 'develop' into fix-request-decimals
This commit is contained in:
commit
0f9f76edc4
|
@ -0,0 +1,9 @@
|
||||||
|
|
||||||
|
// use dates as vars so they're not stripped out by minification
|
||||||
|
let letCheck = new Date();
|
||||||
|
const constCheck = new Date();
|
||||||
|
const arrowCheck = (() => new Date())();
|
||||||
|
|
||||||
|
if (letCheck && constCheck && arrowCheck) {
|
||||||
|
window.localStorage.setItem('goodBrowser', 'true');
|
||||||
|
}
|
|
@ -0,0 +1,33 @@
|
||||||
|
var badBrowser = false;
|
||||||
|
|
||||||
|
try {
|
||||||
|
// Local storage
|
||||||
|
window.localStorage.setItem('test', 'test');
|
||||||
|
window.localStorage.removeItem('test');
|
||||||
|
|
||||||
|
// Flexbox
|
||||||
|
var elTest = document.createElement('div');
|
||||||
|
elTest.style.display = 'flex';
|
||||||
|
if (elTest.style.display !== 'flex') {
|
||||||
|
badBrowser = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// const and let check from badBrowserCheckA.js
|
||||||
|
if (window.localStorage.goodBrowser !== 'true') {
|
||||||
|
badBrowser = true;
|
||||||
|
}
|
||||||
|
window.localStorage.removeItem('goodBrowser');
|
||||||
|
|
||||||
|
} catch (err) {
|
||||||
|
badBrowser = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (badBrowser) {
|
||||||
|
var el = document.getElementsByClassName('BadBrowser')[0];
|
||||||
|
el.className += ' is-open';
|
||||||
|
// Dumb check for known mobile OS's. Not important to catch all, just
|
||||||
|
// displays more appropriate information.
|
||||||
|
if (/iPhone|iPad|iPod|Android/i.test(navigator.userAgent)) {
|
||||||
|
el.className += ' is-mobile';
|
||||||
|
}
|
||||||
|
}
|
|
@ -100,6 +100,7 @@ class ConfirmationModalTemplateClass extends React.Component<Props, State> {
|
||||||
buttons={buttons}
|
buttons={buttons}
|
||||||
handleClose={onClose}
|
handleClose={onClose}
|
||||||
disableButtons={transactionBroadcasting}
|
disableButtons={transactionBroadcasting}
|
||||||
|
hideButtons={transactionBroadcasting}
|
||||||
isOpen={isOpen}
|
isOpen={isOpen}
|
||||||
>
|
>
|
||||||
{transactionBroadcasting ? (
|
{transactionBroadcasting ? (
|
||||||
|
|
|
@ -9,7 +9,8 @@ interface Props {
|
||||||
modalStyle?: CSSProperties;
|
modalStyle?: CSSProperties;
|
||||||
hasButtons?: number;
|
hasButtons?: number;
|
||||||
buttons?: IButton[];
|
buttons?: IButton[];
|
||||||
disableButtons?: any;
|
disableButtons?: boolean;
|
||||||
|
hideButtons?: boolean;
|
||||||
handleClose(): void;
|
handleClose(): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,7 +46,7 @@ export default class ModalBody extends React.Component<Props> {
|
||||||
};
|
};
|
||||||
|
|
||||||
public render() {
|
public render() {
|
||||||
const { title, children, modalStyle, hasButtons, handleClose } = this.props;
|
const { title, children, modalStyle, hasButtons, hideButtons, handleClose } = this.props;
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
className="Modal"
|
className="Modal"
|
||||||
|
@ -68,9 +69,9 @@ export default class ModalBody extends React.Component<Props> {
|
||||||
|
|
||||||
<div className="Modal-content" ref={div => (this.modalContent = div as HTMLElement)}>
|
<div className="Modal-content" ref={div => (this.modalContent = div as HTMLElement)}>
|
||||||
{children}
|
{children}
|
||||||
<div className={`Modal-fade ${!hasButtons ? 'has-no-footer' : ''}`} />
|
<div className={`Modal-fade ${!hasButtons || hideButtons ? 'has-no-footer' : ''}`} />
|
||||||
</div>
|
</div>
|
||||||
{hasButtons && <div className="Modal-footer">{this.renderButtons()}</div>}
|
{hasButtons && !hideButtons && <div className="Modal-footer">{this.renderButtons()}</div>}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@ interface Props {
|
||||||
isOpen?: boolean;
|
isOpen?: boolean;
|
||||||
title?: React.ReactNode;
|
title?: React.ReactNode;
|
||||||
disableButtons?: boolean;
|
disableButtons?: boolean;
|
||||||
|
hideButtons?: boolean;
|
||||||
children: React.ReactNode;
|
children: React.ReactNode;
|
||||||
buttons?: IButton[];
|
buttons?: IButton[];
|
||||||
maxWidth?: number;
|
maxWidth?: number;
|
||||||
|
@ -56,7 +57,16 @@ export default class Modal extends PureComponent<Props, {}> {
|
||||||
}
|
}
|
||||||
|
|
||||||
public render() {
|
public render() {
|
||||||
const { isOpen, title, children, buttons, handleClose, maxWidth } = this.props;
|
const {
|
||||||
|
isOpen,
|
||||||
|
title,
|
||||||
|
children,
|
||||||
|
buttons,
|
||||||
|
disableButtons,
|
||||||
|
hideButtons,
|
||||||
|
handleClose,
|
||||||
|
maxWidth
|
||||||
|
} = this.props;
|
||||||
const hasButtons = buttons && buttons.length;
|
const hasButtons = buttons && buttons.length;
|
||||||
const modalStyle: ModalStyle = {};
|
const modalStyle: ModalStyle = {};
|
||||||
|
|
||||||
|
@ -65,7 +75,16 @@ export default class Modal extends PureComponent<Props, {}> {
|
||||||
modalStyle.maxWidth = `${maxWidth}px`;
|
modalStyle.maxWidth = `${maxWidth}px`;
|
||||||
}
|
}
|
||||||
|
|
||||||
const modalBodyProps = { title, children, modalStyle, hasButtons, buttons, handleClose };
|
const modalBodyProps = {
|
||||||
|
title,
|
||||||
|
children,
|
||||||
|
modalStyle,
|
||||||
|
hasButtons,
|
||||||
|
buttons,
|
||||||
|
disableButtons,
|
||||||
|
hideButtons,
|
||||||
|
handleClose
|
||||||
|
};
|
||||||
|
|
||||||
const modal = (
|
const modal = (
|
||||||
<TransitionGroup>
|
<TransitionGroup>
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"name": "Bridge",
|
||||||
|
"address": "0x0000000000000000000000000000000001000006",
|
||||||
|
"abi":
|
||||||
|
"[{ \"name\": \"getFederationAddress\", \"type\": \"function\", \"constant\": true, \"inputs\": [], \"outputs\": [{ \"name\": \"\", \"type\": \"string\" }] }]"
|
||||||
|
}
|
||||||
|
]
|
|
@ -83,6 +83,11 @@ export const RSK_TESTNET: DPath = {
|
||||||
value: "m/44'/37310'/0'/0"
|
value: "m/44'/37310'/0'/0"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const RSK_MAINNET: DPath = {
|
||||||
|
label: 'Mainnet (RSK)',
|
||||||
|
value: "m/44'/137'/0'/0"
|
||||||
|
};
|
||||||
|
|
||||||
export const GO_DEFAULT: DPath = {
|
export const GO_DEFAULT: DPath = {
|
||||||
label: 'Default (GO)',
|
label: 'Default (GO)',
|
||||||
value: "m/44'/6060'/0'/0"
|
value: "m/44'/6060'/0'/0"
|
||||||
|
@ -114,6 +119,7 @@ export const DPaths: DPath[] = [
|
||||||
ETSC_DEFAULT,
|
ETSC_DEFAULT,
|
||||||
EGEM_DEFAULT,
|
EGEM_DEFAULT,
|
||||||
CLO_DEFAULT,
|
CLO_DEFAULT,
|
||||||
|
RSK_MAINNET,
|
||||||
RSK_TESTNET,
|
RSK_TESTNET,
|
||||||
GO_DEFAULT,
|
GO_DEFAULT,
|
||||||
EOSC_DEFAULT,
|
EOSC_DEFAULT,
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
[]
|
[]
|
|
@ -0,0 +1 @@
|
||||||
|
[]
|
|
@ -21,6 +21,7 @@ import {
|
||||||
ETSC_DEFAULT,
|
ETSC_DEFAULT,
|
||||||
EGEM_DEFAULT,
|
EGEM_DEFAULT,
|
||||||
CLO_DEFAULT,
|
CLO_DEFAULT,
|
||||||
|
RSK_MAINNET,
|
||||||
RSK_TESTNET,
|
RSK_TESTNET,
|
||||||
GO_DEFAULT,
|
GO_DEFAULT,
|
||||||
EOSC_DEFAULT,
|
EOSC_DEFAULT,
|
||||||
|
@ -205,7 +206,7 @@ export const STATIC_NETWORKS_INITIAL_STATE: StaticNetworksState = {
|
||||||
isCustom: false,
|
isCustom: false,
|
||||||
color: '#6d2eae',
|
color: '#6d2eae',
|
||||||
blockExplorer: makeExplorer({
|
blockExplorer: makeExplorer({
|
||||||
name: 'Etherchain Light',
|
name: 'POA Explorer',
|
||||||
origin: 'https://poaexplorer.com',
|
origin: 'https://poaexplorer.com',
|
||||||
addressPath: 'address/search',
|
addressPath: 'address/search',
|
||||||
blockPath: 'blocks/block'
|
blockPath: 'blocks/block'
|
||||||
|
@ -369,6 +370,32 @@ export const STATIC_NETWORKS_INITIAL_STATE: StaticNetworksState = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
RSK: {
|
||||||
|
id: 'RSK',
|
||||||
|
name: 'RSK',
|
||||||
|
unit: 'SBTC',
|
||||||
|
chainId: 30,
|
||||||
|
color: '#58A052',
|
||||||
|
isCustom: false,
|
||||||
|
blockExplorer: makeExplorer({
|
||||||
|
name: 'RSK Explorer',
|
||||||
|
origin: 'https://explorer.rsk.co'
|
||||||
|
}),
|
||||||
|
tokens: require('config/tokens/rsk.json'),
|
||||||
|
contracts: require('config/contracts/rsk.json'),
|
||||||
|
isTestnet: false,
|
||||||
|
dPathFormats: {
|
||||||
|
[SecureWalletName.TREZOR]: RSK_MAINNET,
|
||||||
|
[SecureWalletName.LEDGER_NANO_S]: RSK_MAINNET,
|
||||||
|
[InsecureWalletName.MNEMONIC_PHRASE]: RSK_MAINNET
|
||||||
|
},
|
||||||
|
gasPriceSettings: {
|
||||||
|
min: 0.183,
|
||||||
|
max: 1.5,
|
||||||
|
initial: 0.183
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
RSK_TESTNET: {
|
RSK_TESTNET: {
|
||||||
id: 'RSK_TESTNET',
|
id: 'RSK_TESTNET',
|
||||||
name: 'RSK',
|
name: 'RSK',
|
||||||
|
@ -380,8 +407,8 @@ export const STATIC_NETWORKS_INITIAL_STATE: StaticNetworksState = {
|
||||||
name: 'RSK Testnet Explorer',
|
name: 'RSK Testnet Explorer',
|
||||||
origin: 'https://explorer.testnet.rsk.co'
|
origin: 'https://explorer.testnet.rsk.co'
|
||||||
}),
|
}),
|
||||||
tokens: require('config/tokens/rsk.json'),
|
tokens: require('config/tokens/rsk_testnet.json'),
|
||||||
contracts: require('config/contracts/rsk.json'),
|
contracts: require('config/contracts/rsk_testnet.json'),
|
||||||
isTestnet: true,
|
isTestnet: true,
|
||||||
dPathFormats: {
|
dPathFormats: {
|
||||||
[SecureWalletName.TREZOR]: RSK_TESTNET,
|
[SecureWalletName.TREZOR]: RSK_TESTNET,
|
||||||
|
|
|
@ -71,40 +71,6 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script>
|
|
||||||
(function () {
|
|
||||||
var badBrowser = false;
|
|
||||||
|
|
||||||
try {
|
|
||||||
// Let and const
|
|
||||||
eval('let a = 1;');
|
|
||||||
eval('const b = 1');
|
|
||||||
|
|
||||||
// Local storage
|
|
||||||
window.localStorage.setItem('test', 'test');
|
|
||||||
window.localStorage.removeItem('test');
|
|
||||||
|
|
||||||
// Flexbox
|
|
||||||
var el = document.createElement('div');
|
|
||||||
el.style.display = 'flex';
|
|
||||||
if (el.style.display !== 'flex') {
|
|
||||||
badBrowser = false;
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
badBrowser = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (badBrowser) {
|
|
||||||
var el = document.getElementsByClassName('BadBrowser')[0];
|
|
||||||
el.className += ' is-open';
|
|
||||||
// Dumb check for known mobile OS's. Not important to catch all, just
|
|
||||||
// displays more appropriate information.
|
|
||||||
if (/iPhone|iPad|iPod|Android/i.test(navigator.userAgent)) {
|
|
||||||
el.className += ' is-mobile';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})();
|
|
||||||
</script>
|
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -108,9 +108,9 @@ export const NODE_CONFIGS: { [key in StaticNetworkIds]: RawNodeConfig[] } = {
|
||||||
POA: [
|
POA: [
|
||||||
{
|
{
|
||||||
name: makeNodeName('POA', 'core'),
|
name: makeNodeName('POA', 'core'),
|
||||||
type: 'rpc',
|
type: 'infura',
|
||||||
service: 'poa.network',
|
service: 'poa.infura.io',
|
||||||
url: 'https://core.poa.network'
|
url: 'https://poa.infura.io'
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
||||||
|
@ -168,6 +168,15 @@ export const NODE_CONFIGS: { [key in StaticNetworkIds]: RawNodeConfig[] } = {
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
||||||
|
RSK: [
|
||||||
|
{
|
||||||
|
name: makeNodeName('RSK', 'rsk_mainnet'),
|
||||||
|
type: 'rpc',
|
||||||
|
service: 'mycrypto.rsk.co',
|
||||||
|
url: 'https://mycrypto.rsk.co/'
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
RSK_TESTNET: [
|
RSK_TESTNET: [
|
||||||
{
|
{
|
||||||
name: makeNodeName('RSK_TESTNET', 'rsk_testnet'),
|
name: makeNodeName('RSK_TESTNET', 'rsk_testnet'),
|
||||||
|
|
|
@ -13,6 +13,7 @@ type StaticNetworkIds =
|
||||||
| 'ETSC'
|
| 'ETSC'
|
||||||
| 'EGEM'
|
| 'EGEM'
|
||||||
| 'CLO'
|
| 'CLO'
|
||||||
|
| 'RSK'
|
||||||
| 'RSK_TESTNET'
|
| 'RSK_TESTNET'
|
||||||
| 'GO'
|
| 'GO'
|
||||||
| 'EOSC'
|
| 'EOSC'
|
||||||
|
|
|
@ -16,6 +16,7 @@ configuredStore.getState();
|
||||||
const VALID_BTC_ADDRESS = '1MEWT2SGbqtz6mPCgFcnea8XmWV5Z4Wc6';
|
const VALID_BTC_ADDRESS = '1MEWT2SGbqtz6mPCgFcnea8XmWV5Z4Wc6';
|
||||||
const VALID_ETH_ADDRESS = '0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8';
|
const VALID_ETH_ADDRESS = '0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8';
|
||||||
const VALID_RSK_TESTNET_ADDRESS = '0x5aAeb6053F3e94c9b9A09F33669435E7EF1BEaEd';
|
const VALID_RSK_TESTNET_ADDRESS = '0x5aAeb6053F3e94c9b9A09F33669435E7EF1BEaEd';
|
||||||
|
const VALID_RSK_MAINNET_ADDRESS = '0x5aaEB6053f3e94c9b9a09f33669435E7ef1bEAeD';
|
||||||
const VALID_ETH_PRIVATE_KEY = '3f4fd89ea4970cc77bfd2d07a95786575ea62e183857afe6301578e1a3c5c782';
|
const VALID_ETH_PRIVATE_KEY = '3f4fd89ea4970cc77bfd2d07a95786575ea62e183857afe6301578e1a3c5c782';
|
||||||
const INVALID_ETH_PRIVATE_KEY = '3f4fd89ea4970cc77bfd2d07a95786575ea62e183857afe6301578e1a3c5ZZZZ';
|
const INVALID_ETH_PRIVATE_KEY = '3f4fd89ea4970cc77bfd2d07a95786575ea62e183857afe6301578e1a3c5ZZZZ';
|
||||||
const VALID_ETH_PRIVATE_BUFFER = Buffer.from(VALID_ETH_PRIVATE_KEY, 'hex');
|
const VALID_ETH_PRIVATE_BUFFER = Buffer.from(VALID_ETH_PRIVATE_KEY, 'hex');
|
||||||
|
@ -50,6 +51,12 @@ describe('Validator', () => {
|
||||||
it('should validate correct RSK address in RSK mainnet network as false', () => {
|
it('should validate correct RSK address in RSK mainnet network as false', () => {
|
||||||
expect(isValidAddress(VALID_RSK_TESTNET_ADDRESS, RSK_MAINNET_CHAIN_ID)).toBeFalsy();
|
expect(isValidAddress(VALID_RSK_TESTNET_ADDRESS, RSK_MAINNET_CHAIN_ID)).toBeFalsy();
|
||||||
});
|
});
|
||||||
|
it('should validate correct RSK address in RSK mainnet network as true', () => {
|
||||||
|
expect(isValidAddress(VALID_RSK_MAINNET_ADDRESS, RSK_MAINNET_CHAIN_ID)).toBeTruthy();
|
||||||
|
});
|
||||||
|
it('should validate correct RSK mainnet address in RSK testnet network as false', () => {
|
||||||
|
expect(isValidAddress(VALID_RSK_MAINNET_ADDRESS, RSK_TESTNET_CHAIN_ID)).toBeFalsy();
|
||||||
|
});
|
||||||
it('should validate an incorrect DPath as false', () => {
|
it('should validate an incorrect DPath as false', () => {
|
||||||
expect(isValidPath('m/44/60/0/0')).toBeFalsy();
|
expect(isValidPath('m/44/60/0/0')).toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
|
@ -32,6 +32,8 @@ module.exports = function(opts = {}) {
|
||||||
// ====== Entry =======
|
// ====== Entry =======
|
||||||
// ====================
|
// ====================
|
||||||
const entry = {
|
const entry = {
|
||||||
|
badBrowserCheckA: './common/badBrowserCheckA.js',
|
||||||
|
badBrowserCheckB: './common/badBrowserCheckB.js',
|
||||||
client: './common/index.tsx'
|
client: './common/index.tsx'
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue