data:image/s3,"s3://crabby-images/ffa0a/ffa0a47e2ec6dc27680ff0e94671e82e416f544b" alt="Android studio ide heirarchy on the side"
“Free” documentation that cannot become obsolete for your UseCases.Let’s see what other advantages we get with this approach:
data:image/s3,"s3://crabby-images/a2d28/a2d28146c20d540dde554f5cc4712cd23574c839" alt="android studio ide heirarchy on the side android studio ide heirarchy on the side"
data:image/s3,"s3://crabby-images/1e032/1e03239d47e853577a3e35052d090ebde1ef4453" alt="android studio ide heirarchy on the side android studio ide heirarchy on the side"
It’s definitely a little bit weird at first, but the more I get used to the idea, the more I see how it all makes sense. We start with one of the hierarchies above in a way we are used to writing sealed hierarchies:Īhh, things are making sense… Now if we have other “UseCaseErrors” that should contain ApiCallError as their entries, we need to make ApiCallError implement those “UseCaseErrors” sealed interface.
data:image/s3,"s3://crabby-images/95f50/95f50e7cef6c7b4c3d07ff3564c52db2fa3035c8" alt="android studio ide heirarchy on the side android studio ide heirarchy on the side"
Let’s take it step by step and maybe it will click for us. In fact, I asked two great developers of our dear community to take a look at this article after I finished the first draft, and they too felt the exact same way! (Thank you so much Adam McNeilly and Adam Bennett ❤️)īut this is in fact how we can achieve what we want. Instinctively, I almost wanted to do it the other way around. When I arrived at this solution, it felt weird for some reason. Maybe we’ll even have some Use Cases that can use ApiCallError as the return error type (if they don’t have any other unhappy path).īut, wait a second… Is this really right? Should ApiCallError really implement each UseCaseError and not the other way around? 🤔 This is not only for semantic reasons, we can now have our own wrapper for API calls that always returns ApiCallError in case of error. Once your layout has created, you can load the layout resource from your application code, in your Activity.With this change, we don’t have to repeat any error class ever again, and we even added a new error hierarchy for ApiCallError. Following is a simple example of XML file having LinearLayout − A layout may contain any type of widgets such as buttons, labels, textboxes, and so on. This tutorial is more about creating your GUI based on layouts defined in XML file.
data:image/s3,"s3://crabby-images/0dffc/0dffc67289c51c91b91d159806cad0099a7ddbf0" alt="android studio ide heirarchy on the side android studio ide heirarchy on the side"
The ViewGroup is a subclass of View and provides invisible container that hold other Views or other ViewGroups and define their layout properties.Īt third level we have different layouts which are subclasses of ViewGroup class and a typical layout defines the visual structure for an Android user interface and can be created either at run time using View/ViewGroup objects or you can declare your layout using simple XML file main_layout.xml which is located in the res/layout folder of your project. View is the base class for widgets, which are used to create interactive UI components like buttons, text fields, etc. The basic building block for user interface is a View object which is created from the View class and occupies a rectangular area on the screen and is responsible for drawing and event handling.
data:image/s3,"s3://crabby-images/ffa0a/ffa0a47e2ec6dc27680ff0e94671e82e416f544b" alt="Android studio ide heirarchy on the side"