Top Bar
The Top Bar is a top-anchored component that provides context for the screen and facilitates easy navigation through different flows. Users depend on this Top Bar to navigate and orient themselves within your UI, and this pattern highlights the qualities that make a Top Bar consistent, familiar, and user-friendly.
- Overview
- Specs
- Guidelines
Pattern
The Top Bar is a vital component of a product’s user interface, providing a stable and accessible area for both product-specific and system-wide functionalities. Much like the macOS Menu Bar or the Windows Start Bar, it offers a dependable spot for local navigation and quick access to universal features like system settings, notifications, and cross-product navigation.
This pattern details the basics of using Compose components for both internal and cross-product navigation and offers strategies to maintain consistency across various products.
- 1: Main menu: The primary menu icon is applied to access product navigation features, such as opening the left sidebar;
- 2: Header name: In Cegid products, the header name always starts with Cegid and should exclusively link users to the domain’s home page;
- 3: Search: A search function helps you quickly find specific information or items in the app or website by typing in keywords or phrases;
- 4: Selector: Depending on the app that is used, the user can switch between different companies previously created or different subscriptions;
- 5: Switcher: The switcher allows users to easily switch between different products and systems. It’s best used to show recently or frequently used apps, or all apps connected to the user’s account. If the list is manageable, include every app or product available on the system;
- 6: Utilities: The header serves as a central hub for global system utilities, accessible from anywhere on the site. Instead of using utility icons for direct navigation, they should open a panel that links to different parts of the product;
Used for:
Consistent navigation:
You want to provide a consistent navigation experience across all pages of your app or website.
Access to key features:
You need a space for essential features like search, notifications, user profile, or settings.
Branding:
You want to prominently display your brand’s logo or name.
Global utilities:
You need a fixed place for global utilities that users can access from any page, such as help or account management.
Don’t use for:
Context-specific actions:
The primary actions are highly context-specific and vary significantly from page to page, making a Top Bar less useful.
Simple single-page apps:
Your app or website is a simple single-page application with minimal navigation needs.
Single-purpose tools:
Tools designed for a single, focused task (e.g. calculators, timers) typically don’t benefit from a Top Bar since navigation is minimal or non-existent.
Demo
Access the Figma file and inspect the element using Dev Mode.
Usage
The Top Bar in a product is crucial for enhancing user experience by providing essential navigation, branding, search functionality, and user account access. It offers quick and easy access to key features and information, ensuring users can efficiently navigate through the app. Additionally, the Top Bar often includes notifications, settings, and help options, centralizing important utilities and tools in one accessible location. By consistently being available at the top of the screen, it helps users stay oriented and find what they need without unnecessary clicks or searching.
Change the icons used in the Top Bar.
Use the Top Bar for page-specific functions.
When incorporating additional actions in the Top Bar, ensure it remains organized and uncluttered.
Behavior
Sticky header:
- In mouse-driven interfaces, changing the cursor shape can signify drag-and-drop capability. When users hover over a draggable object, the cursor shifts to indicate that clicking will start the dragging process;
Search functionality:
- Allows users to quickly search in the product and provides suggestions as the user types;
Global utilities:
- Provide quick access to system or product settings for users to easily access help documentation or customer support;
Responsive design:
- Adjusts elements’ layout and visibility based on screen size (desktop, tablet, mobile);
Related
Importance of Non-Productive Environments on Products
Spacing
Structure
Apps menu
User profile
States
The items in the Top Bar can have different states: enabled (1), hover (2), pressed (3), focus (4), and disabled (5). For information on the search and selectbox states, please refer to their individual documentation pages.
Icons
Enabled
.enable{
color: var(--Greys-Grey-7);
}
Hover
.hover{
color: var(--Greys-Grey-8);
border-radius: var(--Border-Radius-rounded);
background: var(--Theme-Theme-10);
}
Pressed
.pressed{
color: var(--Greys-Grey-8);
border-radius: var(--Border-Radius-rounded);
background: var(--Theme-Theme-20);
}
Focus
.focus{
color: var(--Greys-Grey-8);
border-radius: var(--Border-Radius-rounded);
border: 1px solid var(--Greys-Grey-8);
background: var(--Theme-Theme-20);
}
Disabled
.disable{
color: var(--Greys-Grey-5);
}
App menu
Enabled
.enable{
background: var(--Greys-Grey-1);
title: var(--Greys-Grey-8);
subtitle: var(--Greys-Grey-7);
}
Hover
.hover{
background: var(--Greys-Grey-2);
title: var(--Greys-Grey-8);
subtitle: var(--Greys-Grey-7);
}
Pressed
.pressed{
color: var(--Theme-Theme-10);
title: var(--Greys-Grey-8);
subtitle: var(--Greys-Grey-7);
}
Focus
.focus{
border-radius: var(--Border-Radius-x-small-radius);
border: 1px solid var(--Greys-Grey-8);
background: var(--Greys-Grey-1);
title: var(--Greys-Grey-8);
subtitle: var(--Greys-Grey-7);
}
Disabled
.disable{
background: var(--Greys-Grey-2);
title: var(--Greys-Grey-6);
subtitle: var(--Greys-Grey-6);
}
User Profile
For information on the used buttons states, please refer to their individual documentation pages.
Enabled
.enable{
background: var(--Greys-Grey-1);
icon: var(--Greys-Grey-7);
title: var(--Greys-Grey-8);
}
Hover
.hover{
background: var(--Greys-Grey-2);
icon: var(--Greys-Grey-7);
title: var(--Greys-Grey-8);
}
Pressed
.pressed{
background: var(--Theme-Theme-10);
icon: var(--Greys-Grey-7);
title: var(--Greys-Grey-8);
}
Focus
.focus{
border-radius: var(--Border-Radius-x-small-radius, 4px);
border: 1px solid var(--Greys-Grey-8);
background: var(--Greys-Grey-1);
icon: var(--Greys-Grey-7);
title: var(--Greys-Grey-8);
}
Disabled
.disable{
background: var(--Greys-Grey-2);
color: var(--Greys-Grey-6);
icon: var(--Greys-Grey-7);
title: var(--Greys-Grey-6);
}
Useful links
data:image/s3,"s3://crabby-images/c1f45/c1f45365fd6fad8ae2fc7594be8946326cc22f55" alt="guidelines figma accent icon"
Consult our Figma file to access our assets and inspect them in dev mode.
data:image/s3,"s3://crabby-images/c6b53/c6b53c59fc298cf326ae861845a7d53cf5b6c995" alt="polygon-framework"
This component is or will be provided by the Polygon framework. See its documentation to learn more.
data:image/s3,"s3://crabby-images/24bc3/24bc30c5156aaa28a17cf075a9b8900bf6c437e3" alt=""
This element is in line with the guidelines of the CDS (Cegid Design System). Find out more.