Build Blog 1: Building a Connected Mobile App
- Mahad Zaryab
- Jan 27, 2023
- 3 min read
Hi everyone! Welcome to the first blog in which I'll be talking a little bit about how we're building a mobile application that'll connect to the hydroponics system.
The Need for a Mobile App
The main reason that we're building a mobile app as part of our wider hydroponics system is to enhance the user experience and provide the user with an ecosystem in which they can both control and monitor their system. With this objective in mind, we wanted to build a mobile app that would precisely have the following features:
The ability for a user to remotely control important variables in their system. Namely, the user should be able to control the following:
The pH of the water
The Electrical Conductivity (EC) of the water
The lighting of the system
The ability for a user to monitor their system. Namely, the user should be able to get insight into the following aspects of the system:
The pH of the water over time
The Electrical Conductivity (EC) of the water
The temperature and humidity of the system over time
The temperature of the water over time
A visual of the system
Guidance for the user in maintaining the system to ensure that the user is set up for a successful yield in their journey of growing plants hydroponically
Choosing the Right Framework
There are many different frameworks out there that allow a developer to build a mobile application. As a result, I researched some of the most popular frameworks out there (including ones that I had worked with in the past) to find the right framework for our project.
Framework | Advantages | Disadvantages |
iOS with Swift |
|
|
Android with Java |
|
|
Flutter |
|
|
React Native |
|
|
While all four frameworks would have satisfied our needs, React Native was chosen as it had the least friction to getting started which was an important consideration given that the the timeline to complete the project is quite packed.
Learning React Native
After settling on React Native as the choice of framework, the first thing I did was to do a crash course on YouTube as I had never used React Native before. However, I had used React, which is essentially the equivalent framework for building web applications. As a result of this, picking up React Native was relatively easy as it has a very similar development style to React with some minor differences. The tutorial I followed had me build a very basic to-do list application that allowed me to get comfortable with building user interfaces with React Native. After completing this tutorial, I felt ready to start building Planter (that's what we're calling our mobile app)!
Wireframing
I also wanted to mention that at this point I had already completed the wireframes for the mobile app using Figma. If you're unfamiliar with Figma, it's an interface design tool that's highly useful for prototyping a digital product.

Building Planter
I essentially just dove into building Planter. I decided to start by building out the static screens first as I already had the designs ready to go. At this point, the screens did not have any functionality but were styled according to the Figma wireframe that I had developed. Here are some of the screens that I have developed so far!
What's Next?
There are a few things that I'm working on now:
Revamping some of the screens to provide a better product experience
Building out the backend for the application to make the application functional
Designing request/response schemas for integration with the actual system
Stay tuned for more blogs to come as I make progress on the above!
Opmerkingen