Integrating Web3.js with a mobile app allows you to build decentralized applications (dApps) that can interact with the Ethereum blockchain directly from mobile devices. In this guide, we will use React Native as our mobile framework to demonstrate how to integrate Web3.js.

Step 1: Set Up Your React Native Project

First, ensure you have Node.js and React Native CLI installed. Then, create a new React Native project by running:

npx react-native init MyDApp

Navigate into your project directory:

cd MyDApp

Step 2: Install Web3.js

Next, install the Web3.js library. In your project directory, run:

npm install web3

Step 3: Install React Native Dependencies

To interact with the Ethereum blockchain, you will also need to install the following dependencies:

npm install react-native-crypto react-native-randombytes

After installing the packages, link them to your project:

npx react-native link react-native-crypto
npx react-native link react-native-randombytes

Step 4: Set Up Web3.js in Your App

Open the App.js file and set up Web3.js. Below is a sample code snippet:

import React, { useEffect, useState } from 'react';
import { View, Text, Button } from 'react-native';
import Web3 from 'web3';

const App = () => {
const [web3, setWeb3] = useState(null);
const [account, setAccount] = useState(null);

useEffect(() => {
const initWeb3 = async () => {
// Check if MetaMask is installed
if (window.ethereum) {
const web3Instance = new Web3(window.ethereum);
await window.ethereum.request({ method: 'eth_requestAccounts' });
const accounts = await web3Instance.eth.getAccounts();
setAccount(accounts[0]);
setWeb3(web3Instance);
} else {
alert('Please install MetaMask or another Ethereum wallet!');
}
};

initWeb3();
}, []);

return (
<View>
<Text>Welcome to My DApp!</Text>
{account ? <Text>Your account: {account}</Text> : <Text>Connecting...</Text>}
</View>
);
};

export default App;

Step 5: Interacting with Smart Contracts

To interact with a smart contract, you need the contract's ABI (Application Binary Interface) and its deployed address. You can obtain these from your smart contract deployment process.

const contractABI = [ /* ABI goes here */ ];
const contractAddress = '0xYourContractAddress';

const contract = new web3.eth.Contract(contractABI, contractAddress);

You can now call functions on your smart contract. For example, to call a function named getValue:

const getValue = async () => {
const value = await contract.methods.getValue().call();
console.log(value);
};

Step 6: Sending Transactions

To send a transaction to your smart contract, use the following code:

const sendValue = async (newValue) => {
await contract.methods.setValue(newValue).send({ from: account });
};

Step 7: Testing on a Mobile Device

To run your React Native app on a physical device, you can use:

npx react-native run-android  # for Android
npx react-native run-ios # for iOS

Make sure you have the necessary setup for Android or iOS development on your machine.

Conclusion

By following these steps, you can successfully integrate Web3.js with a mobile app built using React Native. This setup allows you to create powerful decentralized applications that can interact with the Ethereum blockchain directly from mobile devices.