From 9bf571bdd7d5a93c4cb7f2499b9ad26e27dbb500 Mon Sep 17 00:00:00 2001 From: Javier Date: Tue, 19 Jul 2016 17:10:40 -0300 Subject: [PATCH] fix UI - fix set form (alt amount) --- public/views/modals/inputAmount.html | 43 +++++++++++++----------- src/js/controllers/modals/inputAmount.js | 37 ++++++++++++++------ src/js/controllers/walletHome.js | 12 +++++++ 3 files changed, 62 insertions(+), 30 deletions(-) diff --git a/public/views/modals/inputAmount.html b/public/views/modals/inputAmount.html index 28e360fda..66d28bc43 100644 --- a/public/views/modals/inputAmount.html +++ b/public/views/modals/inputAmount.html @@ -50,16 +50,29 @@ + +
+
+ +
+
-
-
- - +
+
+ +
+ diff --git a/src/js/controllers/modals/inputAmount.js b/src/js/controllers/modals/inputAmount.js index 0b3b60e69..91acce98a 100644 --- a/src/js/controllers/modals/inputAmount.js +++ b/src/js/controllers/modals/inputAmount.js @@ -1,6 +1,6 @@ 'use strict'; -angular.module('copayApp.controllers').controller('inputAmountController', function($rootScope, $scope, lodash, configService, go, rateService) { +angular.module('copayApp.controllers').controller('inputAmountController', function($rootScope, $scope, platformInfo, lodash, configService, go, rateService) { var unitToSatoshi; var satToUnit; var unitDecimals; @@ -11,12 +11,19 @@ angular.module('copayApp.controllers').controller('inputAmountController', funct $scope.unitName = config.unitName; $scope.alternativeIsoCode = config.alternativeIsoCode; $scope.specificAmount = $scope.specificAlternativeAmount = null; + $scope.isCordova = platformInfo.isCordova; unitToSatoshi = config.unitToSatoshi; satToUnit = 1 / unitToSatoshi; unitDecimals = config.unitDecimals; resetAmount(); }; + $scope.shareAddress = function(uri) { + if ($scope.isCordova) { + window.plugins.socialsharing.share(uri, null, null, null); + } + }; + $scope.toggleAlternative = function() { $scope.showAlternativeAmount = !$scope.showAlternativeAmount; var amount; @@ -110,8 +117,8 @@ angular.module('copayApp.controllers').controller('inputAmountController', funct if (lodash.isNumber(result)) { $scope.amount = $scope.alternativeAmount = val; - $scope.alternativeResult = fromFiat(result); $scope.amountResult = toFiat(result); + $scope.alternativeResult = fromFiat(result); } }; @@ -138,20 +145,28 @@ angular.module('copayApp.controllers').controller('inputAmountController', funct }; $scope.finish = function() { - var amount = toFiat($scope.alternativeResult); - var alternativeAmount = $scope.showAlternative ? fromFiat(amount) : toFiat(amount); + var amount; + var alternativeAmount; + + if ($scope.showAlternativeAmount) { + amount = $scope.alternativeResult; + alternativeAmount = evaluate(format($scope.alternativeAmount)); + } else { + amount = evaluate(format($scope.amount)); + alternativeAmount = toFiat(amount); + } if ($scope.address) { + var satToBtc = 1 / 100000000; + var amountSat = parseInt((amount * unitToSatoshi).toFixed(0)); + if ($scope.unitName == 'bits') { + $scope.specificAmountBtc = (amountSat * satToBtc).toFixed(8); + } + $scope.specificAmount = amount; $scope.specificAlternativeAmount = alternativeAmount; } else { - if ($scope.showAlternativeAmount) { - self.showAlternative = true; - self.setForm(null, alternativeAmount, null); - } else { - self.showAlternative = false; - self.setForm(null, amount, null); - } + self.setAmount(amount, alternativeAmount, $scope.showAlternativeAmount); $scope.cancel(); } }; diff --git a/src/js/controllers/walletHome.js b/src/js/controllers/walletHome.js index 980c509f6..69849cc72 100644 --- a/src/js/controllers/walletHome.js +++ b/src/js/controllers/walletHome.js @@ -346,6 +346,18 @@ angular.module('copayApp.controllers').controller('walletHomeController', functi }, 1); }; + this.setAmount = function(amount, alternativeAmount, useAlternativeAmount) { + var amountResult; + if (useAlternativeAmount) { + amountResult = parseFloat((rateService.fromFiat(alternativeAmount, self.alternativeIsoCode) * self.satToUnit).toFixed(self.unitDecimals), 10); + $scope.showAlternative = true; + } else { + amountResult = amount; + $scope.showAlternative = false; + } + self.setForm(null, amountResult, null); + }; + this.submitForm = function() { if (!$scope._amount || !$scope._address) return; var client = profileService.focusedClient;