This article will give instructions on how to develop a WEB3 application. It will provide examples and detail on defining the project’s targets, preparing technical documentation, determining the functions, designing the UX/UI interface, and selecting the technology stack. Also, it will touch upon what is a WEB3 application and its difference from typical ones.
What is a WEB3 application?
WEB3 (Web 3.0) is a general term for various technologies that will significantly change the internet in the following ten years. It is expected that the WEB3 Internet applications will be decentralized and will use virtual and augmented reality. Also, it will understand the communication on the internet. In other words, 2D websites and texts will become three-dimensional, the search engines will give more relevant results, and the Internet users will have the power instead of the national corporations.
WEB3 applications are pieces of software that use one of the WEB3 technologies, i.e., blockchain for decentralization, artificial intelligence, neural learning, Big Data, VR/AR, dimensional interfaces, and distributed computing.
 
Examples of WEB3 applications that might replace popular modern WEB2 services. 
Source.
How does a WEB3 application function?
WEB3 application architecture is significantly different from WEB2 applications. For example, 
Medium is a website that allows sharing content or interacting (liking, sharing, commenting)  with other users' content. 
As a WEB2 application, Medium might seem to be a straightforward resource, yet the architecture involves many technologies:
 	- Firstly, it requires storage for posts, users’ data, comments, likes, tags, etc. For this purpose, a constantly updating database is necessary, i.e., a local server or a cloud.
- Secondly, the inner code written in Python, C#, Node.js, PHP, or Java must define the website's business logic. For instance, it should understand what happens when a new user registers an account and publishes a post, likes, or comments on something.
- Thirdly, the external code written in CSS, JQuery, HTML, TypeScript, React, or JavaScript must understand the logic of the user interface. For example, it must define how the user sees the website and what happens when they interact with each element on the page.
Having all this information, you will have a picture of how a WEB2 application functions. In our case, you see how Medium functions when you write or publish posts and comments.
 
An example of WEB2 application architecture. 
Source.
It is a centralized type of architecture since the code is stored on an internal server, and data is in a database. Both the code and data are partially owned and controlled by the creator (owner) of the application, which causes issues with the security and privacy of data and the income received from it.
Unlike WEB2 applications like Medium, Facebook, Microsoft Word, WhatsApp, Netflix, or PayPal, WEB3 applications do not have a centralized server or a centralized database that stores information about the users and application. Instead, the technology employs a blockchain for crowdsourcing the public server, which the P2P anonymous nodes support (anonymous internet users).
Furthermore, blockchain technology allows employing smart contracts for inner business logic automatization.
 
An example of decentralized WEB3 application architecture. 
Source.
This example illustrates the changes in the backend of the Web3 application. Do you wonder what happens to the frontend? At this stage, it does not have significant differences, yet in the future, it will change. 
Virtual and augmented reality interfaces will replace the graphical user interfaces (GUI) that we are used to seeing now. We discussed it in the article about Metaverse and related solutions developed.
How to create a WEB3 mobile application?
Developing a WEB3 solution requires custom development since it is the only way to provide decent security and reliability for your product. Furthermore, an experienced development team with high expertise in cybersecurity must take over the assignment, like Merehead. Since 2015 we have worked on Blockchain, DeFi, NFT, and VR/AR projects.
You can see our portfolio and find out the cooperation terms via [email protected] or  +1-206-785-16-88.
Step 1: Initial phase 
Any IT-startup development, including WEB3 mobile applications, starts with defining the idea of your project. At this stage, you and the development team meet online or offline to clarify all details of the future WEB3 solution, including the business aims you want to reach and the requirements for the design and functionality.
As a result of this stage, you must have the following:
 	- The descriptions of the targets and tasks. The description of the business tasks and marks of your WEB3 application must be detailed and precise. It will be much easier for the developers what they need to develop if they have a straightforward and plain description.
- The description of the project. Significantly, the explanation of the functions of your project is detailed too. It requires determining how the users will use the application and why they need it. Also, you must understand the monetization structure of your WEB3 application.
- Application drafts. These are generally handwritten user interface designs that visually demonstrate essential parts that should be considered during the design development.
Preferably, you prepare the descriptions and drafts before contacting the developers. However, if you do not do it, since developing an application is a new experience for you, it is not a big issue. An excellent developer will help you define by asking the right questions and providing examples.
Furthermore, the initial stage requires documents from the development team that we stated below:
 
Step 2: Develop the technical documentation
The second stage of a mobile application with WEB3 solutions involves creating a software document or technical specification. It is a development manual for the upcoming product that explains the business logic, including everything from defining the technologies employed to deadlines, budget, and even risks.
Typically, the product developer provides the technical documentation according to the project’s report given by the client. However, the client might do the technical documentation. To make the technical document, the developer requires:
 	- To define the number of users of the upcoming WEB3 application and their roles (buyer, seller, administrator).
- To offer means of project implementation.
- To provide the user stream structure.
- To give the user interface structure.
- To define the main application functions.
- To determine the application architecture.
When the technical documentation is ready, the development team requires the client to approve it, and then they estimate the project's budget. When everything is agreed upon, the developer will conduct a functional decomposition, split user streams into tabs and functions, define their priorities, and create a project development plan. The plan will determine the tasks as prime (those which must be implemented in MVP) and secondary, which can be added after creating the MVP or even after the release and deployment of the mobile application.
 
