Vou criar um componente Sidebar responsivo em Blazor/Razor com Tailwind CSS. Este será um drawer que funciona bem tanto em desktop quanto mobile.
Components/Sidebar.razor
Agora vou criar um componente de item de menu para usar dentro do sidebar:
Components/SidebarMenuItem.razor
E aqui está um exemplo de como usar o componente:
Pages/ExamplePage.razor
O componente é totalmente funcional e pronto para uso em aplicações Blazor, seguindo as melhores práticas de responsividade e UX.
Vou criar um componente Sidebar responsivo usando Syncfusion Blazor components. O Syncfusion oferece componentes robustos que facilitam a criação de interfaces profissionais.
Components/ResponsiveSidebar.razor
Agora vou criar a classe MenuItem para os itens do menu:
Models/MenuItem.cs
E aqui está um exemplo de como usar o componente:
Pages/ExampleUsage.razor
Para usar este componente, você precisa instalar o Syncfusion Blazor no seu projeto:
YourApp.csproj
E configure no Program.cs:
Program.cs
O componente é totalmente profissional e pronto para produção, aproveitando toda a robustez do Syncfusion Blazor.
<div id="blazor-error-ui">
An unhandled error has occurred.
<a href="." class="reload">Reload</a>
<span class="dismiss">🗙</span>
</div>
<script src="_framework/blazor.webassembly.js"></script>
<script>navigator.serviceWorker.register('service-worker.js');</script>
</body>
</html>
mude a tela de carregamento do blazor, com uma progress bar moderna e em cima o nome da app, e nada mais.
#blazor-error-ui { color-scheme: light only; background: lightyellow; bottom: 0; box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2); box-sizing: border-box; display: none; left: 0; padding: 0.6rem 1.25rem 0.7rem 1.25rem; position: fixed; width: 100%; z-index: 1000; }
#blazor-error-ui .dismiss {
cursor: pointer;
position: absolute;
right: 0.75rem;
top: 0.5rem;
}
.blazor-error-boundary {
background: url() no-repeat 1rem/1.8rem, #b32121
;
padding: 1rem 1rem 1rem 3.7rem;
color: white;
}
.blazor-error-boundary::after {
content: "An error has occurred."
}
.loading-progress { position: relative; display: block; width: 8rem; height: 8rem; margin: 20vh auto 1rem auto; }
.loading-progress circle {
fill: none;
stroke: #e0e0e0;
stroke-width: 0.6rem;
transform-origin: 50% 50%;
transform: rotate(-90deg);
}
.loading-progress circle:last-child {
stroke: #1b6ec2;
stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
transition: stroke-dasharray 0.05s ease-in-out;
}
.loading-progress-text { position: absolute; text-align: center; font-weight: bold; inset: calc(20vh + 3.25rem) 0 auto 0.2rem; }
.loading-progress-text:after {
content: var(--blazor-load-percentage-text, "Loading");
}
code {
color: #c02d76
;
}
.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder { color: var(--bs-secondary-color); text-align: end; }
.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder { text-align: start; }