Overlay

The Overlay component is used to provide emphasis on a particular element or parts of it. It signals to the user of a state change within the application and can be used for creating loaders, dialogs and more.

Usage

Basic
<style>
    .overlay {
        z-index: 9999;
        align-items: center;
        justify-content: center;
        background-color: rgba(0,0,0,.4);
    }
</style>


<BitButton OnClick="() => BasicIsOpen = true">Show Overlay</BitButton>

<BitOverlay @bind-IsOpen="BasicIsOpen" Class="overlay">
    <BitProgress Circular Indeterminate Thickness="10" />
</BitOverlay>
@code {
    private bool BasicIsOpen;
}
                    
Disabled AutoClose
Use BitOverlay with NoAutoClose to disable automatic closing when clicking outside the overlay.

Short story

Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams. Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth, for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.
<style>
    .overlay {
        z-index: 9999;
        align-items: center;
        justify-content: center;
        background-color: rgba(0,0,0,.4);
    }

    .content {
        width: 85%;
        height: 250px;
        display: flex;
        padding: 15px;
        overflow: auto;
        border-radius: 3px;
        background-color: white;
        flex-flow: column nowrap;
    }

    .close-button {
        right: 10px;
        position: absolute;
    }
</style>


<BitButton OnClick="() => AutoCloseIsOpen = true">Show Overlay</BitButton>

<BitOverlay @bind-IsOpen="AutoCloseIsOpen" Class="overlay" NoAutoClose>
    <div class="content">
        <BitButton Class="close-button" Variant="BitVariant.Text" OnClick=@(() => AutoCloseIsOpen = false) IconName="@BitIconName.ChromeClose" Title="Close" />
        <h3>Short story</h3>
        <div>
            Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams.
            Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment
            when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth,
            for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.
        </div>
    </div>
</BitOverlay>
@code {
    private bool AutoCloseIsOpen;
}
                    
Absolute Positioning
Overlay can be positioned abosolutely inside a conainter with a relative position.

This is Container

<style>
    .overlay {
        z-index: 9999;
        align-items: center;
        justify-content: center;
        background-color: rgba(0,0,0,.4);
    }

    .show-button {
        gap: 5px;
        top: 15px;
        left: 10px;
        display: flex;
        width: fit-content;
        position: absolute;
        flex-flow: row wrap;
    }
</style>


<BitButton Class="show-button" OnClick="() => AbsoluteIsOpen = true">Show Overlay</BitButton>

<BitOverlay @bind-IsOpen="AbsoluteIsOpen"
            Class="overlay"
            AbsolutePosition>
    <BitProgress Circular Indeterminate Thickness="10" />
</BitOverlay>

<h3>This is Container</h3>
@code {
    private bool AbsoluteIsOpen;
}
                    
AutoToggleScroll
Scrolling cannot be left enabled behind the Overlay

Please wait...

<style>
    .overlay {
        z-index: 9999;
        align-items: center;
        justify-content: center;
        background-color: rgba(0,0,0,.4);
    }
</style>


<BitButton OnClick="() => AutoToggleIsOpen = true">Show Overlay</BitButton>

<BitOverlay @bind-IsOpen="AutoToggleIsOpen" Class="overlay" AutoToggleScroll>
    <BitStack Alignment="BitAlignment.Center">
        <BitText Style="color: dodgerblue;" Typography="BitTypography.H3">Please wait...</BitText>
        <BitProgress Indeterminate Thickness="10" Style="width: 19rem;"/>
    </BitStack>
</BitOverlay>
@code {
    private bool AutoToggleIsOpen;
}
                    
Scroller Selector
Set specific scroller element to toggle the scrollbar.

Short story

Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams. Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth, for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.

