For the last few months, I have been writing about State Machine. As the final article of this series and the first article of the year, I’ll show you how to implement State Machine in a real-life scenario, using as an example an Uber Clone App.
A few years ago, I did this sample of an Uber Clone app, so I’ll take this sample and modify it to use a State Machine.
Let’s start
As I mentioned in a previous article, the first step when working with State Machines is to define the states that will be handled.
data:image/s3,"s3://crabby-images/b4279/b4279865b13eda14b7580d3af0a9e2939914583f" alt=""
data:image/s3,"s3://crabby-images/a1adb/a1adba62c206818b2b3c8b9fad3e7ec47f841b03" alt=""
These states can be represented using an Enum:
data:image/s3,"s3://crabby-images/9fbcf/9fbcff7ddf0f5d58b14a5cd705eba519f405b53c" alt=""
Create another Enum to define the triggers for each state:
data:image/s3,"s3://crabby-images/f4c54/f4c544dd1f48620fe241fb718201055e430434eb" alt=""
Let’s code
After installing the Stateless package, we create the State machine and configure the initial state:
To connect the State with the UI, we expose a State property that will represent the current state:
Now that we have the UI + ViewModel connected, we can define the rest of our states:
Result:
data:image/s3,"s3://crabby-images/501c0/501c0cb53aadbdaabadb6706773d85ce0794ba7b" alt=""
That’s all for now.
Check the full source code here.
NOTE: This code has a lot of room for improvement, I made this quick sample just to show the concept.
Happy Stateless.