diff --git a/old/walletHome.js b/old/walletHome.js
index 79578d160..2cbd4d59d 100644
--- a/old/walletHome.js
+++ b/old/walletHome.js
@@ -665,20 +665,6 @@ angular.module('copayApp.controllers').controller('walletHomeController', functi
}, 1);
};
- this.openPPModal = function(paypro) {
- var fc = profileService.focusedClient;
- $scope.color = fc.backgroundColor;
- $scope.self = self;
- $scope.paypro = paypro;
-
- $ionicModal.fromTemplateUrl('views/modals/paypro.html', {
- scope: $scope
- }).then(function(modal) {
- $scope.payproModal = modal;
- $scope.payproModal.show();
- });
- };
-
this.setFromPayPro = function(uri, cb) {
if (!cb) cb = function() {};
diff --git a/public/views/confirm.html b/public/views/confirm.html
index d6669bbc3..b13559c79 100644
--- a/public/views/confirm.html
+++ b/public/views/confirm.html
@@ -33,6 +33,12 @@
{{toAddress}}
{{toName}}
+
+
+
+
+ {{_paypro.domain}}
+
diff --git a/public/views/modals/paypro.html b/public/views/modals/paypro.html
index d42b906be..20eecb676 100644
--- a/public/views/modals/paypro.html
+++ b/public/views/modals/paypro.html
@@ -1,4 +1,4 @@
-
+
@@ -12,10 +12,7 @@
@@ -23,38 +20,38 @@
-
Pay To
- {{paypro.domain}}
+ {{_paypro.domain}}
- -
+
-
Address
- {{paypro.toAddress}}
+ {{_paypro.toAddress}}
-
Certified by
-
+
- {{paypro.caName}}
+ {{_paypro.caName}}
(Trusted)
-
-
+
+
Self-signed Certificate
-
- {{paypro.caName}}
+
+ {{_paypro.caName}}
WARNING: UNTRUSTED CERTIFICATE
- -
+
-
Memo
- {{paypro.memo}}
+ {{_paypro.memo}}
- -
+
-
Expires
- {{paypro.expires * 1000 | amTimeAgo }}
+ {{_paypro.expires * 1000 | amTimeAgo }}
diff --git a/src/js/controllers/confirm.js b/src/js/controllers/confirm.js
index c617f6d81..de6a2601b 100644
--- a/src/js/controllers/confirm.js
+++ b/src/js/controllers/confirm.js
@@ -1,8 +1,9 @@
'use strict';
-angular.module('copayApp.controllers').controller('confirmController', function($rootScope, $scope, $filter, $timeout, $ionicScrollDelegate, gettextCatalog, walletService, platformInfo, lodash, configService, rateService, $stateParams, $window, $state, $log, profileService, bitcore, $ionicPopup, txStatus, gettext, txFormatService) {
+angular.module('copayApp.controllers').controller('confirmController', function($rootScope, $scope, $filter, $timeout, $ionicScrollDelegate, gettextCatalog, walletService, platformInfo, lodash, configService, rateService, $stateParams, $window, $state, $log, profileService, bitcore, $ionicPopup, txStatus, gettext, txFormatService, ongoingProcess, $ionicModal) {
var cachedTxp = {};
+ var isChromeApp = platformInfo.isChromeApp;
// An alert dialog
var showAlert = function(title, msg, cb) {
@@ -31,7 +32,7 @@ angular.module('copayApp.controllers').controller('confirmController', function(
$scope.description = $scope.data.comment;
$scope.txp = null;
- createTx($scope.wallet, $scope.toAddress, $scope.toAmount, $scope.data.comment, function(err, txp) {
+ createTx($scope.wallet, function(err, txp) {
if (err) return;
cachedTxp[$scope.wallet.id] = txp;
apply(txp);
@@ -40,9 +41,68 @@ angular.module('copayApp.controllers').controller('confirmController', function(
};
};
+
+ var setFromPayPro = function(uri, cb) {
+ if (!cb) cb = function() {};
+
+ var wallet = profileService.getWallets({
+ onlyComplete: true
+ })[0];
+
+ if (!wallet) return cb();
+
+ if (isChromeApp) {
+ showAlert(gettext('Payment Protocol not supported on Chrome App'));
+ return cb(true);
+ }
+
+ $log.debug('Fetch PayPro Request...', uri);
+
+ ongoingProcess.set('fetchingPayPro', true);
+ wallet.fetchPayPro({
+ payProUrl: uri,
+ }, function(err, paypro) {
+
+ ongoingProcess.set('fetchingPayPro', false);
+
+ if (err) {
+ $log.warn('Could not fetch payment request:', err);
+ var msg = err.toString();
+ if (msg.match('HTTP')) {
+ msg = gettext('Could not fetch payment information');
+ }
+ showAlert(msg);
+ return cb(true);
+ }
+
+ if (!paypro.verified) {
+ $log.warn('Failed to verify payment protocol signatures');
+ showAlert(gettext('Payment Protocol Invalid'));
+ return cb(true);
+ }
+
+ $stateParams.toAmount = paypro.amount;
+ $stateParams.toAddress = paypro.toAddress;
+ $stateParams.description = paypro.memo;
+ $stateParams.paypro = null;
+
+ $scope._paypro = paypro;
+ return $scope.init();
+ });
+ };
+
+
+
$scope.init = function() {
- // TODO (URL , etc)
+ if ($stateParams.paypro) {
+ return setFromPayPro($stateParams.paypro, function(err) {
+ if (err && !isChromeApp) {
+ showAlert(gettext('Could not fetch payment'));
+ }
+ });
+ }
+
if (!$stateParams.toAddress || !$stateParams.toAmount) {
$log.error('Bad params at amount')
throw ('bad params');
@@ -96,7 +156,7 @@ angular.module('copayApp.controllers').controller('confirmController', function(
apply(cachedTxp[wallet.id]);
} else {
stop = $timeout(function() {
- createTx(wallet, $scope.toAddress, $scope.toAmount, $scope.description, function(err, txp) {
+ createTx(wallet, function(err, txp) {
if (err) return;
cachedTxp[wallet.id] = txp;
apply(txp);
@@ -131,14 +191,15 @@ angular.module('copayApp.controllers').controller('confirmController', function(
$scope.$apply();
};
- var createTx = function(wallet, toAddress, toAmount, description, cb) {
+ var createTx = function(wallet, cb) {
var config = configService.getSync().wallet;
-
- //
var currentSpendUnconfirmed = config.spendUnconfirmed;
var outputs = [];
var paypro = $scope.paypro;
+ var toAddress = $scope.toAddress;
+ var toAmount = $scope.toAmount;
+ var description = $scope.description;
// ToDo: use a credential's (or fc's) function for this
if (description && !wallet.credentials.sharedEncryptingKey) {
@@ -170,7 +231,7 @@ angular.module('copayApp.controllers').controller('confirmController', function(
txp.outputs = outputs;
txp.message = description;
- txp.payProUrl = paypro ? paypro.url : null;
+ txp.payProUrl = paypro;
txp.excludeUnconfirmedUtxos = config.spendUnconfirmed ? false : true;
txp.feeLevel = config.settings.feeLevel || 'normal';
@@ -183,6 +244,17 @@ angular.module('copayApp.controllers').controller('confirmController', function(
};
+ $scope.openPPModal = function() {
+ $ionicModal.fromTemplateUrl('views/modals/paypro.html', {
+ scope: $scope
+ }).then(function(modal) {
+ $scope.payproModal = modal;
+ $scope.payproModal.show();
+ });
+ };
+
+
+
$scope.approve = function() {
var wallet = $scope.wallet;
var txp = $scope.txp;
diff --git a/src/js/controllers/modals/paypro.js b/src/js/controllers/modals/paypro.js
index 8d17ac21f..752a6e55e 100644
--- a/src/js/controllers/modals/paypro.js
+++ b/src/js/controllers/modals/paypro.js
@@ -3,12 +3,6 @@
angular.module('copayApp.controllers').controller('payproController', function($scope) {
var self = $scope.self;
- $scope.alternative = self.alternativeAmount;
- $scope.alternativeIsoCode = self.alternativeIsoCode;
- $scope.isRateAvailable = self.isRateAvailable;
- $scope.unitTotal = ($scope.paypro.amount * self.satToUnit).toFixed(self.unitDecimals);
- $scope.unitName = self.unitName;
-
$scope.cancel = function() {
$scope.payproModal.hide();
};
diff --git a/src/js/controllers/tab-send.js b/src/js/controllers/tab-send.js
index 2d8ca9b69..7cbf30980 100644
--- a/src/js/controllers/tab-send.js
+++ b/src/js/controllers/tab-send.js
@@ -1,9 +1,8 @@
'use strict';
-angular.module('copayApp.controllers').controller('tabSendController', function($scope, $ionicModal, $log, $timeout, addressbookService, profileService, lodash, $state, walletService, bitcore, platformInfo, ongoingProcess) {
+angular.module('copayApp.controllers').controller('tabSendController', function($scope, $ionicModal, $log, $timeout, addressbookService, profileService, lodash, $state, walletService, bitcore ) {
var originalList;
- var isChromeApp = platformInfo.isChromeApp;
// An alert dialog
@@ -52,47 +51,6 @@ angular.module('copayApp.controllers').controller('tabSendController', function(
};
- var setFromPayPro = function(uri, cb) {
- if (!cb) cb = function() {};
-
- var wallet = profileService.getWallets({onlyComplete: true})[0];
- if (!wallet) return cb();
-
- if (isChromeApp) {
- showAlert(gettext('Payment Protocol not supported on Chrome App'));
- return cb(true);
- }
-
- $log.debug('Fetch PayPro Request...', uri);
-
- ongoingProcess.set('fetchingPayPro', true);
- wallet.fetchPayPro({
- payProUrl: uri,
- }, function(err, paypro) {
- ongoingProcess.set('fetchingPayPro', false);
-
- if (err) {
- $log.warn('Could not fetch payment request:', err);
- var msg = err.toString();
- if (msg.match('HTTP')) {
- msg = gettext('Could not fetch payment information');
- }
- showAlert(msg);
- return cb(true);
- }
-
- if (!paypro.verified) {
- $log.warn('Failed to verify payment protocol signatures');
- showAlert(gettext('Payment Protocol Invalid'));
- return cb(true);
- }
-
- $state.go('send.confirm', {toAmount: paypro.amount, toAddress: paypro.toAddress, message:paypro.memo, paypro: uri})
- return cb();
- });
- };
-
-
var setFromUri = function(uri) {
function sanitizeUri(uri) {
@@ -129,20 +87,13 @@ angular.module('copayApp.controllers').controller('tabSendController', function(
var amount = parsed.amount ? parsed.amount : '';
if (parsed.r) {
- setFromPayPro(parsed.r, function(err) {
- if (err && addr && amount) {
- // TODO
- $state.go('send.confirm', {toAmount: amount, toAddress: addr, message:message})
- return addr;
- }
- });
+ $state.go('send.confirm', {paypro: parsed.r})
} else {
if (amount) {
- $state.go('send.confirm', {toAmount: amount, toAddress: addr, message:message})
+ $state.go('send.confirm', {toAmount: amount, toAddress: addr, description:message})
} else {
$state.go('send.amount', {toAddress: addr})
}
- return addr;
}
}
};
@@ -155,7 +106,7 @@ angular.module('copayApp.controllers').controller('tabSendController', function(
if (search.indexOf('bitcoin:') === 0) {
return setFromUri(search);
} else if (/^https?:\/\//.test(search)) {
- return setFromPayPro(search);
+ return $state.go('send.confirm', {paypro: search})
}
if (!search || search.length < 2) {