Modal
Modals are temporary pop-ups that take focus from the page or app and require people to interact with them. Unlike a dialog box (Dialog), a modal should be used for hosting lengthy content, such as privacy statements or license agreements, or for asking people to perform complex or multiple actions, such as changing settings.
Usage
Basic
<BitButton OnClick="() => isOpenBasic = true">Open Modal</BitButton> <BitModal @bind-IsOpen="isOpenBasic"> <div style="padding:1rem; max-width:40rem"> 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. </div> </BitModal>@code { private bool isOpenBasic; }
Customizing content
<style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton OnClick="() => isOpenCustomContent = true">Open Modal</BitButton> <BitModal @bind-IsOpen="isOpenCustomContent"> <div class="modal-header"> <span class="modal-header-text">Story title</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenCustomContent = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal>@code { private bool isOpenCustomContent; }
Advanced options
BitModal has some advanced options.
<style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton OnClick="() => isOpenBlocking = true">Open Modal (Blocking)</BitButton> <BitButton OnClick="() => isOpenAutoToggleScroll = true">Open Modal (AutoToggleScroll)</BitButton> <BitButton OnClick="() => isOpenModeless = true">Open Modal (Modeless)</BitButton> <BitModal @bind-IsOpen="isOpenBlocking" Blocking> <div class="modal-header"> <span class="modal-header-text">Blocking</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenBlocking = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> <p> In Blocking mode, the modal won't close by clicking outside (on the overlay). </p> <br /> <p> 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. </p> </div> </BitModal> <BitModal @bind-IsOpen="isOpenAutoToggleScroll" AutoToggleScroll> <div class="modal-header"> <span class="modal-header-text">AutoToggleScroll</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenAutoToggleScroll = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> <p> In AutoToggleScroll mode, the scrollbar of the scroll element (body by default and customizable with the ScrollerSelector parameter) will be removed when the modal opens. </p> <br /> <p> 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. </p> </div> </BitModal> <BitModal @bind-IsOpen="isOpenModeless" Modeless> <div class="modal-header"> <span class="modal-header-text">Modeless</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenModeless = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> <p> In Modeless mode, the overlay element won't render. </p> <br /> <p> 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. </p> </div> </BitModal>@code { private bool isOpenBlocking; private bool isOpenAutoToggleScroll; private bool isOpenModeless; }
Absolute positioning
BitModal has an absolute position option to further customize its location.
                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.
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.
<style> .relative-container { width: 100%; height: 400px; overflow: auto; margin-top: 1rem; position: relative; background-color: #eee; border: 2px lightgreen solid; } .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton OnClick="() => isOpenAbsolutePosition = true">Open Modal (AbsolutePosition)</BitButton> <BitButton OnClick="() => isOpenScrollerSelector = true">Open Modal (ScrollerSelector)</BitButton> <div class="relative-container"> <BitModal @bind-IsOpen="isOpenAbsolutePosition" AbsolutePosition Modeless> <div class="modal-header"> <span class="modal-header-text">AbsolutePosition & Modeless</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenAbsolutePosition = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal> <BitModal @bind-IsOpen="isOpenScrollerSelector" AutoToggleScroll AbsolutePosition ScrollerSelector=".relative-container"> <div class="modal-header"> <span class="modal-header-text">ScrollerSelector</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenScrollerSelector = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal> <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. </div> </div>@code { private bool isOpenAbsolutePosition; private bool isOpenScrollerSelector; }
Position
To set the modal position on the page you can use the Position parameter.
<style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.TopLeft)">Top Left</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.TopCenter)">Top Center</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.TopRight)">Top Right</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.TopStart)">Top Start</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.TopEnd)">Top End</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.CenterLeft)">Center Left</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.Center)">Center</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.CenterRight)">Center Right</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.CenterStart)">Center Start</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.CenterEnd)">Center End</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.BottomLeft)">Bottom Left</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.BottomCenter)">Bottom Center</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.BottomRight)">Bottom Right</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.BottomStart)">Bottom Start</BitButton> <BitButton Class="position-button" OnClick="() => OpenModalInPosition(BitPosition.BottomEnd)">Bottom End</BitButton> <BitModal @bind-IsOpen="isOpenPosition" Position="position"> <div class="modal-header"> <span class="modal-header-text">Modal positioning</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenPosition = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> BitModal with custom positioning. Once upon a time, stories wove connections between people. </div> </BitModal>@code { private bool isOpenPosition; private BitPosition position; private void OpenModalInPosition(BitPosition positionValue) { isOpenPosition = true; position = positionValue; } }
Draggable
The Draggable parameter of the BitModal allows users to move the modal around the screen.
Using custom drag element.
<style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton OnClick="() => isOpenDraggable = true">Open Modal</BitButton> <BitModal @bind-IsOpen="isOpenDraggable" Draggable> <div class="modal-header"> <span class="modal-header-text">Draggble Modal</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenDraggable = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal> <BitButton OnClick="() => isOpenDraggableSelector = true">Open Modal</BitButton> <BitModal @bind-IsOpen="isOpenDraggableSelector" Draggable DragElementSelector=".modal-header-drag"> <div class="modal-header modal-header-drag"> <span class="modal-header-text">Draggble Modal with custom drag element</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenDraggableSelector = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal>@code { private bool isOpenDraggable; private bool isOpenDraggableSelector; }
FullSize
The FullSize parameter of the BitModal allows the modal to be full-screen.
<style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton OnClick="() => isOpenFullSize = true">Open Modal</BitButton> <BitModal @bind-IsOpen="isOpenFullSize" FullSize="isFullSize"> <div class="modal-header"> <span class="modal-header-text">Full size modal</span> <BitButton Variant="BitVariant.Text" OnClick="() => isFullSize = !isFullSize" IconName="@(isFullSize ? BitIconName.BackToWindow : BitIconName.ChromeFullScreen)" Title="@(isFullSize ? "Exit FullScreen" : "FullScreen")" /> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenFullSize = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal>@code { private bool isOpenFullSize; private bool isFullSize; }
Events
Discover different events available in the BitModal component.
Dismissed? [False]
        Overlay clicked? [False]
        <style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton OnClick="() => isEventsOpen = true">Open Modal</BitButton> <div>Dismissed? [@isDismissed]</div> <div>Overlay clicked? [@isOverlayClicked]</div> <BitModal @bind-IsOpen="isEventsOpen" Draggable OnDismiss="HandleOnDismiss" OnOverlayClick="HandleOnOverlayClick"> <div class="modal-header"> <span class="modal-header-text">Events modal</span> <BitButton Title="Close" Variant="BitVariant.Text" OnClick="() => isEventsOpen = false" IconName="@BitIconName.ChromeClose" /> </div> <div class="modal-body"> 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. </div> </BitModal>@code { private bool isEventsOpen; private bool isDismissed; private bool isOverlayClicked; private async Task HandleOnDismiss() { isDismissed = true; await Task.Delay(3000); isDismissed = false; } private void HandleOnOverlayClick() { isOverlayClicked = true; _ = Task.Delay(2000).ContinueWith(_ => { isOverlayClicked = false; InvokeAsync(StateHasChanged); }); } }