WEB3 solution architecture structure example. 
Source.
Step 3: Create the WEB3 application prototype
Developing the WEB3 solution prototype is one of the most crucial development stages since the interface design defines the entire project's success. If the users do not like the interface or find it complicated and confusing, they will delete the application and never use your product. Also, they might leave negative feedback.
To avoid it, your development team must study the competitors and the target audience to understand the tastes and requirements of the users and implement it according to the technical documentation of the project and trends in design. Typically, the process takes three stages.
 	- Sketching the interface design on paper. It will show the significant aspect of the upcoming project, namely the logic, number of tabs, and interaction;
- Developing high-fidelity wireframes that show how the users see the design. The wireframes help visualize the application design so that the client and the developers see how it will eventually look.
- Making a clickable prototype, i.e., an animated interface design version where all icons, buttons, and transitions are present. This prototype helps optimize the user streams and find logical gaps and technical inconsistencies in the source idea.
Step 4: Approving the final UX/UI design
The application prototype developed in the former step will help the UX/UI 
designers create each tab's design, agree on it with the client, and test it on a focus group representing the target audience. As a result, the client will receive:
 	- An application navigation template.
- Icons and buttons design.
- Text fields and their content.
- Other visual elements.
Depending on the difficulty of developing your design, the process will take one week to three months. The design will take a year or even more if it is a WEB3 video game or a virtual space for the metaverse.
When the design development is ready, you will have:
 	- A UX wireframe for the WEB3 solution
- An application design for iOS and Android
- An interactive application design prototype
Step 5: Initiate the development of the application
There are several scenarios for this stage. First, you might start agreeing on the concept, namely developing the minimum viable product (MVP) that will prove that your idea functions and there is demand. This is a good solution for clients who want to check their ideas' perspectives on a low budget and within a short time.
Second, you can start developing the complete WEB3 application that has all functions, integrations, and design solutions. This is a solution for product launches in a competitive market with product analogs. It requires a quality product and details equal to or better than the competitors. This is the only way to attract users.
Despite your choice, the developers of the WEB3 application will need to develop the following:
Frontend. This is the part of your WEB3 solution which the user will interact with. For instance, for a cryptocurrency wallet, the developers use the following technologies and development tools (technology stack):
 	- Programming languages for the web: Angular.JS, React.JS, and Vue.JS.
- Programming languages for App: Java, Kotlin for Android, and Swift for iOS.
- Architecture: MVVM for Android and MVC, MVP, MVVM, and VIPER for iOS.
- IDE: Android Studio and Xcode for iOS.
- SDK: Android SDK and iOS SDK.
Backend.This part is responsible for the inner logic of the application. It connects the interface with the data access level. Developing the backend for a cryptocurrency wallet requires
 	- Smart contracts: Ethereum virtual machine or BSC.
- SQL database: MySQL, PostgreSQL, MariaDB, MS SQL, Oracle.
- DevOps: GitLab CI, TeamCity, GoCD Jenkins, WS CodeBuild, Terraform.
- NoSQL database: MongoDB, Cassandra, DynamoDB.
- Search engine: Apache Solr, Elasticsearch.
- Programming language: Java, PHP, Python.
- Framework: Spring, Symphony, Flask.
- Cache: Redis, Memcached.
Step 6: Testing the product
Quality assurance is an important step at every stage of development for a smooth product launch, especially in the case of creating applications that handle money and business user data. Testers and QA specialists use manual and automated testing to check various vulnerabilities. Typically, these tests are as follows:
 	- Compatibility testing. Running the created mobile app on popular operating systems and various devices;
- Device compatibility testing. Checking how the created mobile application works and looks on screens of different sizes;
- Testing of low-level resources. Testing the application's operation when the Internet connection is slow, the battery is low, etc.;
- Security testing. Searching for vulnerabilities that can be used to compromise the application or create problems with its operation.
- Interface testing. Checking how the navigation, menus, and buttons work;
- Beta testing. Preliminary focus group study of the application and obtaining feedback.
Step 7: Deploy the WEB3 application
When the development of a WEB3 mobile app is complete, it's time to deploy it to the cloud and publish it to the Apple App Store and Google Play. But before that, you need to make sure that your mobile app meets the requirements of these app sites and prepare information about it.
Here is the publishing process for these stores:
 
Post-launch support is not mandatory. But it is strictly recommended if you intend to improve and develop your project. You can set up the support work either through an internal team or by agreeing with your application developer. However, the latter option is not always possible because the developers can be transferred to work on the other projects. Therefore, you need to agree on support in advance, and then the developers will either move to long-term work with your project or train a particular team in advance.
Step 8: Product support
Post-launch support is not mandatory. But it is strictly recommended if you intend to improve and develop your project. You can set up the support work either through an internal team or by agreeing with your application developer. However, the latter option is not always possible because the developers can be transferred to work on the other projects. Therefore, you need to agree on support in advance, and then the developers will either move to long-term work with your project or train a particular team in advance.
The budget for a WEB3 solution development
The cost of implementing WEB3-solutions and other IT projects depends on their complexity and scale. Therefore, it is impossible to say in advance what the development budget of your specific mobile application should be. Here we will only give an approximate cost of cryptocurrency wallet development for the U.S., Western, and Eastern Europe.
