DropMenu

DropMenu component is a versatile dropdown menu used in Blazor applications. It allows you to create a button that, when clicked, opens a callout or dropdown menu. This can be particularly useful for creating navigation menus, action lists, or any other interactive elements that require a dropdown.

Usage

Basic
This is the content

This is the content

This is the content
<BitDropMenu Text="Basic">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
        <BitButton>Click me</BitButton>
        <BitToggle>Toggle me</BitToggle>
    </BitStack>
</BitDropMenu>

<BitDropMenu Text="Disabled" IsEnabled="false">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
        <BitButton>Click me</BitButton>
        <BitToggle>Toggle me</BitToggle>
    </BitStack>
</BitDropMenu>

<BitDropMenu Text="Transparent" Transparent>
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
        <BitButton>Click me</BitButton>
        <BitToggle>Toggle me</BitToggle>
    </BitStack>
</BitDropMenu>
Icon
Customizing the drop menu icons.

This is the content


This is the content
<BitDropMenu Text="IconName" IconName="@BitIconName.Emoji2">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
    </BitStack>
</BitDropMenu>

<BitDropMenu Text="ChevronDownIcon" ChevronDownIcon="@BitIconName.DoubleChevronDown">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
    </BitStack>
</BitDropMenu>
Responsive
Rendering the callout in responsive mode on small screens.

This is the content This is the content This is the content
This is the content
This is the content
This is the content

This is the content This is the content This is the content
This is the content
This is the content
This is the content
<BitDropMenu Text="End PanelPosition" Responsive ScrollContainerId="sc-con1" PanelPosition="BitPanelPosition.End">
    <div style="max-width:200px;overflow:auto" id="sc-con1">
        <BitStack FitWidth Gap="1rem" Style="padding:0.5rem">
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content This is the content This is the content</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content</BitText>
        </BitStack>
    </div>
</BitDropMenu>

<BitDropMenu Text="Start PanelPosition" Responsive ScrollContainerId="sc-con2" PanelPosition="BitPanelPosition.Start">
    <div style="max-width:200px;overflow:auto" id="sc-con2">
        <BitStack FitWidth Gap="1rem" Style="padding:0.5rem">
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content This is the content This is the content</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>This is the content</BitText>
        </BitStack>
    </div>
</BitDropMenu>
Template
Here is an example of customizing the drop menu.

This is the content
<BitDropMenu Text="Add Icon" IconName="@BitIconName.Emoji2">
    <Template>
        <div style="display:flex;gap:10px;">
            <BitIcon IconName="@BitIconName.Airplane" Color="BitColor.Tertiary" />
            <span>A template</span>
            <BitRippleLoading CustomSize="20" Color="BitColor.Tertiary" />
        </div>
    </Template>
    <Body>
        <BitStack Gap="1rem" Style="padding:0.5rem">
            <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
        </BitStack>
    </Body>
</BitDropMenu>
Events
Utilizing the drop menu OnClick event:

This is the content
<BitDropMenu Text="@($"Click me ({clickCounter})")" OnClick="() => clickCounter++">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
    </BitStack>
</BitDropMenu>
@code {
    private int clickCounter;
}
                    
Style & Class
Further customization by overriding default styles and classes, allowing tailored design modifications to suit specific UI requirements.


Component's Style & Class:

This is the content

This is the content




Styles & Classes:

This is the content

This is the content
<style>
    .custom-class {
        border-radius: 1rem;
        border-color: blueviolet;
        transition: background-color 1s;
        background: linear-gradient(90deg, magenta, transparent) blue;
    }

    .custom-class:hover {
        border-color: magenta;
        background-color: magenta;
    }

    .custom-root {
        color: aqua;
        min-width: 7.2rem;
        font-weight: bold;
        border-color: aqua;
        border-radius: 1rem;
        box-shadow: aqua 0 0 0.5rem;
    }

    .custom-root:hover {
        background-color: gray;
    }

    .custom-text {
        text-shadow: tomato 0 0 0.5rem;
    }

    .custom-opened {
        color: green;
    }
</style>

<BitDropMenu Text="Styled Drop menu" Style="background-color: transparent; border-color: blueviolet; color: blueviolet;">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
    </BitStack>
</BitDropMenu>

<BitDropMenu Text="Classed Drop menu" Class="custom-class">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
    </BitStack>
</BitDropMenu>

<BitDropMenu Text="Styled Drop menu"
             Styles="@(new() { Root = "background-color: peachpuff; border-color: peachpuff; min-width: 6rem;",
                               Text = "color: tomato; font-weight: bold;"
                               Opened = "border-color: tomato; background-color: goldenrod;" })">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
    </BitStack>
</BitDropMenu>

<BitDropMenu Text="Classed Drop menu"
             Classes="@(new() { Root = "custom-root",
                                Text = "custom-text",
                                Opened = "custom-opened" })">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">This is the content</BitText>
    </BitStack>
</BitDropMenu>
RTL
Use BitDropMenu in right-to-left (RTL).

این یک محتوای تستی می باشد.

این یک محتوای تستی می باشد این یک محتوای تستی می باشد این یک محتوای تستی می باشد
این یک محتوای تستی می باشد
این یک محتوای تستی می باشد