Short story

Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams. Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth, for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.
Every story starts with a blank canvas, a quiet space waiting to be filled with ideas, emotions, and dreams. These placeholder words symbolize the beginning—a moment of possibility where creativity has yet to take shape. Imagine this text as the scaffolding of something remarkable, a foundation upon which connections and inspirations will be built. Soon, these lines will transform into narratives that provoke thought, spark emotion, and resonate with those who encounter them. Until then, they remind us of the beauty in potential the quiet magic of beginnings, where everything is still to come, and the possibilities are boundless. This space is yours to craft, yours to shape, yours to bring to life.
In the beginning, there is silence a blank canvas yearning to be filled, a quiet space where creativity waits to awaken. These words are temporary, standing in place of ideas yet to come, a glimpse into the infinite possibilities that lie ahead. Think of this text as a bridge, connecting the empty spaces of now with the vibrant narratives of tomorrow. It whispers of the stories waiting to be told, of the thoughts yet to be shaped into meaning, and the emotions ready to resonate with every reader.
In this space, potential reigns supreme. It is a moment suspended in time, where imagination dances freely and each word has the power to transform into something extraordinary. Here lies the start of something new—an opportunity to craft, inspire, and create. Whether it's a tale of adventure, a reflection of truth, or an idea that sparks change, these lines are yours to fill, to shape, and to make uniquely yours. The journey begins here, in this quiet moment where everything is possible.
Imagine this space as a window into the future empty yet alive with the energy of endless possibilities. These words stand as temporary guides, placeholders that whisper of what is to come. They hold the promise of stories waiting to unfold, ideas eager to take shape, and connections that will soon emerge to inspire and resonate. This is not an empty page; it is a canvas, rich with potential and ready to transform into something meaningful.
For now, these lines are here to remind you of the beauty of beginnings. They are the quiet before the symphony, the foundation upon which your creativity will build. Soon, this space will hold your thoughts, your visions, and your voice a reflection of who you are and what you wish to share with the world. Every sentence will carry purpose, every word will invite others to connect, to think, to feel. So take a moment to dream, to imagine what this blank slate can become. Whether it’s a story, an idea, or a message that matters, this is your starting point. The possibilities are endless, and the journey begins now.
<style>
    .overlay {
        z-index: 9999;
        align-items: center;
        justify-content: center;
        background-color: rgba(0,0,0,.4);
    }

    .content {
        width: 87%;
        display: flex;
        padding: 15px;
        overflow: auto;
        max-height: 288px;
        border-radius: 3px;
        position: relative;
        background-color: white;
        flex-flow: column nowrap;
        border: dodgerblue solid 1.6px;
    }

    .scroller {
        height: 360px;
        padding: 15px;
        overflow: auto;
        margin-top: 15px;
        position: relative;
        border-radius: 3px;
        align-items: center;
        border: 2px solid green;
    }
</style>


<BitButton OnClick="() => EnabledScrollerIsOpen = true">Show with Enabled scrolling</BitButton>
<BitButton OnClick="() => DisabledScrollerIsOpen = true">Show with Disabled scrolling</BitButton>

