13. Responsive Apps
Last updated
Last updated
Any JourneyApps application that you develop will automatically be responsive and can therefore be used on either a smartphone, tablet, desktop or even a browser, without any additional development required. JourneyApps does however offer some special functionality aimed at making better use of the available real estate on the larger screen sizes. When you implement these features and run your app on a smartphone, the app will still work and the UI features will "gracefully degrade" to match the smaller screen, as you'll see later in the tutorial. JourneyApps offers 3 features specifically aimed at these larger screen sizes:
Columns: You can divide your View Components into multiple columns, allowing you to fit in more components and data on a single view.
Sidebars: You can add a sidebar to your View Components, that can be used to show the user what their progress is with completing a particular process in your app. (Note: Sidebars can also be used on phones, but they won't appear as a fixed bar on the side of the screen, rather a collapsible bar at the top)
These components are shown below in a hypothetical example app:
The example app in the screenshots above involves a sales rep completing a field ticket (invoice). We use the sidebar to show all the steps in the ticket process that need to be completed. Columns are used to better organize information.
So, let's update our Punch List App to make it more user friendly for our desktop and tablet users and see the responsive nature of JourneyApps in action.
Head back to your Main View, and in the main.view.xml
file we are going add some <columns>
and move some of the existing components into them, like so.
Let's also do this for our Add New and View Item Views. Like so.
In your add_new.view.xml
file, update the code to the following.
And in your view_item.view.xml
, update the code to the following.
Now let's test the app on a tablet or desktop, as well as on a phone, to see the changes.
You will see that on the desktop or tablet the app automatically displays the components we nested inside the columns next to one another, whereas on the phone those components are still displayed above another. This is because on the phone the platform realizes there is not enough screen space to display the columns next to one another and so they get stack on top off one another instead, in the order that you specified them in the xml
. Another good way to test the responsive nature of apps built on JourneyApps is to simply resize the desktop application window. Try it now, once you decrease the width of the window enough it will render as it does on your phone. Like so:
We'll also be adding a sidebar to our app, but since sidebars are most often used in conjunction with icons and other styling, we'll wait until the next section which covers the basic styling options before adding the sidebar.