Style & Class
Using css related parameter users can further customize the modal based on their needs.
            Component's Style & Class:
Styles & Classes:
<style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } .custom-class { border: 0.5rem solid tomato; background-color: darkgoldenrod; } .custom-root { border: 0.25rem solid #0054C6; } .custom-overlay { background-color: #ffbd5a66; } .custom-content { margin: 1rem; box-shadow: 0 0 10rem purple; border-end-end-radius: 1rem; border-end-start-radius: 1rem; } </style> <BitButton OnClick="() => isOpenStyle = true">Open styled modal</BitButton> <BitButton OnClick="() => isOpenClass = true">Open classed modal</BitButton> <BitModal @bind-IsOpen="isOpenStyle" Style="box-shadow: inset 0px 0px 1.5rem 1.5rem palevioletred;"> <div class="modal-header"> <span class="modal-header-text">Styled modal</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenStyle = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal> <BitModal @bind-IsOpen="isOpenClass" Class="custom-class"> <div class="modal-header"> <span class="modal-header-text">Classed modal</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenClass = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal> <BitButton OnClick="() => isOpenStyles = true">Open modal styles</BitButton> <BitButton OnClick="() => isOpenClasses = true">Open modal classes</BitButton> <BitModal @bind-IsOpen="isOpenStyles" Styles="@(new() { Overlay = "background-color: #4776f433;", Content = "box-shadow: 0 0 1rem tomato;" })"> <div class="modal-header"> <span class="modal-header-text">Modal styles</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenStyles = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal> <BitModal @bind-IsOpen="isOpenClasses" Classes="@(new() { Root = "custom-root", Overlay = "custom-overlay", Content = "custom-content" })"> <div class="modal-header"> <span class="modal-header-text">Modal classes</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenClasses = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> 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. </div> </BitModal>@code { private bool isOpenStyle; private bool isOpenClass; private bool isOpenStyles; private bool isOpenClasses; }
RTL
Use BitModal in right-to-left (RTL).
<style> .modal-header { gap: 0.5rem; display: flex; font-size: 24px; font-weight: 600; align-items: center; padding: 12px 12px 14px 24px; border-top: 4px solid #0054C6; } .modal-header-text { flex-grow: 1; } .modal-body { max-width: 960px; line-height: 20px; overflow-y: hidden; padding: 0 24px 24px; } </style> <BitButton Dir="BitDir.Rtl" OnClick="() => isOpenRtl = true">باز کردن مُدال</BitButton> <BitModal Dir="BitDir.Rtl" @bind-IsOpen="isOpenRtl"> <div class="modal-header"> <span class="modal-header-text">لورم ایپسوم</span> <BitButton Variant="BitVariant.Text" OnClick="() => isOpenRtl = false" IconName="@BitIconName.ChromeClose" Title="Close" /> </div> <div class="modal-body"> <p> لورم ایپسوم متن ساختگی با تولید سادگی نامفهوم از صنعت چاپ و با استفاده از طراحان گرافیک است. چاپگرها و متون بلکه روزنامه و مجله در ستون و سطرآنچنان که لازم است و برای شرایط فعلی تکنولوژی مورد نیاز و کاربردهای متنوع با هدف بهبود ابزارهای کاربردی می باشد. کتابهای زیادی در شصت و سه درصد گذشته، حال و آینده شناخت فراوان جامعه و متخصصان را می طلبد تا با نرم افزارها شناخت بیشتری را برای طراحان رایانه ای علی الخصوص طراحان خلاقی و فرهنگ پیشرو در زبان فارسی ایجاد کرد. در این صورت می توان امید داشت که تمام و دشواری موجود در ارائه راهکارها و شرایط سخت تایپ به پایان رسد وزمان مورد نیاز شامل حروفچینی دستاوردهای اصلی و جوابگوی سوالات پیوسته اهل دنیای موجود طراحی اساسا مورد استفاده قرار گیرد. </p> <p> لورم ایپسوم متن ساختگی با تولید سادگی نامفهوم از صنعت چاپ و با استفاده از طراحان گرافیک است. چاپگرها و متون بلکه روزنامه و مجله در ستون و سطرآنچنان که لازم است و برای شرایط فعلی تکنولوژی مورد نیاز و کاربردهای متنوع با هدف بهبود ابزارهای کاربردی می باشد. کتابهای زیادی در شصت و سه درصد گذشته، حال و آینده شناخت فراوان جامعه و متخصصان را می طلبد تا با نرم افزارها شناخت بیشتری را برای طراحان رایانه ای علی الخصوص طراحان خلاقی و فرهنگ پیشرو در زبان فارسی ایجاد کرد. در این صورت می توان امید داشت که تمام و دشواری موجود در ارائه راهکارها و شرایط سخت تایپ به پایان رسد وزمان مورد نیاز شامل حروفچینی دستاوردهای اصلی و جوابگوی سوالات پیوسته اهل دنیای موجود طراحی اساسا مورد استفاده قرار گیرد. </p> <p> لورم ایپسوم متن ساختگی با تولید سادگی نامفهوم از صنعت چاپ و با استفاده از طراحان گرافیک است. چاپگرها و متون بلکه روزنامه و مجله در ستون و سطرآنچنان که لازم است و برای شرایط فعلی تکنولوژی مورد نیاز و کاربردهای متنوع با هدف بهبود ابزارهای کاربردی می باشد. کتابهای زیادی در شصت و سه درصد گذشته، حال و آینده شناخت فراوان جامعه و متخصصان را می طلبد تا با نرم افزارها شناخت بیشتری را برای طراحان رایانه ای علی الخصوص طراحان خلاقی و فرهنگ پیشرو در زبان فارسی ایجاد کرد. در این صورت می توان امید داشت که تمام و دشواری موجود در ارائه راهکارها و شرایط سخت تایپ به پایان رسد وزمان مورد نیاز شامل حروفچینی دستاوردهای اصلی و جوابگوی سوالات پیوسته اهل دنیای موجود طراحی اساسا مورد استفاده قرار گیرد. </p> </div> </BitModal>@code { private bool isOpenRtl; }
API
BitModal parameters
| Name | Type | Default value | Description | 
|---|---|---|---|
| AutoToggleScroll | bool | false | Enables the auto scrollbar toggle behavior of the Modal. | 
| AbsolutePosition | bool | false | When true, the Modal will be positioned absolute instead of fixed. | 
| Blocking | bool | false | Whether the Modal can be light dismissed by clicking outside the Modal (on the overlay). | 
| ChildContent | RenderFragment? | null | The content of Modal, It can be Any custom tag or a text. | 
| Classes | BitModalClassStyles? | null | Custom CSS classes for different parts of the BitModal component. | 
| DragElementSelector | string? | null | The CSS selector of the drag element. by default the Modal container is the drag element. | 
| Draggable | bool | false | Whether the Modal can be dragged around. | 
| FullHeight | bool | false | Makes the Modal height 100% of its parent container. | 
| FullSize | bool | false | Makes the Modal width and height 100% of its parent container. | 
| FullWidth | bool | false | Makes the Modal width 100% of its parent container. | 
| IsAlert | bool? | null | Determines the ARIA role of the Modal (alertdialog/dialog). If this is set, it will override the ARIA role determined by Blocking and Modeless. | 
| IsOpen | bool | false | Whether the Modal is displayed. | 
| Modeless | bool | false | Whether the Modal should be modeless (e.g. not dismiss when focusing/clicking outside of the Modal). if true: Blocking is ignored, there will be no overlay. | 
| OnDismiss | EventCallback<MouseEventArgs> | A callback function for when the Modal is dismissed. | |
| OnOverlayClick | EventCallback<MouseEventArgs> | A callback function for when somewhere on the overlay element of the Modal is clicked. | |
| Position | BitPosition? | null | Position of the Modal on the screen. | 
| ScrollerElement | ElementReference? | null | Set the element reference for which the Modal disables its scroll if applicable. | 
| ScrollerSelector | string? | null | Set the element selector for which the Modal disables its scroll if applicable. | 
| Styles | BitModalClassStyles? | null | Custom CSS styles for different parts of the BitModal component. | 
| SubtitleAriaId | string? | null | ARIA id for the subtitle of the Modal, if any. | 
| TitleAriaId | string? | null | ARIA id for the title of the Modal, if any. | 
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. | 
BitModalClassStyles properties
| Name | Type | Default value | Description | 
|---|---|---|---|
| Root | string? | null | Custom CSS classes/styles for the root element of the BitModal. | 
| Overlay | string? | null | Custom CSS classes/styles for the overlay of the BitModal. | 
| Content | string? | null | Custom CSS classes/styles for the content of the BitModal. | 
BitPosition enum
| Name | Value | Description | 
|---|---|---|
| TopLeft | 0 | |
| TopCenter | 1 | |
| TopRight | 2 | |
| TopStart | 3 | |
| TopEnd | 4 | |
| CenterLeft | 5 | |
| Center | 6 | |
| CenterRight | 7 | |
| CenterStart | 8 | |
| CenterEnd | 9 | |
| BottomLeft | 10 | |
| BottomCenter | 11 | |
| BottomRight | 12 | |
| BottomStart | 13 | |
| BottomEnd | 14 | 
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