Panel
Overview
The Panel component implements Bulma's versatile panel block for React. It provides a convenient way to display lists, filters, navigation menus, or grouped actions in a card-like vertical container. The Panel supports color modifiers, search, tabs, icons, selectable blocks, and comes with several subcomponents for every panel part.
Use Panel for sidebar menus, filter lists, admin navigation, or any grouped interface actions.
Import
import { Panel } from '@allxsmith/bestax-bulma';
Props
| Prop | Type | Default | Description |
|---|---|---|---|
color | 'primary' | 'link' | 'info' | 'success' | 'warning' | 'danger' | 'black' | 'dark' | 'light' | 'white' | — | Bulma color modifier for the panel. |
className | string | — | Additional CSS classes. |
children | React.ReactNode | — | Panel content (usually includes subcomponents). |
| ... | All standard HTML and Bulma helper props (see Helper Props) | Utility and accessibility props. |
Subcomponents:
Panel.Heading: Main heading (renders as<p class="panel-heading">)Panel.Tabs: Panel tabs (renders as<p class="panel-tabs">)Panel.Block: Individual panel block (renders as<a class="panel-block">)Panel.Icon: Icon container (renders as<span class="panel-icon">)Panel.InputBlock: Search input with icon (renders as<div class="panel-block">)Panel.CheckboxBlock: Checkbox block (renders as<label class="panel-block">)Panel.ButtonBlock: Call-to-action button (renders as<div class="panel-block"><button /></div>)
Usage
Complete Panel (Revolutionary Figures)
This example shows a complete panel layout using Panel and its subcomponents. The Panel.Heading provides a title, Panel.InputBlock adds a search field, and Panel.Tabs enables filtering. Use Panel.Block for each selectable item, optionally with an active state, and Panel.Icon to display icons. This structure is ideal for sidebars, filter lists, or admin menus. The color prop customizes the panel's appearance.
<Panel> <Panel.Heading>Revolutionary Figures</Panel.Heading> <Panel.InputBlock placeholder="Search" /> <Panel.Tabs> <a className="is-active">All</a> <a>Patriots</a> <a>Loyalists</a> <a>Battles</a> <a>Documents</a> </Panel.Tabs> <Panel.Block active> <Panel.Icon> <i className="fas fa-user" aria-hidden="true"></i> </Panel.Icon> George Washington </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-user" aria-hidden="true"></i> </Panel.Icon> Alexander Hamilton </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-user" aria-hidden="true"></i> </Panel.Icon> Benedict Arnold </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-user" aria-hidden="true"></i> </Panel.Icon> John Adams </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-flag" aria-hidden="true"></i> </Panel.Icon> Battle of Saratoga </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-flag" aria-hidden="true"></i> </Panel.Icon> Treaty of Paris </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-flag" aria-hidden="true"></i> </Panel.Icon> Bunker Hill </Panel.Block> <Panel.CheckboxBlock>remember me</Panel.CheckboxBlock> <Panel.ButtonBlock>Reset all filters</Panel.ButtonBlock> </Panel>
Color Variants
This example demonstrates the Panel component's color variants. The color prop applies Bulma's color modifiers to the panel. Each panel in this example uses a different color, showcasing the flexibility of the Panel component in adapting to various design requirements.
<> {[ 'primary', 'link', 'info', 'success', 'warning', 'danger', 'black', 'dark', 'light', 'white', ].map(color => ( <Panel key={color} color={color}> <Panel.Heading> {color.charAt(0).toUpperCase() + color.slice(1)} Panel </Panel.Heading> <Panel.InputBlock placeholder="Search" /> <Panel.Block active> <Panel.Icon> <i className="fas fa-user" aria-hidden="true"></i> </Panel.Icon> George Washington </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-user" aria-hidden="true"></i> </Panel.Icon> Marquis de Lafayette </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-user" aria-hidden="true"></i> </Panel.Icon> Nathanael Greene </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-flag" aria-hidden="true"></i> </Panel.Icon> Battle of Trenton </Panel.Block> <Panel.Block> <Panel.Icon> <i className="fas fa-flag" aria-hidden="true"></i> </Panel.Icon> Yorktown </Panel.Block> <Panel.ButtonBlock>Reset all filters</Panel.ButtonBlock> </Panel> ))} </>
Accessibility
- The root panel renders as a semantic
<nav>for navigation/landmark. - Use headings, links, and buttons with appropriate labels for best accessibility.
- The
Panel.Blockby default renders as an anchor<a>, but can be customized for interactive blocks.
For keyboard navigation, ensure interactive Panel blocks are focusable and provide clear visual states.
Related Components
Icon: For icons insidePanel.Icon.- Helper Props: All Bulma utility helpers can be used.
Additional Resources
You can use all Bulma helper props with <Panel /> and its subcomponents for powerful utility-based styling.