3.0.1 • Published 2 years ago
nuxt-metamask v3.0.1
Hello! I'm not very expert in creating modules, but I hope it can help someone 🧡🧡🧡
nuxt-metamask
Metamask support for
nuxt 3project with Web3
Installation
# using npm
npm install nuxt-metamask
# or yarn
yarn add nuxt-metamaskSetup
 1. Add nuxt-metamask dependency to your project
{
  modules: [
    // Simple usage
    'nuxt-metamask'
  ]
  
}Usage
  1. Use Component MetamaskProvider 
- Example using component MetamaskProviderin App.vue
<template>
  <MetamaskProvider>
      <!-- only if is not installed -->
      <template #not-installed>
          <h1>is not installed</h1>
      </template>
      <!-- only if is installed -->
      <template #installed>
          <h1>installed</h1>
      </template>
      <!-- default -->
      <h1>default slot</h1>
  
  </MetamaskProvider>
</template>
 States
2. using states in template
- Metamask states
// get $metamask using `useNuxtapp`
const { $metamask } = useNuxtapp();
//states of $metamask.states
/*
{
  connected: boolean,
  address: string,
  chainId: number,
  installed: boolean,
}
*/- Example using states in template
<template>
  <div>
    <!-- show if not installed -->
    <div v-if="!$metamask.states.installed">
      <h3>Metamask is not installed</h3>
      <p>Install Metamask to use this app</p>
    </div>
    <!-- show if installed -->
    <div v-if="$metamask.states.installed">
      
      <h3>Metamask is already installed</h3>
      <p>Network Chain ID: {{ $metamask.states.chainId }}</p>
      <!-- show if connected -->
      <p v-if="$metamask.states.connected">
        Wallet: {{ $metamask.states.address }}
      </p>
      <!-- click to connect your wallet -->
      <button
        :disabled="$metamask.states.connected"
        @click="$metamask.connect()"
      >
        Connect your Wallet
      </button>
      
    </div>
  </div>
</template>
<script setup>
  //metamask plugin
  const $metamask = useMetamask();
</script>  3. Use $contracts methods
- Define a contract and use later
  // using composable 'useContracts'
  const $contracts = useContracts()
  //or
  // const $metamask = useMetamask();
  // abi example to get only the name
  const exampleAbi = [
    {
        "constant": true,
        "inputs": [],
        "name": "name",
        "outputs": [
            {
                "name": "",
                "type": "string"
            }
        ],
        "payable": false,
        "stateMutability": "view",
        "type": "function"
    },
    {
        "constant": false,
        "inputs": [
            {
                "name": "_to",
                "type": "address"
            },
            {
                "name": "_value",
                "type": "uint256"
            }
        ],
        "name": "transfer",
        "outputs": [
            {
                "name": "",
                "type": "bool"
            }
        ],
        "payable": false,
        "stateMutability": "nonpayable",
        "type": "function"
    }
  ]
  
  // define BUSD contract using Metamask provider - Smart Chain Testnet
  // using window.ethereum provider by default
  $contracts.define(
    "busd", 
    exampleAbi, 
    "0x78867bbeef44f2326bf8ddd1941a4439382ef2a7"
  )
  // or connect directly to  Smart Chain Testnet
  $contracts.define(
    "busd", 
    exampleAbi, 
    "0x78867bbeef44f2326bf8ddd1941a4439382ef2a7", 
    "https://data-seed-prebsc-1-s3.binance.org:8545" // custom rpc url
  )- executes the contract methods already defined
  // get $contracts & $metamask web3 instance
  const { $contracts, $metamask } = useNuxtApp()
  // call - get name of BUSD contract
  $contracts.call("busd", "name").then(console.log) // BUSD Token
  // or use
  $contracts.get("busd").methods.name().call().then(console.log)// BUSD Token
  // send - transfer token to another address
  $contracts.send(
    "busd", 
    "transfer", 
    [
      "0x0000000000000000000000000000000000000000", // address to send tokens
      $metamask.Web3.utils.toWei("10") //amount
    ], 
    {
      from: $metamask.states.address
    }
  ).then(console.log) 
  // get method encode by `encodeABI`
  $contracts.abi(
    "busd", 
    "name"
  )License
Copyright (c) Nuxt Community
3.0.1
2 years ago
2.1.1
2 years ago
2.0.7
2 years ago
2.0.9
2 years ago
2.0.8
2 years ago
2.1.0
2 years ago
2.0.5
3 years ago
2.0.6
3 years ago
2.0.4
3 years ago
2.0.22
3 years ago
2.0.2
3 years ago
2.0.1
3 years ago
2.0.0
3 years ago
1.1.8
3 years ago
1.1.7
3 years ago
1.1.6
3 years ago
1.1.5
3 years ago
1.1.4
3 years ago
1.1.3
3 years ago
1.1.2
3 years ago
1.1.1
3 years ago
1.1.0
3 years ago
1.0.9
3 years ago
1.0.8
3 years ago
1.0.7
3 years ago
1.0.6
3 years ago
1.0.5
3 years ago
1.0.4
3 years ago
1.0.3
3 years ago
1.0.2
3 years ago
1.0.1
3 years ago
1.0.0
3 years ago