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.
        <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
        <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.
                
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.
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.
        <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