2018-01-20 14:06:28 -06:00
|
|
|
import { WhitelistedCoins, bityConfig } from 'config';
|
2017-12-11 12:44:53 -05:00
|
|
|
import { checkHttpStatus, parseJSON, filter } from './utils';
|
2018-01-02 12:04:50 -06:00
|
|
|
import bitcoinIcon from 'assets/images/bitcoin.png';
|
|
|
|
import repIcon from 'assets/images/augur.png';
|
|
|
|
import etherIcon from 'assets/images/ether.png';
|
2017-12-11 12:44:53 -05:00
|
|
|
|
|
|
|
const isCryptoPair = (from: string, to: string, arr: WhitelistedCoins[]) => {
|
|
|
|
return filter(from, arr) && filter(to, arr);
|
|
|
|
};
|
2017-06-11 20:01:27 -05:00
|
|
|
|
2018-01-02 12:04:50 -06:00
|
|
|
const btcOptions = {
|
|
|
|
id: 'BTC',
|
|
|
|
status: 'available',
|
|
|
|
image: bitcoinIcon,
|
|
|
|
name: 'Bitcoin'
|
|
|
|
};
|
|
|
|
|
|
|
|
const ethOptions = {
|
|
|
|
id: 'ETH',
|
|
|
|
status: 'available',
|
|
|
|
image: etherIcon,
|
|
|
|
name: 'Ether'
|
|
|
|
};
|
|
|
|
|
|
|
|
const repOptions = {
|
|
|
|
id: 'REP',
|
|
|
|
status: 'available',
|
|
|
|
image: repIcon,
|
|
|
|
name: 'Augur'
|
|
|
|
};
|
|
|
|
|
2017-07-03 19:08:35 -05:00
|
|
|
export function getAllRates() {
|
|
|
|
const mappedRates = {};
|
2017-11-30 00:35:17 -05:00
|
|
|
return _getAllRates().then(bityRates => {
|
|
|
|
bityRates.objects.forEach(each => {
|
2017-07-03 19:08:35 -05:00
|
|
|
const pairName = each.pair;
|
2017-12-11 12:44:53 -05:00
|
|
|
const from = { id: pairName.substring(0, 3) };
|
|
|
|
const to = { id: pairName.substring(3, 6) };
|
|
|
|
// Check if rate exists= && check if the pair only crypto to crypto, not crypto to fiat, or any other combination
|
|
|
|
if (parseFloat(each.rate_we_sell) && isCryptoPair(from.id, to.id, ['BTC', 'ETH', 'REP'])) {
|
2018-01-02 12:04:50 -06:00
|
|
|
let fromOptions;
|
|
|
|
let toOptions;
|
|
|
|
switch (from.id) {
|
|
|
|
case 'BTC':
|
|
|
|
fromOptions = btcOptions;
|
|
|
|
break;
|
|
|
|
case 'ETH':
|
|
|
|
fromOptions = ethOptions;
|
|
|
|
break;
|
|
|
|
case 'REP':
|
|
|
|
fromOptions = repOptions;
|
|
|
|
}
|
|
|
|
switch (to.id) {
|
|
|
|
case 'BTC':
|
|
|
|
toOptions = btcOptions;
|
|
|
|
break;
|
|
|
|
case 'ETH':
|
|
|
|
toOptions = ethOptions;
|
|
|
|
break;
|
|
|
|
case 'REP':
|
|
|
|
toOptions = repOptions;
|
|
|
|
}
|
2017-12-11 12:44:53 -05:00
|
|
|
mappedRates[pairName] = {
|
|
|
|
id: pairName,
|
2018-01-02 12:04:50 -06:00
|
|
|
options: [fromOptions, toOptions],
|
2017-12-11 12:44:53 -05:00
|
|
|
rate: parseFloat(each.rate_we_sell)
|
|
|
|
};
|
|
|
|
}
|
2017-06-19 00:39:07 -05:00
|
|
|
});
|
2017-07-03 19:08:35 -05:00
|
|
|
return mappedRates;
|
|
|
|
});
|
2017-07-31 18:14:30 -05:00
|
|
|
}
|
|
|
|
|
2017-12-11 12:44:53 -05:00
|
|
|
export function postOrder(amount: number, destAddress: string, mode: number, pair: string) {
|
2017-07-31 18:14:30 -05:00
|
|
|
return fetch(`${bityConfig.serverURL}/order`, {
|
|
|
|
method: 'post',
|
|
|
|
body: JSON.stringify({
|
|
|
|
amount,
|
|
|
|
destAddress,
|
|
|
|
mode,
|
|
|
|
pair
|
|
|
|
}),
|
2017-11-30 00:35:17 -05:00
|
|
|
headers: new Headers(bityConfig.postConfig.headers)
|
2017-07-31 18:14:30 -05:00
|
|
|
})
|
|
|
|
.then(checkHttpStatus)
|
|
|
|
.then(parseJSON);
|
|
|
|
}
|
|
|
|
|
2017-09-24 19:06:28 -07:00
|
|
|
export function getOrderStatus(orderId: string) {
|
2017-07-31 18:14:30 -05:00
|
|
|
return fetch(`${bityConfig.serverURL}/status`, {
|
|
|
|
method: 'POST',
|
|
|
|
body: JSON.stringify({
|
2017-09-24 19:06:28 -07:00
|
|
|
orderid: orderId
|
2017-07-31 18:14:30 -05:00
|
|
|
}),
|
2017-11-30 00:35:17 -05:00
|
|
|
headers: new Headers(bityConfig.postConfig.headers)
|
2017-07-31 18:14:30 -05:00
|
|
|
})
|
|
|
|
.then(checkHttpStatus)
|
|
|
|
.then(parseJSON);
|
2017-07-03 19:08:35 -05:00
|
|
|
}
|
2017-06-11 20:01:27 -05:00
|
|
|
|
2017-07-03 19:08:35 -05:00
|
|
|
function _getAllRates() {
|
2017-09-05 15:07:28 -05:00
|
|
|
return fetch(`${bityConfig.bityURL}/v1/rate2/`)
|
2017-07-31 18:14:30 -05:00
|
|
|
.then(checkHttpStatus)
|
|
|
|
.then(parseJSON);
|
2017-11-30 00:35:17 -05:00
|
|
|
}
|