این یک محتوای تستی می باشد این یک محتوای تستی می باشد این یک محتوای تستی می باشد
این یک محتوای تستی می باشد
این یک محتوای تستی می باشد
<BitDropMenu Text="منو" Dir="BitDir.Rtl">
    <BitStack Gap="1rem" Style="padding:0.5rem">
        <BitText Typography="BitTypography.Subtitle1">این یک محتوای تستی می باشد.</BitText>
    </BitStack>
</BitDropMenu>

<BitDropMenu Text="ریسپانسیو منو در انتها" Dir="BitDir.Rtl" Responsive ScrollContainerId="sc-con-rtl1">
    <div style="max-width:200px;overflow:auto" id="sc-con-rtl1">
        <BitStack Gap="1rem" Style="padding:0.5rem">
            <BitText Typography="BitTypography.Subtitle1" NoWrap>این یک محتوای تستی می باشد این یک محتوای تستی می باشد این یک محتوای تستی می باشد</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>این یک محتوای تستی می باشد</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>این یک محتوای تستی می باشد</BitText>
        </BitStack>
    </div>
</BitDropMenu>

<BitDropMenu Text="ریسپانسیو منو در ابتدا" Dir="BitDir.Rtl" Responsive ScrollContainerId="sc-con-rtl2" PanelPosition="BitPanelPosition.Start">
    <div style="max-width:200px;overflow:auto" id="sc-con-rtl2">
        <BitStack Gap="1rem" Style="padding:0.5rem">
            <BitText Typography="BitTypography.Subtitle1" NoWrap>این یک محتوای تستی می باشد این یک محتوای تستی می باشد این یک محتوای تستی می باشد</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>این یک محتوای تستی می باشد</BitText>
            <BitText Typography="BitTypography.Subtitle1" NoWrap>این یک محتوای تستی می باشد</BitText>
        </BitStack>
    </div>
</BitDropMenu>

API

BitDropMenu parameters
Name
Type
Default value
Description
Body RenderFragment? null Alias of the ChildContent.
ChevronDownIcon string? null The icon name of the chevron down part of the drop menu.
ChildContent RenderFragment? null The content of the callout of the drop menu.
Classes BitDropMenuClassStyles? null Custom CSS classes for different parts of the drop menu.
IconName string? null The icon to show inside the header of the drop menu.
IsOpen bool false Determines the opening state of the callout of the drop menu.
OnClick EventCallback The callback is called when the drop menu is clicked.
OnDismiss EventCallback The callback is called when the drop menu is dismissed.
ScrollContainerId string? The id of the element which needs to be scrollable in the content of the callout of the drop menu.
Responsive bool false Renders the drop menu in responsive mode on small screens.
Styles BitDropMenuClassStyles? null Custom CSS styles for different parts of the drop menu.
Template RenderFragment? null The custom content to render inside the header of the drop menu.
Text string? null The text to show inside the header of the drop menu.
Transparent bool false Makes the background of the header of the drop menu transparent.
BitComponentBase parameters
Name
Type
Default value
Description
AriaLabel string? null The aria-label of the control for the benefit of screen readers.
Class string? null Custom CSS class for the root element of the component.
Dir BitDir? null Determines the component direction.
HtmlAttributes Dictionary<string, object> new Dictionary<string, object>() Capture and render additional attributes in addition to the component's parameters.
Id string? null Custom id attribute for the root element. if null the UniqueId will be used instead.
IsEnabled bool true Whether or not the component is enabled.
Style string? null Custom CSS style for the root element of the component.
Visibility BitVisibility BitVisibility.Visible Whether the component is visible, hidden or collapsed.
BitComponentBase public members
Name
Type
Default value
Description
UniqueId Guid Guid.NewGuid() The readonly unique id of the root element. it will be assigned to a new Guid at component instance construction.
RootElement ElementReference The ElementReference of the root element.
BitDropMenuClassStyles properties
Name
Type
Default value
Description
Root string? null Custom CSS classes/styles for the root element of the BitDropMenu.
Opened string? null Custom CSS classes/styles for the opened callout state of the BitDropMenu.
Button string? null Custom CSS classes/styles for the button of the BitDropMenu.
Icon string? null Custom CSS classes/styles for the icon of the BitDropMenu.
Text string? null Custom CSS classes/styles for the text of the BitDropMenu.
ChevronDown string? null Custom CSS classes/styles for the chevron-down icon of the BitDropMenu.
Overlay string? null Custom CSS classes/styles for the overlay of the BitDropMenu.
Callout string? null Custom CSS classes/styles for the callout of the BitDropMenu.
BitVisibility enum
Name
Value
Description
Visible 0 The content of the component is visible.
Hidden 1 The content of the component is hidden, but the space it takes on the page remains (visibility:hidden).
Collapsed 2 The component is hidden (display:none).
BitDir enum
Name
Value
Description
Ltr 0 Ltr (left to right) is to be used for languages that are written from the left to the right (like English).
Rtl 1 Rtl (right to left) is to be used for languages that are written from the right to the left (like Arabic).
Auto 2 Auto lets the user agent decide. It uses a basic algorithm as it parses the characters inside the element until it finds a character with a strong directionality, then applies that directionality to the whole element.

Feedback

You can give us your feedback through our GitHub repo by filing a new Issue or starting a new Discussion.

Or you can review / edit this page on GitHub.

Or you can review / edit this component on GitHub.
  • On this page