-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Responsive Layouts and Fluid Typography #47
Comments
I have some maintainability concerns around component level breakpoints, mostly related to how per-component breakpoints are out of sync with global breakpoints. Having a container A with 3 breakpoints contain another component, B, with two breakpoints essentially means having that whole section having 5 effective breakpoints at a minimum, assuming that the container gets progressively smaller. (A + B + ...) But if containers jump in size, like going from side-by-side to fullwidth vertically stacked layout the number of effective layouts becomes larger (A * B * ...) and more difficult to reason about. This is a much smaller problem when dealing with intrinsically responsive layout presented by flexbox, grid, calc, fluid images and types, etc. I think it might be worth looking at components that have logical breakpoints that can be activated by props, providers, or parent css classes (e.g. body.extra-wide) and limiting reliance on per-component, explicit breakpoints. Furthermore, most of these breakpoints would be placed into top or second level layout components, which is to say the non-reusable components that typically give the site its structure, look and feel. This could result in at least three component categories:
|
Yeah, I've found the web of component-level breakpoints to be quite overwhelming on 2U. Perhaps we could have relied more on selecting for classes provided by a few high level Overall, I'm unsure of how much reusability we could get out of layout components in general, which is a big reason why I haven't tried to extract this stuff from 2U yet. I think of the 'nonreusable' components @refactorized describes above:
and see these things as describing an application-specific design system. Maybe what we want to think about, more than developing explicit components for layout in hzcore, is what kinds of design system building blocks we want to use. One such set of building blocks that I'm interested in exploring: https://theme-ui.com/ |
Responsive Layouts
Responsive layouts are usually built from the outside in. A responsive layout built using media queries only cares about the size of the viewport, and it . It doesn't take the needs of the content into consideration. Container-level queries can allow responsive layouts to be closer to the content:
Modern CSS has a growing list of tools, such as
Flexbox
,Grid
, andcalc
that might enable building responsive layouts from the inside out:Fluid Typography
The text was updated successfully, but these errors were encountered: