2015-07-24 12:11:07 -03:00
|
|
|
'use strict';
|
|
|
|
|
|
2015-08-05 16:34:05 -03:00
|
|
|
angular.module('copayApp.services').factory('feeService', function($log, profileService, configService, gettextCatalog, lodash) {
|
2015-07-24 12:11:07 -03:00
|
|
|
var root = {};
|
|
|
|
|
|
2015-07-29 13:07:35 -03:00
|
|
|
// Constant fee options to translate
|
2015-07-30 15:26:16 -03:00
|
|
|
root.feeOpts = {
|
|
|
|
|
priority: gettextCatalog.getString('Priority'),
|
|
|
|
|
normal: gettextCatalog.getString('Normal'),
|
|
|
|
|
economy: gettextCatalog.getString('Economy')
|
|
|
|
|
};
|
2015-07-29 13:07:35 -03:00
|
|
|
|
2016-02-22 19:56:53 -03:00
|
|
|
root.getCurrentFeeLevel = function() {
|
|
|
|
|
return configService.getSync().wallet.settings.feeLevel || 'normal';
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
root.getCurrentFeeValue = function(cb) {
|
2015-07-24 12:11:07 -03:00
|
|
|
var fc = profileService.focusedClient;
|
2016-02-22 19:56:53 -03:00
|
|
|
var feeLevel = root.getCurrentFeeLevel();
|
2015-07-24 12:11:07 -03:00
|
|
|
// static fee
|
|
|
|
|
var fee = 10000;
|
|
|
|
|
fc.getFeeLevels(fc.credentials.network, function(err, levels) {
|
|
|
|
|
if (err) {
|
2015-07-28 10:42:11 -03:00
|
|
|
return cb({message: 'Could not get dynamic fee. Using static 10000sat'}, fee);
|
2015-07-24 12:11:07 -03:00
|
|
|
}
|
|
|
|
|
else {
|
2015-08-05 16:34:05 -03:00
|
|
|
fee = lodash.find(levels, { level: feeLevel }).feePerKB;
|
2015-08-13 11:07:24 -03:00
|
|
|
$log.debug('Dynamic fee: ' + feeLevel + ' ' + fee + ' SAT');
|
2015-07-24 12:11:07 -03:00
|
|
|
return cb(null, fee);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
root.getFeeLevels = function(cb) {
|
|
|
|
|
var fc = profileService.focusedClient;
|
2016-02-22 19:56:53 -03:00
|
|
|
var unitName = configService.getSync().wallet.settings.unitName;
|
2015-07-24 12:11:07 -03:00
|
|
|
|
|
|
|
|
fc.getFeeLevels('livenet', function(errLivenet, levelsLivenet) {
|
|
|
|
|
fc.getFeeLevels('testnet', function(errTestnet, levelsTestnet) {
|
2015-07-27 12:33:37 -03:00
|
|
|
if (errLivenet || errTestnet) $log.debug('Could not get dynamic fee');
|
|
|
|
|
else {
|
|
|
|
|
for (var i = 0; i < 3; i++) {
|
|
|
|
|
levelsLivenet[i]['feePerKBUnit'] = profileService.formatAmount(levelsLivenet[i].feePerKB) + ' ' + unitName;
|
|
|
|
|
levelsTestnet[i]['feePerKBUnit'] = profileService.formatAmount(levelsTestnet[i].feePerKB) + ' ' + unitName;
|
|
|
|
|
}
|
2015-07-24 12:23:30 -03:00
|
|
|
}
|
2015-07-24 12:11:07 -03:00
|
|
|
|
2015-07-24 12:23:30 -03:00
|
|
|
return cb({
|
|
|
|
|
'livenet': levelsLivenet,
|
|
|
|
|
'testnet': levelsTestnet
|
|
|
|
|
});
|
2015-07-24 12:11:07 -03:00
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return root;
|
|
|
|
|
});
|