2014-03-26 09:18:42 -03:00
|
|
|
'use strict';
|
|
|
|
|
|
2014-10-30 14:13:40 -03:00
|
|
|
angular.module('copayApp.controllers').controller('ReceiveController',
|
2014-11-29 18:35:48 -03:00
|
|
|
function($scope, $rootScope, $timeout, $modal) {
|
2014-05-19 17:51:21 -03:00
|
|
|
|
2014-04-14 16:48:12 -03:00
|
|
|
$scope.newAddr = function() {
|
2014-10-28 11:34:19 -03:00
|
|
|
var w = $rootScope.wallet;
|
2014-05-19 17:51:21 -03:00
|
|
|
$scope.loading = true;
|
2014-11-28 18:43:22 -03:00
|
|
|
w.generateAddress(null);
|
2014-11-30 03:23:15 -03:00
|
|
|
$scope.setAddressList();
|
2014-11-28 18:43:22 -03:00
|
|
|
$timeout(function() {
|
|
|
|
|
$scope.loading = false;
|
|
|
|
|
}, 1);
|
2014-04-14 16:48:12 -03:00
|
|
|
};
|
|
|
|
|
|
2014-12-04 10:36:58 -03:00
|
|
|
$scope.init = function() {
|
|
|
|
|
$rootScope.title = 'Receive';
|
|
|
|
|
$scope.showAll = false;
|
|
|
|
|
|
|
|
|
|
var w = $rootScope.wallet;
|
|
|
|
|
var lastAddr = _.first(w.getAddressesOrderer());
|
|
|
|
|
var balance = w.balanceInfo.balanceByAddr;
|
|
|
|
|
|
|
|
|
|
if (balance[lastAddr]>0)
|
|
|
|
|
$scope.loading = true;
|
|
|
|
|
|
|
|
|
|
while (balance && balance[lastAddr] > 0) {
|
|
|
|
|
$scope.newAddr();
|
|
|
|
|
lastAddr = w.generateAddress(null);
|
|
|
|
|
};
|
|
|
|
|
$scope.loading = false;
|
|
|
|
|
$scope.addr = lastAddr;
|
|
|
|
|
};
|
|
|
|
|
|
2014-07-18 11:23:45 -03:00
|
|
|
$scope.openAddressModal = function(address) {
|
2014-09-19 17:12:54 -03:00
|
|
|
var ModalInstanceCtrl = function($scope, $modalInstance, address) {
|
2014-07-18 11:23:45 -03:00
|
|
|
$scope.address = address;
|
2014-07-30 00:51:38 -03:00
|
|
|
|
2014-09-19 17:12:54 -03:00
|
|
|
$scope.cancel = function() {
|
2014-07-18 11:23:45 -03:00
|
|
|
$modalInstance.dismiss('cancel');
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$modal.open({
|
2014-07-18 18:51:55 -03:00
|
|
|
templateUrl: 'views/modals/qr-address.html',
|
2014-07-22 11:03:08 -03:00
|
|
|
windowClass: 'tiny',
|
2014-07-18 11:23:45 -03:00
|
|
|
controller: ModalInstanceCtrl,
|
|
|
|
|
resolve: {
|
2014-09-19 17:12:54 -03:00
|
|
|
address: function() {
|
|
|
|
|
return address;
|
|
|
|
|
}
|
2014-07-18 11:23:45 -03:00
|
|
|
}
|
|
|
|
|
});
|
2014-04-14 16:48:12 -03:00
|
|
|
};
|
2014-05-20 19:40:02 -03:00
|
|
|
|
2014-09-19 17:12:54 -03:00
|
|
|
$scope.toggleShowAll = function() {
|
|
|
|
|
$scope.showAll = !$scope.showAll;
|
2014-11-30 03:23:15 -03:00
|
|
|
$scope.setAddressList();
|
2014-09-19 17:12:54 -03:00
|
|
|
};
|
|
|
|
|
|
2014-11-30 03:23:15 -03:00
|
|
|
$scope.setAddressList = function() {
|
2014-12-04 10:36:58 -03:00
|
|
|
if ($scope.showAll) {
|
|
|
|
|
var w = $rootScope.wallet;
|
|
|
|
|
var balance = w.balanceInfo.balanceByAddr;
|
2014-09-19 17:12:54 -03:00
|
|
|
|
2014-12-04 10:36:58 -03:00
|
|
|
var addresses = w.getAddressesOrderer();
|
|
|
|
|
if (addresses) {
|
|
|
|
|
$scope.addrLength = addresses.length;
|
2014-11-30 03:23:15 -03:00
|
|
|
|
2014-12-04 10:36:58 -03:00
|
|
|
if (!$scope.showAll)
|
|
|
|
|
addresses = addresses.slice(0, 3);
|
2014-11-30 03:23:15 -03:00
|
|
|
|
2014-12-04 10:36:58 -03:00
|
|
|
var list = [];
|
|
|
|
|
_.each(addresses, function(address, index) {
|
|
|
|
|
list.push({
|
|
|
|
|
'index': index,
|
|
|
|
|
'address': address,
|
|
|
|
|
'balance': balance ? balance[address] : null,
|
|
|
|
|
'isChange': w.addressIsChange(address),
|
|
|
|
|
});
|
2014-05-20 19:40:02 -03:00
|
|
|
});
|
2014-12-04 10:36:58 -03:00
|
|
|
$scope.addresses = list;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
$scope.addresses = [];
|
2014-05-20 19:40:02 -03:00
|
|
|
}
|
2014-09-19 17:12:54 -03:00
|
|
|
};
|
2014-07-18 11:23:45 -03:00
|
|
|
}
|
|
|
|
|
);
|