Page Banner
DESIGN COMPLETE IMPLEMENTATION PLANNED
A Page Banner displays an important, succinct message, and provides actions for users to address (or dismiss the banner). It requires a user action to be dismissed.
Paragon Jira tickets: https://openedx.atlassian.net/browse/PAR-277?atlOrigin=eyJpIjoiODEzNzFiYmNhZmY3NGU0NDgwZTVjZWU2MDBhZDVjZDYiLCJwIjoiaiJ9 https://openedx.atlassian.net/browse/PAR-320?atlOrigin=eyJpIjoiN2Y1ZWU0OGM0ZTZiNDFkYjhiODVkYTNhZDRhMDk5ZTciLCJwIjoiaiJ9
Design resources: Page Banner
Global Banners
Page Banners that appear throughout pages of the site are known as Global Banners.
Today, Global Banners are the most prevalent form of Page Banners, i.e. COVID response, Cyber Monday promotion, etc.
Variants
Color variant | Primary (bright blue), Light, Dark, Warning |
---|---|
Dismissible | True, false (warning variant is not dismissible) |
Best Practices
Do |
Page Banner and System Warning Banner can appear simultaneously. However, there can only be one Page Banner at a time. |
Do |
Use the Page Banner component for temporary promotions-only. |
Don't |
Donāt stack Page Banners. There can only be one Page Banner at any given time. |
Donāt use the Page Banner component as a Cookie Banner - the Cookie Banner will be a separate component. |
Related Components
https://openedx.atlassian.net/l/c/KuRr3wzb
Specification
Behaviors
Dismissible: Default persistence: Scrolling behavior: Position:
|
Accessibility
Implementation considerations: | 1) System Warning banners are presumed to be highest priority ā urgent/must-notice in every case. There are two ways to (try to) ensure this for screen reader users: |
---|---|
message discoverability and navigation | 2) Page banners are generally given role=āalertā, but in scenarios where there are more than one present at a time, we have a repeat of point 1) above. The W3C recommends putting page-level messages in a list structure at the top of the page. Hereās my recommended container structure: |
Notes
01.21.2021:
Implementing the component as designed, while leaving the implementation of the display rules āhow many, etcā to a future component. We need a frame to do the orchestration of these components.
Ā