added animation to receive tab
This commit is contained in:
parent
e6d4782f94
commit
1ee7ee4f76
4 changed files with 260 additions and 49 deletions
|
|
@ -4,6 +4,7 @@ angular.module('copayApp.controllers').controller('tabReceiveController', functi
|
||||||
|
|
||||||
$scope.isCordova = platformInfo.isCordova;
|
$scope.isCordova = platformInfo.isCordova;
|
||||||
$scope.isNW = platformInfo.isNW;
|
$scope.isNW = platformInfo.isNW;
|
||||||
|
$scope.walletAddrs = {};
|
||||||
|
|
||||||
$scope.shareAddress = function(addr) {
|
$scope.shareAddress = function(addr) {
|
||||||
if ($scope.generatingAddress) return;
|
if ($scope.generatingAddress) return;
|
||||||
|
|
@ -20,12 +21,19 @@ angular.module('copayApp.controllers').controller('tabReceiveController', functi
|
||||||
$scope.generatingAddress = false;
|
$scope.generatingAddress = false;
|
||||||
if (err) popupService.showAlert(gettextCatalog.getString('Error'), err);
|
if (err) popupService.showAlert(gettextCatalog.getString('Error'), err);
|
||||||
$scope.addr = addr;
|
$scope.addr = addr;
|
||||||
|
if ($scope.walletAddrs[$scope.wallet.id]) $scope.walletAddrs[$scope.wallet.id] = addr;
|
||||||
$timeout(function() {
|
$timeout(function() {
|
||||||
$scope.$apply();
|
$scope.$apply();
|
||||||
}, 10);
|
}, 10);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$scope.loadAddresses = function(wallet, index) {
|
||||||
|
walletService.getAddress(wallet, false, function(err, addr) {
|
||||||
|
$scope.walletAddrs[wallet.id] = addr || null;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
$scope.goCopayers = function() {
|
$scope.goCopayers = function() {
|
||||||
$ionicHistory.removeBackView();
|
$ionicHistory.removeBackView();
|
||||||
$ionicHistory.nextViewOptions({
|
$ionicHistory.nextViewOptions({
|
||||||
|
|
@ -67,7 +75,32 @@ angular.module('copayApp.controllers').controller('tabReceiveController', functi
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$scope.setWallet = function(index) {
|
||||||
|
$scope.wallet = $scope.wallets[index];
|
||||||
|
$scope.walletIndex = index;
|
||||||
|
if ($scope.walletAddrs[$scope.walletIndex].addr) $scope.addr = $scope.walletAddrs[$scope.walletIndex].addr;
|
||||||
|
else $scope.setAddress(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
$scope.isActive = function(index) {
|
||||||
|
return $scope.wallets[index] == $scope.wallet;
|
||||||
|
}
|
||||||
|
|
||||||
|
$scope.walletPosition = function(index) {
|
||||||
|
if (index == $scope.walletIndex) return 'current';
|
||||||
|
if (index < $scope.walletIndex) return 'prev';
|
||||||
|
if (index > $scope.walletIndex) return 'next';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
$scope.$on('Wallet/Changed', function(event, wallet) {
|
$scope.$on('Wallet/Changed', function(event, wallet) {
|
||||||
|
$scope.wallet = wallet;
|
||||||
|
$scope.walletIndex = lodash.findIndex($scope.wallets, function(wallet) {
|
||||||
|
return wallet.id == $scope.wallet.id;
|
||||||
|
});
|
||||||
|
if (!$scope.walletAddrs[wallet.id]) $scope.setAddress(false);
|
||||||
|
else $scope.addr = $scope.walletAddrs[wallet.id];
|
||||||
|
$scope.$apply();
|
||||||
if (!wallet) {
|
if (!wallet) {
|
||||||
$log.debug('No wallet provided');
|
$log.debug('No wallet provided');
|
||||||
return;
|
return;
|
||||||
|
|
@ -77,14 +110,13 @@ angular.module('copayApp.controllers').controller('tabReceiveController', functi
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$scope.wallet = wallet;
|
$scope.wallet = wallet;
|
||||||
$scope.generatingAddress = false;
|
|
||||||
$log.debug('Wallet changed: ' + wallet.name);
|
$log.debug('Wallet changed: ' + wallet.name);
|
||||||
$timeout(function() {
|
|
||||||
$scope.setAddress(false);
|
|
||||||
}, 100);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$scope.$on("$ionicView.beforeEnter", function(event, data) {
|
$scope.$on("$ionicView.beforeEnter", function(event, data) {
|
||||||
$scope.wallets = profileService.getWallets();
|
$scope.wallets = profileService.getWallets();
|
||||||
|
lodash.each($scope.wallets, function(wallet, index) {
|
||||||
|
$scope.loadAddresses(wallet);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,7 @@
|
||||||
box-shadow:$subtle-box-shadow;
|
box-shadow:$subtle-box-shadow;
|
||||||
padding:0;
|
padding:0;
|
||||||
border-radius: 6px;
|
border-radius: 6px;
|
||||||
|
margin: 0 auto;
|
||||||
@media (min-width: 500px) {
|
@media (min-width: 500px) {
|
||||||
& {
|
& {
|
||||||
width: 350px;
|
width: 350px;
|
||||||
|
|
@ -64,10 +65,10 @@
|
||||||
transform: scale(.8);
|
transform: scale(.8);
|
||||||
}
|
}
|
||||||
&.swiper-slide-prev {
|
&.swiper-slide-prev {
|
||||||
left: 10vw;
|
left: 5vw;
|
||||||
}
|
}
|
||||||
&.swiper-slide-next {
|
&.swiper-slide-next {
|
||||||
left: -10vw;
|
left: -5vw;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,7 @@
|
||||||
.scroll{height:100%;}
|
.scroll{height:100%;}
|
||||||
#address {
|
#address {
|
||||||
background: #fff;
|
background: #fff;
|
||||||
height: calc(100vh - 33vh);
|
height: calc(100vh - 34vh);
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
|
|
@ -22,14 +22,26 @@
|
||||||
@media(max-height: 600px){
|
@media(max-height: 600px){
|
||||||
height: calc(100vh - 36vh);
|
height: calc(100vh - 36vh);
|
||||||
}
|
}
|
||||||
|
&-info{
|
||||||
|
height: 100%;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
article{
|
article{
|
||||||
flex:1;
|
flex:1;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
#bit-address{
|
#bit-address{
|
||||||
position: absolute;
|
width: 100%;
|
||||||
bottom:0;
|
align-self: flex-end;
|
||||||
width:100%;
|
margin-top: auto;
|
||||||
|
justify-content: center;
|
||||||
|
align-content: center;
|
||||||
|
position: relative;
|
||||||
|
min-height: 40px;
|
||||||
#next-address{
|
#next-address{
|
||||||
color:$light-gray;
|
color:$light-gray;
|
||||||
}
|
}
|
||||||
|
|
@ -58,6 +70,31 @@
|
||||||
}
|
}
|
||||||
.bit-address {
|
.bit-address {
|
||||||
font-size: .8rem;
|
font-size: .8rem;
|
||||||
|
// left:10%;
|
||||||
|
position: absolute;
|
||||||
|
transition: all .4s ease;
|
||||||
|
width:100%;
|
||||||
|
height: 100%;
|
||||||
|
z-index: 0;
|
||||||
|
position: absolute;
|
||||||
|
top:50%;
|
||||||
|
&, &.next{
|
||||||
|
left:100%;
|
||||||
|
transform: translate(100%, -40%);
|
||||||
|
}
|
||||||
|
&.next, &.prev{
|
||||||
|
z-index:2;
|
||||||
|
}
|
||||||
|
&.current, &.prev{
|
||||||
|
left:50%;
|
||||||
|
}
|
||||||
|
&.current{
|
||||||
|
transform: translate(-50%, -40%);
|
||||||
|
z-index: 3;
|
||||||
|
}
|
||||||
|
&.prev{
|
||||||
|
transform: translate(-150%, -40%);
|
||||||
|
}
|
||||||
.item {
|
.item {
|
||||||
padding-top: 5px;
|
padding-top: 5px;
|
||||||
padding-bottom: 5px;
|
padding-bottom: 5px;
|
||||||
|
|
@ -67,6 +104,32 @@
|
||||||
}
|
}
|
||||||
.qr {
|
.qr {
|
||||||
padding: calc(100vh - 85vh) 0 calc(100vh - 96vh);
|
padding: calc(100vh - 85vh) 0 calc(100vh - 96vh);
|
||||||
|
align-self: center;
|
||||||
|
margin-top: auto;
|
||||||
|
height: 220px;
|
||||||
|
position: relative;
|
||||||
|
justify-content: center;
|
||||||
|
flex: 1;
|
||||||
|
div{
|
||||||
|
transition: all .4s ease;
|
||||||
|
&.current, &.prev, &.next{
|
||||||
|
position: absolute;
|
||||||
|
top:50%;
|
||||||
|
}
|
||||||
|
&.current, &.prev{
|
||||||
|
left:50%;
|
||||||
|
}
|
||||||
|
&.current{
|
||||||
|
transform: translate(-50%, -40%);
|
||||||
|
}
|
||||||
|
&.prev{
|
||||||
|
transform: translate(-150%, -40%);
|
||||||
|
}
|
||||||
|
&.next{
|
||||||
|
left:100%;
|
||||||
|
transform: translate(100%, -40%);
|
||||||
|
}
|
||||||
|
}
|
||||||
@media(max-height: 700px){
|
@media(max-height: 700px){
|
||||||
padding: calc(100vh - 90vh) 0 calc(100vh - 96vh);
|
padding: calc(100vh - 90vh) 0 calc(100vh - 96vh);
|
||||||
}
|
}
|
||||||
|
|
@ -74,13 +137,13 @@
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
position: relative;
|
||||||
|
min-height: 220px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#qr-options{
|
#qr-options{
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-content: center;
|
align-self: flex-end;
|
||||||
.item{
|
.item{
|
||||||
i{left:25px;}
|
i{left:25px;}
|
||||||
}
|
}
|
||||||
|
|
@ -90,6 +153,8 @@
|
||||||
color: #fff;
|
color: #fff;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
left:0;
|
||||||
|
z-index: 2;
|
||||||
i {
|
i {
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
}
|
}
|
||||||
|
|
@ -122,7 +187,7 @@
|
||||||
left: 50%;
|
left: 50%;
|
||||||
-webkit-transform: translateX(-50%);
|
-webkit-transform: translateX(-50%);
|
||||||
transform: translateX(-50%);
|
transform: translateX(-50%);
|
||||||
z-index: 2;
|
z-index: 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#first-time-tip {
|
#first-time-tip {
|
||||||
|
|
@ -165,6 +230,9 @@
|
||||||
border-right: 1px solid rgb(228, 228, 228);
|
border-right: 1px solid rgb(228, 228, 228);
|
||||||
padding-right: 10px;
|
padding-right: 10px;
|
||||||
}
|
}
|
||||||
|
#wallets{
|
||||||
|
#sidebar-wallet{display: none;}
|
||||||
|
}
|
||||||
.wallets{
|
.wallets{
|
||||||
position: relative;
|
position: relative;
|
||||||
height: calc(100vh - 83vh);
|
height: calc(100vh - 83vh);
|
||||||
|
|
@ -175,6 +243,17 @@
|
||||||
top: 50%;
|
top: 50%;
|
||||||
-webkit-transform: translate(-50%, -50%);
|
-webkit-transform: translate(-50%, -50%);
|
||||||
transform: translate(-50%, -50%);
|
transform: translate(-50%, -50%);
|
||||||
|
max-width: 450px;
|
||||||
|
.swiper-slide{
|
||||||
|
text-align: center;
|
||||||
|
.card{
|
||||||
|
margin-top:2vh;
|
||||||
|
display: inline-block;
|
||||||
|
width:80%;
|
||||||
|
}
|
||||||
|
&-next{left:-25%;}
|
||||||
|
&-prev{left:25%;}
|
||||||
|
}
|
||||||
@media (max-height: 600px){
|
@media (max-height: 600px){
|
||||||
&{
|
&{
|
||||||
-webkit-transform: translate(-50%, -58%);
|
-webkit-transform: translate(-50%, -58%);
|
||||||
|
|
@ -184,23 +263,107 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// @media(min-width: 700px) and (min-height: 700px){
|
@media(min-width: 700px) and (min-height: 700px){
|
||||||
// .wallets{display: none;}
|
.wallets{display: none;}
|
||||||
// #address{
|
#address{
|
||||||
// height:90vh;
|
float:left;
|
||||||
// width:75%;
|
height:90vh;
|
||||||
// .qr{
|
width:65%;
|
||||||
// height: 70%;
|
&-info{
|
||||||
// div{
|
height: 100%;
|
||||||
// transform: scale(1.5);
|
}
|
||||||
// }
|
.qr{
|
||||||
// }
|
height: 70%;
|
||||||
// #bit-address{
|
div{
|
||||||
// height: 10%;
|
opacity: 0;
|
||||||
// padding: calc(100vh - 99vh);
|
transition: none;
|
||||||
// }
|
&.current{
|
||||||
// }
|
opacity: 1;
|
||||||
// }
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.bit-address{
|
||||||
|
opacity: 0;
|
||||||
|
transition: none;
|
||||||
|
&.current{
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.backup, #bit-address{left:0;}
|
||||||
|
#bit-address{
|
||||||
|
height: 10%;
|
||||||
|
padding: calc(100vh - 99vh);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#wallets{
|
||||||
|
float:left;
|
||||||
|
width:35%;
|
||||||
|
height: 100%;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
overflow: visible;
|
||||||
|
#sidebar-wallet{display: block;}
|
||||||
|
.list{height: 100%;overflow: visible;}
|
||||||
|
#wallet-list{
|
||||||
|
position: absolute;
|
||||||
|
width: 100%;
|
||||||
|
overflow-y: scroll;
|
||||||
|
height: 100%;
|
||||||
|
left: -6%;
|
||||||
|
}
|
||||||
|
.wallet{
|
||||||
|
position: relative;
|
||||||
|
&.current{
|
||||||
|
&:before {
|
||||||
|
right: 93%;
|
||||||
|
top: 50%;
|
||||||
|
border: solid transparent;
|
||||||
|
content: " ";
|
||||||
|
height: 0;
|
||||||
|
width: 0;
|
||||||
|
position: absolute;
|
||||||
|
pointer-events: none;
|
||||||
|
border-right-color: #f2f2f2;
|
||||||
|
border-width: 20px;
|
||||||
|
margin-top: -20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.card {
|
||||||
|
max-width: 350px;
|
||||||
|
box-shadow:$subtle-box-shadow;
|
||||||
|
padding:0;
|
||||||
|
border-radius: 6px;
|
||||||
|
padding:2px;
|
||||||
|
width: 80%;
|
||||||
|
position: relative;
|
||||||
|
margin: 1.5rem auto 0;
|
||||||
|
.item{
|
||||||
|
padding: 6% 10% 6% 8%;
|
||||||
|
i{left:auto;}
|
||||||
|
span{
|
||||||
|
clear:both;
|
||||||
|
width: 100%;
|
||||||
|
display: inline-block;
|
||||||
|
&.wallet-name{
|
||||||
|
margin-top:10px;
|
||||||
|
margin-bottom:5px;
|
||||||
|
font-size:13px;
|
||||||
|
}
|
||||||
|
&.wallet-number{
|
||||||
|
visibility: hidden;
|
||||||
|
}
|
||||||
|
&.visible{
|
||||||
|
visibility: visible !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.big-icon-svg{
|
||||||
|
& > .bg{padding:.3rem;width: 40px;height:40px;}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@keyframes fadeIn {
|
@keyframes fadeIn {
|
||||||
|
|
|
||||||
|
|
@ -3,11 +3,11 @@
|
||||||
<ion-nav-title>{{'Receive' | translate}}</ion-nav-title>
|
<ion-nav-title>{{'Receive' | translate}}</ion-nav-title>
|
||||||
</ion-nav-bar>
|
</ion-nav-bar>
|
||||||
<ion-content scroll="false">
|
<ion-content scroll="false">
|
||||||
<div class="list card padding text-center" ng-if="!wallets[0]">
|
<article class="list card padding text-center" ng-if="!wallets[0]">
|
||||||
<span translate>No Wallet</span>
|
<span translate>No Wallet</span>
|
||||||
</div>
|
</article>
|
||||||
<div id="address" ng-if="wallets[0]">
|
<article id="address" ng-if="wallets[0]">
|
||||||
<article class="text-center" ng-if="!wallet">
|
<div id="address-info" class="text-center" ng-if="!wallet">
|
||||||
<div class="row qr">
|
<div class="row qr">
|
||||||
<div class="text-center col center-block">
|
<div class="text-center col center-block">
|
||||||
<div style="height:225px; width:220px; margin:auto; background: white; padding-top: 25%;">
|
<div style="height:225px; width:220px; margin:auto; background: white; padding-top: 25%;">
|
||||||
|
|
@ -23,8 +23,8 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</article>
|
</div>
|
||||||
<article class="text-center" ng-if="wallet && !wallet.isComplete()">
|
<div id="address-info" class="text-center" ng-if="wallet && !wallet.isComplete()">
|
||||||
<div class="incomplete">
|
<div class="incomplete">
|
||||||
<div class="title">
|
<div class="title">
|
||||||
<span translate>Incomplete wallet</span>
|
<span translate>Incomplete wallet</span>
|
||||||
|
|
@ -44,17 +44,17 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</article>
|
</div>
|
||||||
<article ng-if="wallet && wallet.isComplete()">
|
<div id="address-info" ng-if="wallet && wallet.isComplete()">
|
||||||
<div class="row backup" ng-show="wallet.needsBackup" ng-click="openBackupNeededModal()">
|
<div class="row backup" ng-show="wallet.needsBackup" ng-click="openBackupNeededModal()">
|
||||||
<div class="text-center col center-block">
|
<div class="text-center col center-block">
|
||||||
<i class="icon ion-alert"></i><span translate>Wallet not backed up</span><i class="icon ion-ios-arrow-thin-right"></i>
|
<i class="icon ion-alert"></i><span translate>Wallet not backed up</span><i class="icon ion-ios-arrow-thin-right"></i>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row qr">
|
<div class="row qr">
|
||||||
<div class="text-center col center-block" copy-to-clipboard="addr">
|
<div class="text-center col center-block" copy-to-clipboard="addr" ng-repeat="wallet in wallets track by $index" ng-class="walletPosition($index)">
|
||||||
<qrcode ng-if="addr" size="220" data="bitcoin:{{addr}}" color="#334"></qrcode>
|
<qrcode ng-if="walletAddrs[wallet.id]" size="220" data="bitcoin:{{walletAddrs[wallet.id]}}" color="#334"></qrcode>
|
||||||
<div ng-if="!addr" style="height:225px; width:220px; margin:auto; background: white; padding-top: 25%;">
|
<div ng-if="!walletAddrs[wallet.id]" style="height:225px; width:220px; margin:auto;padding-top: 25%;position:absolute;left:50%;top:50%;z-index:1;">
|
||||||
...
|
...
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
@ -72,20 +72,35 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div id="bit-address" class="row border-top">
|
<div id="bit-address" class="row border-top">
|
||||||
<div class="col col-90 center-block bit-address text-center">
|
<div class="center-block bit-address text-center" ng-repeat="wallet in wallets track by $index" ng-class="walletPosition($index)">
|
||||||
<div class="item item-icon-left item-icon-right">
|
<div class="item item-icon-left item-icon-right">
|
||||||
<i class="icon icon-svg receive-tab-bitcoin-icon"><img src="img/icon-bitcoin-symbol.svg"></i>
|
<i class="icon icon-svg receive-tab-bitcoin-icon"><img src="img/icon-bitcoin-symbol.svg"></i>
|
||||||
<span class="bit-address-gen-address" ng-if="generatingAddress">...</span>
|
<span class="bit-address-gen-address" ng-if="generatingAddress">...</span>
|
||||||
<span class="bit-address-gen-address" ng-if="!generatingAddress" copy-to-clipboard="addr">{{addr}}</span>
|
<span class="bit-address-gen-address" ng-if="!generatingAddress" copy-to-clipboard="walletAddrs[wallet.id]">{{walletAddrs[wallet.id]}}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</article>
|
|
||||||
</div>
|
|
||||||
<article id="wallets" ng-if="wallets[0]">
|
|
||||||
<div class="list">
|
|
||||||
<wallets wallets="wallets"></wallets>
|
|
||||||
</div>
|
</div>
|
||||||
</article>
|
</article>
|
||||||
|
<article id="wallets" ng-if="wallets[0]">
|
||||||
|
<div id="sidebar-wallet" class="list">
|
||||||
|
<div id="wallet-list">
|
||||||
|
<div class="wallet" ng-repeat="wallet in wallets track by $index" ng-click="setWallet($index)" ng-class="walletPosition($index)">
|
||||||
|
<div class="card">
|
||||||
|
<div class="item item-icon-left text-right" ng-class="{'noBalance': !wallet.status.availableBalanceStr}">
|
||||||
|
<i class="icon big-icon-svg">
|
||||||
|
<img src="img/icon-wallet.svg" ng-style="{'background-color': wallet.color}" class="bg"/>
|
||||||
|
</i>
|
||||||
|
<span class="wallet-name">{{wallet.name || wallet.id}}</span>
|
||||||
|
<span class="item-note m10l">
|
||||||
|
{{wallet.status.availableBalanceStr}}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<wallets id="wallet-slider" wallets="wallets" options="sliderOptions"></wallets>
|
||||||
|
</article>
|
||||||
</ion-content>
|
</ion-content>
|
||||||
</ion-view>
|
</ion-view>
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue