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:
parent
203376a20f
commit
cd588622ea
@ -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;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -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
9
src/utils/debounce.ts
Normal 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)
|
||||||
|
}
|
||||||
|
}
|
@ -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>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user