This page covers three ways to adjust layout for mobile devices (from simplest to most powerful):
- Wrap Component
- Angular Flex-Layout Directives
- Conditional Components
Wrap
The simplest way to adjust layout of items for a smaller screen is the Wrap Component in the Dynamic Components Library. Wrap will lay out fields or cards in a grid of equal widths based on the size of the screen. You simply put the items inside the Wrap component and specify the widths for each Angular Flex-Layout breakpoint.
data:image/s3,"s3://crabby-images/e9905/e9905529321757da3750a1bd547da17b92fc2126" alt="Wrap component with a division inside"
In the example above, the "100 100 50" widths means that each product instance will be 100% of the width for extra small (xs) and small(sm) and will be 50% of the width for everything larger.
Angular Flex-Layout Directives
If you need more control over the layout of the items, you can use the Angular Flex-Layout directives. This section contains a few examples showing common patterns. Here is a div that will position its children in a row with a 20px gap between them with each child will be left aligned horizontally and centered vertically:
data:image/s3,"s3://crabby-images/cf135/cf135ea5032fc6e4bf9ec1bc909d0e3998d28b9d" alt="Division using the flex-layout directives"
Here are the three children with the left div set to 300px wide, the button set to not grow, and the middle div set to use the remaining space:
data:image/s3,"s3://crabby-images/e599e/e599e517c07f518e8d5197ac82b62b090ac04e3f" alt="Three divisions, each with a different flex directive"
You can add suffixes to the directives to provide different values by screen size. Here is a div that is a row for screen sizes medium (md) and larger and a column for screen sizes smaller:
data:image/s3,"s3://crabby-images/60d74/60d74fbee4171277708ab3ed01d67ef404d8575c" alt="A division using multiple flex directives for different screen sizes"
There are other many other options including hide/show, reorder, and offset. See Angular Flex-Layout directives for all the details.
Conditional Components
The third pattern is to use the Angular Flex-Layout MediaObserver to set UI properties and then apply conditional logic to the elements. Start by adding the MediaObserver class as a dependency for your UI:
data:image/s3,"s3://crabby-images/9ad49/9ad498133c72ca95dfc8224ca85dba8add7f7f80" alt="Dialog used to define a dependency for your app"
Then create a UI method that runs on load something like this:
this.subscriptions.push(
this.mediaObserver.media$.subscribe((mediaInfo) => {
debug('mediaInfo', mediaInfo);
this.isMobile = mediaInfo.mqAlias == 'xs' || mediaInfo.mqAlias == 'sm';
})
);
Then apply conditional logic to the components like this:
data:image/s3,"s3://crabby-images/97c64/97c649ea99095471ae9c765b9a3992a870d817d6" alt="A button with conditional visibility for a specific case"
data:image/s3,"s3://crabby-images/15f9a/15f9a7c815909255b9e27e63ec63665ebf74b9b7" alt="A button with conditional visibility for a different specific case"
Remember to clean up your subscriptions.