add validations to search tokens form, also implemented core functions

Co-authored-by: brunoedcf <brest.dallacosta@outlook.com>
Co-authored-by: Esio Freitas <esio.gustavo@gmail.com>
This commit is contained in:
RcleydsonR 2022-11-25 17:05:21 -03:00
parent 203376a20f
commit cd588622ea
4 changed files with 58 additions and 13 deletions

View File

@ -4,7 +4,7 @@ export const useEtherStore = defineStore("ether", {
state: () => ({ state: () => ({
walletAddress: "", walletAddress: "",
balance: "", balance: "",
depositList: {}, depositList: [{}],
}), }),
actions: { actions: {
setWalletAddress(walletAddress: string) { setWalletAddress(walletAddress: string) {
@ -13,7 +13,7 @@ export const useEtherStore = defineStore("ether", {
setBalance(balance: string) { setBalance(balance: string) {
this.balance = balance; this.balance = balance;
}, },
setDepositList(depositList: {}) { setDepositList(depositList: any[]) {
this.depositList = depositList; this.depositList = depositList;
}, },
}, },

View File

@ -45,7 +45,6 @@ const connectProvider = async () => {
const events = await p2pContract.queryFilter(filter); const events = await p2pContract.queryFilter(filter);
console.log(events) console.log(events)
etherStore.setDepositList(events); etherStore.setDepositList(events);
connection.on("accountsChanged", (accounts: string[]) => { connection.on("accountsChanged", (accounts: string[]) => {
@ -129,6 +128,11 @@ const formatEther = (balance: string) => {
return formatted; return formatted;
}; };
const verifyDepositAmmount = (ammountBigNumber: BigNumber) => {
return ethers.utils.formatEther(ammountBigNumber)
}
const getProvider = (): ethers.providers.Web3Provider | null => { const getProvider = (): ethers.providers.Web3Provider | null => {
const window_ = window as any; const window_ = window as any;
const connection = window_.ethereum; const connection = window_.ethereum;
@ -138,4 +142,4 @@ const getProvider = (): ethers.providers.Web3Provider | null => {
return new ethers.providers.Web3Provider(connection); return new ethers.providers.Web3Provider(connection);
}; };
export default { connectProvider, formatEther, splitTokens, mockDeposit, countDeposit, mapDeposits }; export default { connectProvider, formatEther, splitTokens, mockDeposit, countDeposit, mapDeposits, verifyDepositAmmount };

9
src/utils/debounce.ts Normal file
View File

@ -0,0 +1,9 @@
export const debounce = (func: any, delay: number) => {
let timer: any = null
return function (this: unknown, ...args: any) {
clearTimeout(timer)
timer = setTimeout(() => {
func.apply(this, args)
}, delay)
}
}

View File

@ -1,11 +1,43 @@
<script setup lang="ts"> <script setup lang="ts">
import { ref } from "vue"; import { ref } from "vue";
import CustomButton from "../components/CustomButton.vue"; import CustomButton from "../components/CustomButton.vue";
import { debounce } from "@/utils/debounce";
import { ethers } from "ethers";
import { useEtherStore } from "@/store/ether";
import { storeToRefs } from "pinia";
import blockchain from "../utils/blockchain";
const TAX_CONVERSION = 1.005
const etherStore = useEtherStore();
const { depositList } = storeToRefs(etherStore);
const searchClick = () => { const searchClick = () => {
console.log(value); console.log("pass the deposit and token value ammount to next screen")
}; };
const value = ref<Number>() const valueConversion = (event: any) => {
const { value } = event.target
valueToToken.value = Number(value) / TAX_CONVERSION
enableSelectButton.value = false;
selectedDeposit.value = null;
depositList.value.forEach((deposit) => {
const p2pixTokenValue = blockchain.verifyDepositAmmount(deposit.args.amount);
if(valueToToken.value!! <= Number(p2pixTokenValue)){
enableSelectButton.value = true;
selectedDeposit.value = deposit
return;
}
})
}
const valueToToken = ref<Number>(0);
const enableSelectButton = ref(false);
const selectedDeposit = ref();
</script> </script>
<template> <template>
@ -23,17 +55,17 @@ const value = ref<Number>()
class="flex flex-col justify-center items-center px-8 py-6 gap-2 rounded-lg shadow-md shadow-gray-600 backdrop-blur-md w-1/3 mt-10" class="flex flex-col justify-center items-center px-8 py-6 gap-2 rounded-lg shadow-md shadow-gray-600 backdrop-blur-md w-1/3 mt-10"
> >
<div <div
class="flex justify-between w-full bg-white px-10 py-5 rounded-lg border-y-10 relative gap-1" class="flex justify-between w-full bg-white px-8 py-5 rounded-lg border-y-10 relative gap-2"
> >
<p class="text-xl font-normal text-gray-900 mr-1" v-if="value != undefined && value.toString() != ''">R$</p> <p class="text-xl font-normal text-gray-900" v-if="valueToToken != undefined && valueToToken != 0">R$</p>
<input <input
type="number" type="number"
class="border-none outline-none text-lg text-gray-900 w-full" class="border-none outline-none text-lg text-gray-900 w-full"
v-bind:class="{ 'font-semibold': value != undefined, 'text-xl': value != undefined}" v-bind:class="{ 'font-semibold': valueToToken != undefined, 'text-xl': valueToToken != undefined}"
placeholder="Digite o valor que deseja pagar" placeholder="Digite o valor que deseja pagar"
v-model="value" @input="debounce(valueConversion, 500)($event)"
/> />
<p class="text-xl font-normal text-gray-900" v-if="value == undefined || value.toString() == ''">R$</p> <p class="text-xl font-normal text-gray-900" v-if="valueToToken == undefined || valueToToken == 0">R$</p>
</div> </div>
<div <div
class="flex flex-col w-full bg-white px-10 py-5 rounded-lg border-y-10" class="flex flex-col w-full bg-white px-10 py-5 rounded-lg border-y-10"
@ -45,7 +77,7 @@ const value = ref<Number>()
</div> </div>
<div class="flex justify-between w-full items-center"> <div class="flex justify-between w-full items-center">
<p class="text-3xl text-gray-900">0</p> <p class="text-3xl text-gray-900">{{valueToToken.toFixed(3)}}</p>
<div class="flex flex-row p-2 px-3 bg-gray-300 rounded-full"> <div class="flex flex-row p-2 px-3 bg-gray-300 rounded-full">
<img alt="Ethereum image" class="mr-3" src="@/assets/brz.svg" /> <img alt="Ethereum image" class="mr-3" src="@/assets/brz.svg" />
<p class="text-gray-900 text-lg">BRZ</p> <p class="text-gray-900 text-lg">BRZ</p>
@ -63,7 +95,7 @@ const value = ref<Number>()
</div> </div>
<CustomButton <CustomButton
:text="'Selecionar Oferta'" :text="'Selecionar Oferta'"
:is-disabled="false" :is-disabled="!enableSelectButton"
@clicked="searchClick()" @clicked="searchClick()"
/> />
</div> </div>