+ Swapping to Development environment will display more detailed information about the error that occurred.
+
+
+ The Development environment shouldn't be enabled for deployed applications.
+ It can result in displaying sensitive information from exceptions to end users.
+ For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development
+ and restarting the app.
+
+ Swapping to Development environment will display more detailed information about the error that occurred.
+
+
+ The Development environment shouldn't be enabled for deployed applications.
+ It can result in displaying sensitive information from exceptions to end users.
+ For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development
+ and restarting the app.
+
+
+@code{
+ [CascadingParameter]
+ private HttpContext? HttpContext { get; set; }
+
+ private string? RequestId { get; set; }
+ private bool ShowRequestId => !string.IsNullOrEmpty(RequestId);
+
+ protected override void OnInitialized() =>
+ RequestId = Activity.Current?.Id ?? HttpContext?.TraceIdentifier;
+}
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Pages/Home.razor b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Pages/Home.razor
new file mode 100644
index 0000000..bfc157a
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Pages/Home.razor
@@ -0,0 +1,6 @@
+@page "/";
+
+
+
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Pages/Weather.razor b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Pages/Weather.razor
new file mode 100644
index 0000000..381bbd2
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Pages/Weather.razor
@@ -0,0 +1,64 @@
+@page "/weather"
+@attribute [StreamRendering]
+
+Weather
+
+
Weather
+
+
This component demonstrates showing data.
+
+@if (forecasts == null)
+{
+
Loading...
+}
+else
+{
+
+
+
+
Date
+
Temp. (C)
+
Temp. (F)
+
Summary
+
+
+
+ @foreach (var forecast in forecasts)
+ {
+
+
@forecast.Date.ToShortDateString()
+
@forecast.TemperatureC
+
@forecast.TemperatureF
+
@forecast.Summary
+
+ }
+
+
+}
+
+@code {
+ private WeatherForecast[]? forecasts;
+
+ protected override async Task OnInitializedAsync()
+ {
+ // Simulate asynchronous loading to demonstrate streaming rendering
+ await Task.Delay(500);
+
+ var startDate = DateOnly.FromDateTime(DateTime.Now);
+ var summaries = new[] { "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching" };
+ forecasts = Enumerable.Range(1, 5).Select(index => new WeatherForecast
+ {
+ Date = startDate.AddDays(index),
+ TemperatureC = Random.Shared.Next(-20, 55),
+ Summary = summaries[Random.Shared.Next(summaries.Length)]
+ }).ToArray();
+ }
+
+ private class WeatherForecast
+ {
+ public DateOnly Date { get; set; }
+ public int TemperatureC { get; set; }
+ public string? Summary { get; set; }
+ public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
+ }
+}
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Routes.razor b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Routes.razor
new file mode 100644
index 0000000..f756e19
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/Routes.razor
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/_Imports.razor b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/_Imports.razor
new file mode 100644
index 0000000..8ac97a9
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Components/_Imports.razor
@@ -0,0 +1,12 @@
+@using System.Net.Http
+@using System.Net.Http.Json
+@using Microsoft.AspNetCore.Components.Forms
+@using Microsoft.AspNetCore.Components.Routing
+@using Microsoft.AspNetCore.Components.Web
+@using static Microsoft.AspNetCore.Components.Web.RenderMode
+@using Microsoft.AspNetCore.Components.Web.Virtualization
+@using Microsoft.JSInterop
+@using BlazorWebApp
+@using BlazorWebApp.Components
+@using Syncfusion.Blazor;
+@using Syncfusion.Blazor.SfPdfViewer;
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/NuGet.config b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/NuGet.config
new file mode 100644
index 0000000..7c8896e
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/NuGet.config
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Program.cs b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Program.cs
new file mode 100644
index 0000000..26d0fc0
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Program.cs
@@ -0,0 +1,34 @@
+using BlazorWebApp.Components;
+using Syncfusion.Blazor;
+
+var builder = WebApplication.CreateBuilder(args);
+
+// Add services to the container.
+builder.Services.AddRazorComponents()
+ .AddInteractiveServerComponents();
+builder.Services.AddSignalR(o => { o.MaximumReceiveMessageSize = 102400000; });
+
+builder.Services.AddMemoryCache();
+//Add Syncfusion Blazor service to the container.
+builder.Services.AddSyncfusionBlazor();
+
+var app = builder.Build();
+
+// Configure the HTTP request pipeline.
+if (!app.Environment.IsDevelopment())
+{
+ app.UseExceptionHandler("/Error", createScopeForErrors: true);
+ // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
+ app.UseHsts();
+}
+
+app.UseHttpsRedirection();
+
+
+app.UseAntiforgery();
+
+app.MapStaticAssets();
+app.MapRazorComponents()
+ .AddInteractiveServerRenderMode();
+
+app.Run();
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Properties/launchSettings.json b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Properties/launchSettings.json
new file mode 100644
index 0000000..7ce71cf
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/Properties/launchSettings.json
@@ -0,0 +1,23 @@
+{
+ "$schema": "https://json.schemastore.org/launchsettings.json",
+ "profiles": {
+ "http": {
+ "commandName": "Project",
+ "dotnetRunMessages": true,
+ "launchBrowser": true,
+ "applicationUrl": "http://localhost:5148",
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ },
+ "https": {
+ "commandName": "Project",
+ "dotnetRunMessages": true,
+ "launchBrowser": true,
+ "applicationUrl": "https://localhost:7077;http://localhost:5148",
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ }
+ }
+ }
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/appsettings.Development.json b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/appsettings.Development.json
new file mode 100644
index 0000000..0c208ae
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/appsettings.Development.json
@@ -0,0 +1,8 @@
+{
+ "Logging": {
+ "LogLevel": {
+ "Default": "Information",
+ "Microsoft.AspNetCore": "Warning"
+ }
+ }
+}
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/appsettings.json b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/appsettings.json
new file mode 100644
index 0000000..10f68b8
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/appsettings.json
@@ -0,0 +1,9 @@
+{
+ "Logging": {
+ "LogLevel": {
+ "Default": "Information",
+ "Microsoft.AspNetCore": "Warning"
+ }
+ },
+ "AllowedHosts": "*"
+}
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/Data/PDF_Succinctly.pdf b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/Data/PDF_Succinctly.pdf
new file mode 100644
index 0000000..d06ad9a
Binary files /dev/null and b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/Data/PDF_Succinctly.pdf differ
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/app.css b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/app.css
new file mode 100644
index 0000000..73a69d6
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/app.css
@@ -0,0 +1,60 @@
+html, body {
+ font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
+}
+
+a, .btn-link {
+ color: #006bb7;
+}
+
+.btn-primary {
+ color: #fff;
+ background-color: #1b6ec2;
+ border-color: #1861ac;
+}
+
+.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
+ box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
+}
+
+.content {
+ padding-top: 1.1rem;
+}
+
+h1:focus {
+ outline: none;
+}
+
+.valid.modified:not([type=checkbox]) {
+ outline: 1px solid #26b050;
+}
+
+.invalid {
+ outline: 1px solid #e50000;
+}
+
+.validation-message {
+ color: #e50000;
+}
+
+.blazor-error-boundary {
+ background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
+ padding: 1rem 1rem 1rem 3.7rem;
+ color: white;
+}
+
+ .blazor-error-boundary::after {
+ content: "An error has occurred."
+ }
+
+.darker-border-checkbox.form-check-input {
+ border-color: #929292;
+}
+
+.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;
+}
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/favicon.png b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/favicon.png
new file mode 100644
index 0000000..8422b59
Binary files /dev/null and b/Toolbar/Mobile Toolbar/Enable Scrolling in Desktop Mode/BlazorWebApp/wwwroot/favicon.png differ
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/BlazorWebApp.csproj b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/BlazorWebApp.csproj
new file mode 100644
index 0000000..e4e8a53
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/BlazorWebApp.csproj
@@ -0,0 +1,12 @@
+
+
+
+ net9.0
+ enable
+ enable
+
+
+
+
+
+
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/BlazorWebApp.sln b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/BlazorWebApp.sln
new file mode 100644
index 0000000..39d60d1
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/BlazorWebApp.sln
@@ -0,0 +1,34 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio Version 17
+VisualStudioVersion = 17.0.31903.59
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "BlazorWebApp", "BlazorWebApp.csproj", "{042F4C27-8295-403A-B94B-04DBA225CB7F}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|Any CPU = Debug|Any CPU
+ Debug|x64 = Debug|x64
+ Debug|x86 = Debug|x86
+ Release|Any CPU = Release|Any CPU
+ Release|x64 = Release|x64
+ Release|x86 = Release|x86
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x64.ActiveCfg = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x64.Build.0 = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x86.ActiveCfg = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x86.Build.0 = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|Any CPU.Build.0 = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x64.ActiveCfg = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x64.Build.0 = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x86.ActiveCfg = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x86.Build.0 = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+EndGlobal
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/App.razor b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/App.razor
new file mode 100644
index 0000000..f734711
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/App.razor
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Layout/MainLayout.razor b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Layout/MainLayout.razor
new file mode 100644
index 0000000..78624f3
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Layout/MainLayout.razor
@@ -0,0 +1,23 @@
+@inherits LayoutComponentBase
+
+
+
+
+
+@code {
+ private int currentCount = 0;
+
+ private void IncrementCount()
+ {
+ currentCount++;
+ }
+}
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Error.razor b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Error.razor
new file mode 100644
index 0000000..576cc2d
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Error.razor
@@ -0,0 +1,36 @@
+@page "/Error"
+@using System.Diagnostics
+
+Error
+
+
Error.
+
An error occurred while processing your request.
+
+@if (ShowRequestId)
+{
+
+ Request ID:@RequestId
+
+}
+
+
Development Mode
+
+ Swapping to Development environment will display more detailed information about the error that occurred.
+
+
+ The Development environment shouldn't be enabled for deployed applications.
+ It can result in displaying sensitive information from exceptions to end users.
+ For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development
+ and restarting the app.
+
+
+@code{
+ [CascadingParameter]
+ private HttpContext? HttpContext { get; set; }
+
+ private string? RequestId { get; set; }
+ private bool ShowRequestId => !string.IsNullOrEmpty(RequestId);
+
+ protected override void OnInitialized() =>
+ RequestId = Activity.Current?.Id ?? HttpContext?.TraceIdentifier;
+}
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Home.razor b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Home.razor
new file mode 100644
index 0000000..e19ca8e
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Home.razor
@@ -0,0 +1,6 @@
+@page "/";
+
+
+
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Weather.razor b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Weather.razor
new file mode 100644
index 0000000..381bbd2
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Pages/Weather.razor
@@ -0,0 +1,64 @@
+@page "/weather"
+@attribute [StreamRendering]
+
+Weather
+
+
Weather
+
+
This component demonstrates showing data.
+
+@if (forecasts == null)
+{
+
Loading...
+}
+else
+{
+
+
+
+
Date
+
Temp. (C)
+
Temp. (F)
+
Summary
+
+
+
+ @foreach (var forecast in forecasts)
+ {
+
+
@forecast.Date.ToShortDateString()
+
@forecast.TemperatureC
+
@forecast.TemperatureF
+
@forecast.Summary
+
+ }
+
+
+}
+
+@code {
+ private WeatherForecast[]? forecasts;
+
+ protected override async Task OnInitializedAsync()
+ {
+ // Simulate asynchronous loading to demonstrate streaming rendering
+ await Task.Delay(500);
+
+ var startDate = DateOnly.FromDateTime(DateTime.Now);
+ var summaries = new[] { "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching" };
+ forecasts = Enumerable.Range(1, 5).Select(index => new WeatherForecast
+ {
+ Date = startDate.AddDays(index),
+ TemperatureC = Random.Shared.Next(-20, 55),
+ Summary = summaries[Random.Shared.Next(summaries.Length)]
+ }).ToArray();
+ }
+
+ private class WeatherForecast
+ {
+ public DateOnly Date { get; set; }
+ public int TemperatureC { get; set; }
+ public string? Summary { get; set; }
+ public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
+ }
+}
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Routes.razor b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Routes.razor
new file mode 100644
index 0000000..f756e19
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/Routes.razor
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/_Imports.razor b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/_Imports.razor
new file mode 100644
index 0000000..8ac97a9
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Components/_Imports.razor
@@ -0,0 +1,12 @@
+@using System.Net.Http
+@using System.Net.Http.Json
+@using Microsoft.AspNetCore.Components.Forms
+@using Microsoft.AspNetCore.Components.Routing
+@using Microsoft.AspNetCore.Components.Web
+@using static Microsoft.AspNetCore.Components.Web.RenderMode
+@using Microsoft.AspNetCore.Components.Web.Virtualization
+@using Microsoft.JSInterop
+@using BlazorWebApp
+@using BlazorWebApp.Components
+@using Syncfusion.Blazor;
+@using Syncfusion.Blazor.SfPdfViewer;
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/NuGet.config b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/NuGet.config
new file mode 100644
index 0000000..7c8896e
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/NuGet.config
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Program.cs b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Program.cs
new file mode 100644
index 0000000..26d0fc0
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Program.cs
@@ -0,0 +1,34 @@
+using BlazorWebApp.Components;
+using Syncfusion.Blazor;
+
+var builder = WebApplication.CreateBuilder(args);
+
+// Add services to the container.
+builder.Services.AddRazorComponents()
+ .AddInteractiveServerComponents();
+builder.Services.AddSignalR(o => { o.MaximumReceiveMessageSize = 102400000; });
+
+builder.Services.AddMemoryCache();
+//Add Syncfusion Blazor service to the container.
+builder.Services.AddSyncfusionBlazor();
+
+var app = builder.Build();
+
+// Configure the HTTP request pipeline.
+if (!app.Environment.IsDevelopment())
+{
+ app.UseExceptionHandler("/Error", createScopeForErrors: true);
+ // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
+ app.UseHsts();
+}
+
+app.UseHttpsRedirection();
+
+
+app.UseAntiforgery();
+
+app.MapStaticAssets();
+app.MapRazorComponents()
+ .AddInteractiveServerRenderMode();
+
+app.Run();
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Properties/launchSettings.json b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Properties/launchSettings.json
new file mode 100644
index 0000000..7ce71cf
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/Properties/launchSettings.json
@@ -0,0 +1,23 @@
+{
+ "$schema": "https://json.schemastore.org/launchsettings.json",
+ "profiles": {
+ "http": {
+ "commandName": "Project",
+ "dotnetRunMessages": true,
+ "launchBrowser": true,
+ "applicationUrl": "http://localhost:5148",
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ },
+ "https": {
+ "commandName": "Project",
+ "dotnetRunMessages": true,
+ "launchBrowser": true,
+ "applicationUrl": "https://localhost:7077;http://localhost:5148",
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ }
+ }
+ }
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/appsettings.Development.json b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/appsettings.Development.json
new file mode 100644
index 0000000..0c208ae
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/appsettings.Development.json
@@ -0,0 +1,8 @@
+{
+ "Logging": {
+ "LogLevel": {
+ "Default": "Information",
+ "Microsoft.AspNetCore": "Warning"
+ }
+ }
+}
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/appsettings.json b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/appsettings.json
new file mode 100644
index 0000000..10f68b8
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/appsettings.json
@@ -0,0 +1,9 @@
+{
+ "Logging": {
+ "LogLevel": {
+ "Default": "Information",
+ "Microsoft.AspNetCore": "Warning"
+ }
+ },
+ "AllowedHosts": "*"
+}
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/Data/PDF_Succinctly.pdf b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/Data/PDF_Succinctly.pdf
new file mode 100644
index 0000000..d06ad9a
Binary files /dev/null and b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/Data/PDF_Succinctly.pdf differ
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/app.css b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/app.css
new file mode 100644
index 0000000..73a69d6
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/app.css
@@ -0,0 +1,60 @@
+html, body {
+ font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
+}
+
+a, .btn-link {
+ color: #006bb7;
+}
+
+.btn-primary {
+ color: #fff;
+ background-color: #1b6ec2;
+ border-color: #1861ac;
+}
+
+.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
+ box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
+}
+
+.content {
+ padding-top: 1.1rem;
+}
+
+h1:focus {
+ outline: none;
+}
+
+.valid.modified:not([type=checkbox]) {
+ outline: 1px solid #26b050;
+}
+
+.invalid {
+ outline: 1px solid #e50000;
+}
+
+.validation-message {
+ color: #e50000;
+}
+
+.blazor-error-boundary {
+ background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
+ padding: 1rem 1rem 1rem 3.7rem;
+ color: white;
+}
+
+ .blazor-error-boundary::after {
+ content: "An error has occurred."
+ }
+
+.darker-border-checkbox.form-check-input {
+ border-color: #929292;
+}
+
+.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;
+}
\ No newline at end of file
diff --git a/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/favicon.png b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/favicon.png
new file mode 100644
index 0000000..8422b59
Binary files /dev/null and b/Toolbar/Mobile Toolbar/Modern Navigation Panel in Mobile View/BlazorWebApp/wwwroot/favicon.png differ
diff --git a/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/BlazorWebApp.csproj b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/BlazorWebApp.csproj
new file mode 100644
index 0000000..e4e8a53
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/BlazorWebApp.csproj
@@ -0,0 +1,12 @@
+
+
+
+ net9.0
+ enable
+ enable
+
+
+
+
+
+
diff --git a/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/BlazorWebApp.sln b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/BlazorWebApp.sln
new file mode 100644
index 0000000..39d60d1
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/BlazorWebApp.sln
@@ -0,0 +1,34 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio Version 17
+VisualStudioVersion = 17.0.31903.59
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "BlazorWebApp", "BlazorWebApp.csproj", "{042F4C27-8295-403A-B94B-04DBA225CB7F}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|Any CPU = Debug|Any CPU
+ Debug|x64 = Debug|x64
+ Debug|x86 = Debug|x86
+ Release|Any CPU = Release|Any CPU
+ Release|x64 = Release|x64
+ Release|x86 = Release|x86
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x64.ActiveCfg = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x64.Build.0 = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x86.ActiveCfg = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Debug|x86.Build.0 = Debug|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|Any CPU.Build.0 = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x64.ActiveCfg = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x64.Build.0 = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x86.ActiveCfg = Release|Any CPU
+ {042F4C27-8295-403A-B94B-04DBA225CB7F}.Release|x86.Build.0 = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+EndGlobal
diff --git a/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/App.razor b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/App.razor
new file mode 100644
index 0000000..f734711
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/App.razor
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/Layout/MainLayout.razor b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/Layout/MainLayout.razor
new file mode 100644
index 0000000..78624f3
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/Layout/MainLayout.razor
@@ -0,0 +1,23 @@
+@inherits LayoutComponentBase
+
+
+
+
+
+@code {
+ private int currentCount = 0;
+
+ private void IncrementCount()
+ {
+ currentCount++;
+ }
+}
diff --git a/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/Pages/Error.razor b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/Pages/Error.razor
new file mode 100644
index 0000000..576cc2d
--- /dev/null
+++ b/Toolbar/Mobile Toolbar/Redaction Toolbar in Mobile View/BlazorWebApp/Components/Pages/Error.razor
@@ -0,0 +1,36 @@
+@page "/Error"
+@using System.Diagnostics
+
+Error
+
+
Error.
+
An error occurred while processing your request.
+
+@if (ShowRequestId)
+{
+
+ Request ID:@RequestId
+
+}
+
+
Development Mode
+
+ Swapping to Development environment will display more detailed information about the error that occurred.
+
+
+ The Development environment shouldn't be enabled for deployed applications.
+ It can result in displaying sensitive information from exceptions to end users.
+ For local debugging, enable the Development environment by setting the ASPNETCORE_ENVIRONMENT environment variable to Development
+ and restarting the app.
+