<div class="scroller">
    <BitOverlay @bind-IsOpen="EnabledScrollerIsOpen"
                Class="overlay"
                Style="background-color:unset"
                ScrollerSelector=".scroller"
                AbsolutePosition>
        <div class="content">
            <h3>Short story</h3>
            <div>
                Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams.
                Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment
                when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth,
                for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.
            </div>
        </div>
    </BitOverlay>

    <BitOverlay @bind-IsOpen="DisabledScrollerIsOpen"
                Class="overlay"
                ScrollerSelector=".scroller"
                AbsolutePosition
                AutoToggleScroll>
        <BitProgress Circular Indeterminate Thickness="10" />
    </BitOverlay>

    <h3>Short story</h3>
    <div>
        Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams.
        Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment
        when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth,
        for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.
        <br />
        Every story starts with a blank canvas, a quiet space waiting to be filled with ideas, emotions, and dreams.
        These placeholder words symbolize the beginning—a moment of possibility where creativity has yet to take shape.
        Imagine this text as the scaffolding of something remarkable, a foundation upon which connections and
        inspirations will be built. Soon, these lines will transform into narratives that provoke thought,
        spark emotion, and resonate with those who encounter them. Until then, they remind us of the beauty
        in potential the quiet magic of beginnings, where everything is still to come, and the possibilities
        are boundless. This space is yours to craft, yours to shape, yours to bring to life.
        <br />
        In the beginning, there is silence a blank canvas yearning to be filled, a quiet space where creativity waits
        to awaken. These words are temporary, standing in place of ideas yet to come, a glimpse into the infinite
        possibilities that lie ahead. Think of this text as a bridge, connecting the empty spaces of now with the
        vibrant narratives of tomorrow. It whispers of the stories waiting to be told, of the thoughts yet to be
        shaped into meaning, and the emotions ready to resonate with every reader.
        <br />
        In this space, potential reigns supreme. It is a moment suspended in time, where imagination dances freely and
        each word has the power to transform into something extraordinary. Here lies the start of something new—an
        opportunity to craft, inspire, and create. Whether it's a tale of adventure, a reflection of truth, or an
        idea that sparks change, these lines are yours to fill, to shape, and to make uniquely yours. The journey
        begins here, in this quiet moment where everything is possible.
        <br />
        Imagine this space as a window into the future empty yet alive with the energy of endless possibilities.
        These words stand as temporary guides, placeholders that whisper of what is to come.
        They hold the promise of stories waiting to unfold, ideas eager to take shape, and
        connections that will soon emerge to inspire and resonate. This is not an empty page;
        it is a canvas, rich with potential and ready to transform into something meaningful.
        <br />
        For now, these lines are here to remind you of the beauty of beginnings. They are the quiet before the symphony,
        the foundation upon which your creativity will build. Soon, this space will hold your thoughts, your visions,
        and your voice a reflection of who you are and what you wish to share with the world. Every sentence will carry
        purpose, every word will invite others to connect, to think, to feel. So take a moment to dream, to imagine
        what this blank slate can become. Whether it’s a story, an idea, or a message that matters, this is your
        starting point. The possibilities are endless, and the journey begins now.
    </div>
</div>
@code {
    private bool EnabledScrollerIsOpen;
    private bool DisabledScrollerIsOpen;
}
                    
Events
Use BitOverlay with event handlers to handle custom actions on user interactions, such as clicking outside to close.

Short story

Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams. Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth, for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.
<style>
    .overlay {
        z-index: 9999;
        align-items: center;
        justify-content: center;
        background-color: rgba(0,0,0,.4);
    }

    .content {
        width: 85%;
        height: 250px;
        display: flex;
        padding: 15px;
        overflow: auto;
        border-radius: 3px;
        background-color: white;
        flex-flow: column nowrap;
    }
</style>


<BitButton OnClick="() => EventOnCloseIsOpen = true">Show Overlay</BitButton>
<BitOverlay @bind-IsOpen="EventOnCloseIsOpen" Class="overlay" OnClick=@(() => EventOnCloseIsOpen = false) NoAutoClose>
    <div class="content">
        <h3>Short story</h3>
        <div>
            Once upon a time, stories wove connections between people, a symphony of voices crafting shared dreams.
            Each word carried meaning, each pause brought understanding. Placeholder text reminds us of that moment
            when possibilities are limitless, waiting for content to emerge. The spaces here are open for growth,
            for ideas that change minds and spark emotions. This is where the journey begins your words will lead the way.
        </div>
    </div>
</BitOverlay>
@code {
    private bool EventOnCloseIsOpen;
}
                    

API

BitOverlay parameters
Name
Type
Default value
Description
AutoToggleScroll bool false When true, the scroll behavior of the Scroller element behind the overlay will be disabled.
AbsolutePosition bool false When true, the Overlay will be positioned absolute instead of fixed.
ChildContent RenderFragment? null The content of the Overlay.
IsOpen bool false When true, the Overlay and its content will be shown.
NoAutoClose bool false When true, the Overlay will be closed by clicking on it.
OnClick EventCallback<MouseEventArgs> Callback for when the toggle button is clicked.
ScrollerSelector string body Set the selector of the Selector element for the Overlay to disable its scroll if applicable.
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.
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