bitcooo
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

590 lines
15 KiB

<template>
<view class="ac">
<navigation :showBack="false" :bgnum="true">
<image src="../../../../static/tongyonh/Vector.png" mode="aspectFit" class="back" @click="back()"></image>
<text class="big_title">
{{coin.name}} Transfer
</text>
</navigation>
<view class="main">
<view class="main_con">
<view class="yuan">
<image :src="coin.icon" mode="aspectFit" class="img1"></image>
</view>
<view class="title">
{{coin.name}}
</view>
<view class="item">
<view class="top flex">
<view class="text1">
Receiving address
</view>
<view class="text2" @click="goAddress('transfer')">
Adress Book
</view>
</view>
<view class="inputcon">
<input type="text" value="" placeholder-style="font-size: 30rpx; color: #D0D0D2;"
placeholder="Please enter the recipient address" class="input1"
v-model="transInfoPass.toAddress" />
<image src="../../../../static/tongyonh/Frame330.png" mode="aspectFit" class="img1"></image>
</view>
</view>
<view class="item">
<view class="top flex">
<view class="text1">
Transfer amount
</view>
</view>
<view class="inputcon2 flex">
<view class="inputc flex">
<view class="textt">
{{coin.name}}
</view>
<input type="text" value="" placeholder-style="font-size: 30rpx; color: #D0D0D2;"
placeholder="0.0000000" class="input3" v-model="transInfoPass.amount" />
</view>
<text>≈</text>
<view class="inputc flex">
<view class="textt">
USD
</view>
<input type="text" value="" disabled="disabled"
placeholder-style="font-size: 30rpx; color: #D0D0D2;" placeholder="0.0000000"
class="input3" />
</view>
</view>
<view class="top flex bottom">
<view class="text3">
Balance: {{coin.balance}}
</view>
<view class="text1 bg" @click="forAll">
ALL
</view>
</view>
</view>
<view class="item">
<view class="top flex">
<view class="text1">
Remark
</view>
</view>
<view class="inputcon">
<input type="text" value="" placeholder-style="font-size: 30rpx; color: #D0D0D2;"
placeholder="Please enter a note (off-chain)" v-model="transInfoPass.remark" class="input1" />
</view>
</view>
<view class="item">
<view class="top flex">
<view class="text1">
Transaction fee
</view>
</view>
<view class="inputcon">
<input type="text" v-model="fee" value="" placeholder-style="font-size: 30rpx; color: #D0D0D2;"
placeholder="Please enter a note (off-chain)" class="input2" />
<view class="rig">
<text class="text2">{{coin.type}}</text>
</view>
</view>
</view>
</view>
</view>
<view class="big_con" v-if="showBottom">
<view class="tiao" @click="cancelAll">
</view>
<view class="bigtitle">
Transfer confirmation
</view>
<view class="bottom_con">
<view class="yuan">
<image :src="coin.icon" mode="aspectFit" class="img1"></image>
</view>
<view class="title">
{{coin.type}}
</view>
<view class="title_con flex">
<view class="text1">
Amount
</view>
<view class="text1">
{{transInfoPass.amount}} {{coin.name}}
</view>
</view>
<view class="item">
<view class="text1">
Send address
</view>
<view class="text2">
{{transInfoPass.fromAddress}}
</view>
</view>
<view class="item">
<view class="text1">
Receiving address
</view>
<view class="text2">
{{transInfoPass.toAddress}}
</view>
</view>
<view class="item">
<view class="text1">
Remark
</view>
<view class="text2">
1.00 TRX
</view>
</view>
<view class="item">
<view class="text1">
Transaction fee
</view>
<view class="text2">
{{fee}} {{coin.type}}
</view>
</view>
<view class="goto" @click="confirmTo">
Confirm
</view>
</view>
</view>
<u-mask z-index="10" :show="show" @click="cancelAll"></u-mask>
<!-- <u-mask z-index="1000" :show="show2" @click="show2 = false"></u-mask> -->
<view class="zhiwen_con" v-if="showFinger">
<view class="tiao" @click="cancel">
</view>
<view class="bigtitle">
Fingerprint password
</view>
<view class="bottom_con">
<image src="../../../../static/tongyonh/zhiwen.png" mode="aspectFit" class="img1"></image>
<view class="text1">
Touch the fingerprint sensor
</view>
<view class="flex con">
<view class="textt1" @click="goPassword">
Use Password
</view>
<view class="textt2" @click="cancel">
Cancel
</view>
</view>
</view>
</view>
<view class="zhiwen_con" v-if="fingerFail">
<view class="tiao">
</view>
<view class="bigtitle">
Fingerprint password
</view>
<view class="bottom_con">
<image src="../../../../static/tongyonh/alert-circle.png" mode="aspectFit" class="img1"></image>
<view class="text1 red">
Fingerprint not recognized. <br><text @click="confirmTo('try')">Try again</text> .
</view>
<view class="flex con">
<view class="textt1" @click="goPassword">
Use Password
</view>
<view class="textt2" @click="cancelFail">
Cancel
</view>
</view>
</view>
</view>
<view class="zhiwen_con" v-if="fingerSuccess">
<view class="tiao">
</view>
<view class="bigtitle">
Fingerprint password
</view>
<view class="bottom_con">
<image src="../../../../static/tongyonh/x-circle.png" mode="aspectFit" class="img1"></image>
<view class="text1 green">
Fingerprint recognized.
</view>
<view class="flex con">
<view class="textt1">
Use Password
</view>
<view class="textt2">
Confirm
</view>
</view>
</view>
</view>
<view class="btn_con" @click="Confirm">
<view class="btn">
Confirm
</view>
</view>
</view>
</template>
<script>
import cont from "@/components/navigation/navigation.vue"
export default {
data() {
return {
coin: {},
fee: 0,
show: false,
show2: false,
showFinger: false,
showBottom: false,
fingerSuccess: false,
fingerFail: false,
// 是否显示使用密码,有设置指纹就不显示
passShow: false,
// 不用指纹去密码页面存的信息
transInfoPass: {
fromAddress: '',
toAddress: '1',
privateKey: '',
amount: '1',
remark:'1',
contractAddress:'',
password:''
}
}
},
methods: {
transaction() {
let that=this;
if (this.coin.type === 'ETH') {
this.$EthUtil.transaction(this.transInfoPass.fromAddress, this.transInfoPass.privateKey,
this.transInfoPass.toAddress, this.transInfoPass.amount, this.transInfoPass.contractAddress,
function(hash, err) {
if (!err) {
console.log(2222211111)
that.showFinger = false
that.showBottom = false;
that.fingerSuccess = true;
uni.showToast({
title: 'Transfer succeeded',
icon: 'none',
duration: 1500
})
setTimeout(() => {
that.fingerSuccess = false;
uni.reLaunch({
url: '/pages/menu/wallet/index'
})
}, 1000)
} else {
console.log(err, 'cuowu')
that.showFinger = false;
that.showBottom = true;
uni.showToast({
title: 'Transfer failed, please confirm the information is correct',
icon: 'none',
duration: 1500
})
}
})
} else if (this.coin.type === 'TRX') {
this.$TronUtil.transaction(this.transInfoPass.fromAddress, this.transInfoPass.privateKey,
this.transInfoPass.toAddress, this.transInfoPass.amount, this.transInfoPass.remark, this.transInfoPass.contractAddress)
.then((res) => {
console.log(1212121212121212)
that.showFinger = false
that.showBottom = false;
that.fingerSuccess = true;
uni.showToast({
title: 'Transfer succeeded',
icon: 'none',
duration: 1500
})
setTimeout(() => {
that.fingerSuccess = false;
uni.reLaunch({
url: '/pages/menu/wallet/index'
})
}, 1000)
}).catch(err => {
console.log(err, 'cuowu')
that.showFinger = false;
that.showBottom = true;
uni.showToast({
title: 'Transfer failed, please confirm the information is correct',
icon: 'none',
duration: 1500
})
})
}
},
cancelAll() {
this.show = false;
this.showBottom = false;
},
cancelFail() {
this.printCancel()
this.fingerFail = false
this.showBottom = true;
this.showFinger = false;
},
cancel() {
this.showFinger = false
this.showBottom = true;
this.printCancel()
},
// 不用指纹去密码页
goPassword() {
this.printCancel();
this.show = false;
this.showBottom=false;
console.log(111)
uni.setStorageSync('transInfoPass', this.transInfoPass)
uni.navigateTo({
url: '/pages/menu/sendToken/enPassword/index'
})
},
// 唤起指纹
confirmTo(type) {
if(!this.passShow){
this.goPassword();
}else{
console.log('点击提交')
if (type == 'try') {
this.fingerFail = false;
}
console.log(123123132132132)
this.show = true
this.showFinger = true
this.showBottom = false;
this.fingerprint();
}
},
back() {
uni.reLaunch({
url: '../../wallet/index'
})
},
// 点击获取所有钱
forAll() {
this.transInfoPass.amount = this.coin.balance
},
// 确认提交
Confirm() {
// 做判断
if (this.transInfoPass.amount == '') {
uni.showToast({
title: 'Please enter the transfer amount',
icon: 'none',
duration: 1500
})
return
}
if (this.transInfoPass.toAddress == '') {
uni.showToast({
title: 'Please enter the receiving address',
icon: 'none',
duration: 1500
})
return
}
if (Number(this.transInfoPass.amount) == '' < 0) {
uni.showToast({
title: 'The entered amount cannot be less than 0',
icon: 'none',
duration: 1500
})
return
}
if (Number(this.transInfoPass.amount) > this.coin.balance) {
uni.showToast({
title: 'Sorry, your credit is running low',
icon: 'none',
duration: 1500
})
return
}
this.showBottom = true;
this.show = true;
},
// 取消指纹识别
printCancel() {
this.showFinger = false;
console.log(this.showFinger, 4444)
//plus.fingerprint.cancel();
console.log(this.showFinger, 4444)
},
fingerprint: function(sett) {
let bltype = true;
// #ifdef APP-PLUS
if (!plus.fingerprint.isSupport()) {
uni.showToast({
title: 'This device does not support fingerprint identification',
icon: 'none',
duration: 1500
})
// this.disabled = true;
} else if (!plus.fingerprint.isKeyguardSecure()) {
uni.showToast({
title: 'This device is not equipped with a password lock screen and cannot use fingerprint identification',
icon: 'none',
duration: 1500
})
} else if (!plus.fingerprint.isEnrolledFingerprints()) {
uni.showToast({
title: 'There is no fingerprint entered in this device. Please turn it on in the setting',
icon: 'none',
duration: 1500
})
// this.disabled = true;
} else {
// this.result = '此设备支持指纹识别';
// // this.disabled = false;
// #ifdef MP-WEIXIN
// this.disabled = false;
uni.showToast({
title: 'Please use it in wechat real machine. The simulator does not support it',
icon: 'none',
duration: 1500
})
// #endif
// #ifndef APP-PLUS || MP-WEIXIN
uni.showToast({
title: 'Fingerprint identification is not supported on this platform',
icon: 'none',
duration: 1500,
})
// #endif
let that = this;
// #ifdef APP-PLUS
plus.fingerprint.authenticate(function() {
plus.nativeUI.closeWaiting(); //兼容Android平台关闭等待框
that.transaction()
}, function(e) {
switch (e.code) {
case e.AUTHENTICATE_MISMATCH:
// plus.nativeUI.toast('Fingerprint matching failed, please re-enter');
// uni.setStorageSync('fingerPass',false)
console.log(that.showFinger, 454545)
that.showBottom = false;
that.fingerFail = true;
console.log(that.fingerFail, 454545)
break;
case e.AUTHENTICATE_OVERLIMIT:
plus.nativeUI.closeWaiting(); //兼容Android平台关闭等待框
// plus.nativeUI.alert('The number of fingerprint identification failures exceeds the limit. Please use other methods for authentication');
// uni.setStorageSync('fingerPass',false)
console.log(that.showFinger, 454545)
that.showBottom = false;
that.fingerFail = true;
console.log(that.fingerFail, 454545)
break;
case e.CANCEL:
plus.nativeUI.toast('Recognition has been cancelled');
// uni.setStorageSync('fingerPass',false)
console.log(that.showFinger, 454545)
that.showBottom = false;
that.fingerFail = true;
console.log(that.fingerFail, 454545)
break;
default:
plus.nativeUI.closeWaiting(); //兼容Android平台关闭等待框
uni.setStorageSync('fingerPass', false)
console.log(that.showFinger, 454545)
that.showBottom = false;
that.fingerFail = true;
console.log(that.fingerFail, 454545)
plus.nativeUI.alert('Fingerprint identification failed, please try again');
break;
}
});
// Android平台手动弹出等待提示框
if ('Android' == plus.os.name) {
this.show = true;
/* plus.nativeUI.showWaiting('指纹识别中...').onclose = function() {
plus.fingerprint.cancel();
} */
}
// #endif
// 微信平台禁用
// #ifdef MP-WEIXIN
// wx.startSoterAuthentication({
// requestAuthModes: ['fingerPrint'],
// challenge: '123456',
// authContent: '请用指纹解锁',
// success(res) {
// uni.showToast({
// title: '识别成功',
// mask: false,
// duration: 1500
// });
// }
// })
// #endif
}
// #endif
},
goAddress(text) {
console.log(text)
uni.navigateTo({
url: '../address/index?item=' + text
})
}
},
onLoad() {
this.coin = uni.getStorageSync('coin')
// 每次进来拿缓存里有没有指纹
this.transInfoPass.fromAddress=this.coin.address;
this.transInfoPass.privateKey=this.coin.privateKey;
this.transInfoPass.password=this.coin.password;
this.transInfoPass.contractAddress=this.coin.contractAddress
this.transInfoPass.type=this.coin.type;
console.log(this.transInfoPass,'指纹')
if (uni.getStorageSync('fingerPass')) {
this.passShow = uni.getStorageSync('fingerPass')
}
}
};
</script>
<style scoped>
page {
background: #FAFAFA;
height: 100%;
}
</style>
<style>
@import './index.css';
</style>