Along with the development of blockchain technology, Cryptocurrencies and assets have become more popular. It leads to a high demand for crypto wallets, that help users can safely store their tokens, cryptocurrencies, NFTs… In this article, we will guide you step-by-step on how to build a Chrome extension for a crypto wallet
Crypto wallet extension overview
Crypto wallet extension introduction
Crypto Wallet Extension allows users to securely manage and transfer cryptocurrency directly in their browser. It is also a place where users can interact with many decentralized applications (DApps) and control their data and digital assets through multiple blockchains.
Key features of a crypto wallet extension
- Multiple chain support
- Multiple wallet support
- Send, receive, swap token
- Store private key
- Simple and intuitive user interface
Chrome extension installation
You can follow the steps below to install a Chrome extension.
- Download source code
- Install node_modules. (npm i) package using node v20.10.0
- Build project (npm run build)
- Open Google Chrome and insert this link chrome://extensions/
- Turn on Developer mode.
- Click “Load unpacked” and then select folder build (folder name is ‘dist’)
- Use extension
After finishing all the steps above, you need to deploy the extension on Google Chrome. You can follow Google’s guideline to complete the deployment
How to build a crypto wallet Chrome extension
Build Chrome extension source code
Step 1: Use Vite to create source code reactjs + typescript. (You can refer Vite’s document)
data:image/s3,"s3://crabby-images/ce0d7/ce0d78848693134f985aa7d531ec7058c4d5db9c" alt=""
data:image/s3,"s3://crabby-images/86627/866273a7d1d747de9a9185dfc7212d0b218a5385" alt=""
data:image/s3,"s3://crabby-images/7138b/7138b02c235136b6dba50e21845a0c1c929c45e6" alt=""
Step 5: Integrate ethers to your project
- Create AppEthers file to process tasks related to wallet
data:image/s3,"s3://crabby-images/3d099/3d099014be62b6ca5a34e3bac98760b4d1821d17" alt=""
- Use crypto-js library to encrypt and decrypt the wallet.
data:image/s3,"s3://crabby-images/42ded/42ded11f1c5b31ec0f9572023dceff69d6b935e4" alt=""
- Initialize the client (by default, we will have two chains: Ethereum and Sepolia-Ethereum)
data:image/s3,"s3://crabby-images/9b683/9b6837774cb38ced272bf48b6995d712bb332d7b" alt=""
- Create the AppView class to handle functions and variables related to the blockchain in the extension.
data:image/s3,"s3://crabby-images/28986/2898652851f8d9da75a067a2a0ae6285c32c0875" alt=""
- Use client to process the mandatory features of the extension
data:image/s3,"s3://crabby-images/83bc2/83bc20eeb56fdeeeec96bbb31ac836a6050d3593" alt=""
data:image/s3,"s3://crabby-images/bc5d6/bc5d6a378cbc2c6f5273dd23163a256e1223de61" alt=""
data:image/s3,"s3://crabby-images/92d03/92d03da6fcd8cec0f7baba84b62cf5b82241433d" alt=""
Step 7: Use the chrome.storage.local và chrome.storage.session to manage storage
- Chrome.storage.local
data:image/s3,"s3://crabby-images/cd64d/cd64d248917eeda559d2a21074854007dacbe38a" alt=""
- Chrome.storage.session
data:image/s3,"s3://crabby-images/72db6/72db613a8aeb7b829afb96ad2aad5a1bdac8879d" alt=""
- useChain
data:image/s3,"s3://crabby-images/bbad6/bbad6677f738c4e6f86cd7c583aac87479405fad" alt=""
- useToken
data:image/s3,"s3://crabby-images/64534/64534c0e76ead55144e40d762eb36dddaed1af48" alt=""
- usePrice (use crypto-compare to get the price)
data:image/s3,"s3://crabby-images/fd33b/fd33b9cf8d9699c749e14afec44ccab82254034a" alt=""
Develop main features
1. Create an account
- Use appEthers to create 1 seed phrase
data:image/s3,"s3://crabby-images/f29a0/f29a0090746187d51d5df2cfa1270ebd62350201" alt=""
- From seed phrase, we use ethers to get the privateKey then we encrypt the password and save in your storage
data:image/s3,"s3://crabby-images/33d08/33d08f589b57367e6aa2b1352f1100ed616d5298" alt=""
data:image/s3,"s3://crabby-images/a9fc8/a9fc8ff9b55c2f45a1a2edece114772f94d0d79e" alt=""
- Use the useEstimateFee hook in order that estimate fee returned while sending
data:image/s3,"s3://crabby-images/e5b3d/e5b3d70a56e2cea2d77f11ba31263b2e47aae2cc" alt=""
- Handle the input parameters, then call sendRawTransaction to recall send token balance
data:image/s3,"s3://crabby-images/d5ec8/d5ec8f01dabb93b2f28477b919b5901fd62f35b0" alt=""
- Use waitForTransactionReceipt to receive the transaction and save it to the history
data:image/s3,"s3://crabby-images/68626/6862626bdbcc5af6401599382c2e1612c46c3aee" alt=""
4. Receive token
- Use useSwapRoute hook to retrieve the swap value
data:image/s3,"s3://crabby-images/e65e2/e65e209829a3528514164232b27d22ec16d97df7" alt=""
- Use the useReadContract hook to retrieve the amount that has been allowed on the chain. Then, we use this to check; if the current amount is greater than the allowed amount, we need to approve it before swapping
data:image/s3,"s3://crabby-images/19f61/19f61ff3d558e7c3a1660fb0d6096807fea3d34b" alt=""
- Similarly to send activity, we also use the useEstimateFee hook to calculate the estimate Fee
data:image/s3,"s3://crabby-images/ec6cc/ec6cca3c775e5b0eeb52ba0ca187aad62dd081c3" alt=""
- Use sendRawTransaction function to send a request
data:image/s3,"s3://crabby-images/b7d17/b7d17a3b914fc80b051c2ecf727bd156d4e6594f" alt=""
- Use waitForTransactionReceipt function to receive the transaction and save it to the history
data:image/s3,"s3://crabby-images/68626/6862626bdbcc5af6401599382c2e1612c46c3aee" alt=""
- Convert the input fields of the add chain form into a request to create a chain
data:image/s3,"s3://crabby-images/303d9/303d9d05321bdcfa00ef2503e11af126f00ee288" alt=""
- Create a new chain and save it in the storage
data:image/s3,"s3://crabby-images/bd38a/bd38a0915432f3bb92434be4c6451261adf4e1b5" alt=""
That’s all the steps for building a Chrome extension with main features of a crypto wallet and I hope they are useful to you. In case, you want to build a crypto wallet for your own, let’s have a look at our Blockchain Development Service and contact us for the quotation.