-
Notifications
You must be signed in to change notification settings - Fork 771
Use Cases
Thomas Burleson edited this page Dec 15, 2016
·
4 revisions
Below are the use cases address by this Layout library. These will be detailed in a separate design doc (pending). The current implementation, however, provides features/solutions for all listed user cases.
- Layout elements in rows
- Layout elements in columns
- Nested containers should have isolated layout constraints
- Adjust container children sizes (flex) based on static percentages
- Adjust container children sizes (flex) based on static pixel values
- Adjust container children sizes (flex) based on expressions
- Adjust alignment of container children based on static/dynamic values
- Adjust offset of container children based on static/dynamic values
- Adjust ordering of container children based on static/dynamic values
- Container children resizing (flex) is dependent upon container layout directions (layout)
- Changes in Layout directives will update nested Flex children
- Change Detection:
ngOnChanges
due to Layout attribute expressions only trigger for defined activated breakpoints or used as fallback- Input changes are filtered so the default input key is used if the activation key is not defined
- Input changes are filtered so only the current activated input change will trigger an update
- Activations: when the mediaQuery becomes active
- mq Activation only uses expressions for the activated breakpoint
- mq Activation fallback to use to non-responsive expressions (fallback) if no breakpoint defined
- Subscription notifications: using OnMediaQueryChanges
- Components implementing
OnMediaQueryChanges
will be notified for each activation (pending) -
ngOnMediaQueryChanges()
uses MediaQueryChanges event arguments -
MediaQueryChanges
will contain the previous activation (and expression value) and the current
- Components implementing
- Querying: for imperative or template logic
- Components can use
MediaQueries::observe()
to subscribe to all activations [for imperative actions] - Component templates can use
$mdMedia.isActive(<query_alias>)
- Components can use
- Breakpoint Customization:
- Custom set of breakpoints can be defined as a Provider
- Custom breakpoints will override ALL default breakpoints (no merging)
-
Quick Links
-
Documentation
-
Demos
-
StackBlitz Templates
-
Learning FlexBox
-
History
-
Developer Guides
-
Contributing