From 3e9436ba0c1768df4748d8d973c8d2e2df111cb6 Mon Sep 17 00:00:00 2001 From: "HOME-LAPTOP\\kshkulev" Date: Mon, 22 Sep 2025 19:50:45 +0900 Subject: [PATCH] Add new Blazor web app --- Hcs.WebApp/Components/App.razor | 18 +++++++++ Hcs.WebApp/Components/Layout/MainLayout.razor | 9 +++++ .../Components/Layout/MainLayout.razor.css | 18 +++++++++ Hcs.WebApp/Components/Pages/Error.razor | 39 +++++++++++++++++++ Hcs.WebApp/Components/Pages/Home.razor | 7 ++++ Hcs.WebApp/Components/Routes.razor | 6 +++ Hcs.WebApp/Components/_Imports.razor | 10 +++++ Hcs.WebApp/Hcs.WebApp.csproj | 9 +++++ Hcs.WebApp/Program.cs | 24 ++++++++++++ Hcs.WebApp/Properties/launchSettings.json | 38 ++++++++++++++++++ Hcs.WebApp/appsettings.Development.json | 8 ++++ Hcs.WebApp/appsettings.json | 9 +++++ Hcs.WebApp/wwwroot/app.css | 29 ++++++++++++++ Hcs.sln | 8 +++- 14 files changed, 231 insertions(+), 1 deletion(-) create mode 100644 Hcs.WebApp/Components/App.razor create mode 100644 Hcs.WebApp/Components/Layout/MainLayout.razor create mode 100644 Hcs.WebApp/Components/Layout/MainLayout.razor.css create mode 100644 Hcs.WebApp/Components/Pages/Error.razor create mode 100644 Hcs.WebApp/Components/Pages/Home.razor create mode 100644 Hcs.WebApp/Components/Routes.razor create mode 100644 Hcs.WebApp/Components/_Imports.razor create mode 100644 Hcs.WebApp/Hcs.WebApp.csproj create mode 100644 Hcs.WebApp/Program.cs create mode 100644 Hcs.WebApp/Properties/launchSettings.json create mode 100644 Hcs.WebApp/appsettings.Development.json create mode 100644 Hcs.WebApp/appsettings.json create mode 100644 Hcs.WebApp/wwwroot/app.css diff --git a/Hcs.WebApp/Components/App.razor b/Hcs.WebApp/Components/App.razor new file mode 100644 index 0000000..04aea9e --- /dev/null +++ b/Hcs.WebApp/Components/App.razor @@ -0,0 +1,18 @@ + + + + + + + + + + + + + + + + + + diff --git a/Hcs.WebApp/Components/Layout/MainLayout.razor b/Hcs.WebApp/Components/Layout/MainLayout.razor new file mode 100644 index 0000000..526c101 --- /dev/null +++ b/Hcs.WebApp/Components/Layout/MainLayout.razor @@ -0,0 +1,9 @@ +@inherits LayoutComponentBase + +@Body + +
+ An unhandled error has occurred + Reload + 🗙 +
diff --git a/Hcs.WebApp/Components/Layout/MainLayout.razor.css b/Hcs.WebApp/Components/Layout/MainLayout.razor.css new file mode 100644 index 0000000..df8c10f --- /dev/null +++ b/Hcs.WebApp/Components/Layout/MainLayout.razor.css @@ -0,0 +1,18 @@ +#blazor-error-ui { + background: lightyellow; + bottom: 0; + box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2); + 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; + } diff --git a/Hcs.WebApp/Components/Pages/Error.razor b/Hcs.WebApp/Components/Pages/Error.razor new file mode 100644 index 0000000..7053d0b --- /dev/null +++ b/Hcs.WebApp/Components/Pages/Error.razor @@ -0,0 +1,39 @@ +@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/Hcs.WebApp/Components/Pages/Home.razor b/Hcs.WebApp/Components/Pages/Home.razor new file mode 100644 index 0000000..20031e5 --- /dev/null +++ b/Hcs.WebApp/Components/Pages/Home.razor @@ -0,0 +1,7 @@ +@page "/" + +Home + +

Hello, world!

+ +Welcome to your new app diff --git a/Hcs.WebApp/Components/Routes.razor b/Hcs.WebApp/Components/Routes.razor new file mode 100644 index 0000000..f756e19 --- /dev/null +++ b/Hcs.WebApp/Components/Routes.razor @@ -0,0 +1,6 @@ + + + + + + diff --git a/Hcs.WebApp/Components/_Imports.razor b/Hcs.WebApp/Components/_Imports.razor new file mode 100644 index 0000000..6958545 --- /dev/null +++ b/Hcs.WebApp/Components/_Imports.razor @@ -0,0 +1,10 @@ +@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 Hcs.WebApp +@using Hcs.WebApp.Components diff --git a/Hcs.WebApp/Hcs.WebApp.csproj b/Hcs.WebApp/Hcs.WebApp.csproj new file mode 100644 index 0000000..1b28a01 --- /dev/null +++ b/Hcs.WebApp/Hcs.WebApp.csproj @@ -0,0 +1,9 @@ + + + + net8.0 + enable + enable + + + diff --git a/Hcs.WebApp/Program.cs b/Hcs.WebApp/Program.cs new file mode 100644 index 0000000..c928b0b --- /dev/null +++ b/Hcs.WebApp/Program.cs @@ -0,0 +1,24 @@ +using Hcs.WebApp.Components; + +var builder = WebApplication.CreateBuilder(args); +builder.Services + .AddRazorComponents() + .AddInteractiveServerComponents(); + +var app = builder.Build(); +if (!app.Environment.IsDevelopment()) +{ + app.UseExceptionHandler("/Error", createScopeForErrors: true); + app.UseHsts(); +} + +app.UseHttpsRedirection(); + +app.UseStaticFiles(); +app.UseAntiforgery(); + +app + .MapRazorComponents() + .AddInteractiveServerRenderMode(); + +app.Run(); diff --git a/Hcs.WebApp/Properties/launchSettings.json b/Hcs.WebApp/Properties/launchSettings.json new file mode 100644 index 0000000..759aa69 --- /dev/null +++ b/Hcs.WebApp/Properties/launchSettings.json @@ -0,0 +1,38 @@ +{ + "$schema": "http://json.schemastore.org/launchsettings.json", + "iisSettings": { + "windowsAuthentication": false, + "anonymousAuthentication": true, + "iisExpress": { + "applicationUrl": "http://localhost:34512", + "sslPort": 44330 + } + }, + "profiles": { + "http": { + "commandName": "Project", + "dotnetRunMessages": true, + "launchBrowser": true, + "applicationUrl": "http://localhost:5228", + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + }, + "https": { + "commandName": "Project", + "dotnetRunMessages": true, + "launchBrowser": true, + "applicationUrl": "https://localhost:7292;http://localhost:5228", + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + }, + "IIS Express": { + "commandName": "IISExpress", + "launchBrowser": true, + "environmentVariables": { + "ASPNETCORE_ENVIRONMENT": "Development" + } + } + } + } diff --git a/Hcs.WebApp/appsettings.Development.json b/Hcs.WebApp/appsettings.Development.json new file mode 100644 index 0000000..0c208ae --- /dev/null +++ b/Hcs.WebApp/appsettings.Development.json @@ -0,0 +1,8 @@ +{ + "Logging": { + "LogLevel": { + "Default": "Information", + "Microsoft.AspNetCore": "Warning" + } + } +} diff --git a/Hcs.WebApp/appsettings.json b/Hcs.WebApp/appsettings.json new file mode 100644 index 0000000..10f68b8 --- /dev/null +++ b/Hcs.WebApp/appsettings.json @@ -0,0 +1,9 @@ +{ + "Logging": { + "LogLevel": { + "Default": "Information", + "Microsoft.AspNetCore": "Warning" + } + }, + "AllowedHosts": "*" +} diff --git a/Hcs.WebApp/wwwroot/app.css b/Hcs.WebApp/wwwroot/app.css new file mode 100644 index 0000000..e398853 --- /dev/null +++ b/Hcs.WebApp/wwwroot/app.css @@ -0,0 +1,29 @@ +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; +} diff --git a/Hcs.sln b/Hcs.sln index c6b32c3..abecab7 100644 --- a/Hcs.sln +++ b/Hcs.sln @@ -1,12 +1,14 @@  Microsoft Visual Studio Solution File, Format Version 12.00 # Visual Studio Version 17 -VisualStudioVersion = 17.14.36327.8 d17.14 +VisualStudioVersion = 17.14.36327.8 MinimumVisualStudioVersion = 10.0.40219.1 Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Hcs.Client", "Hcs.Client\Hcs.Client.csproj", "{3AF820FD-6776-4C74-AA76-F918E60FE456}" EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Hcs.TestApp", "Hcs.TestApp\Hcs.TestApp.csproj", "{0EE8594D-D76E-4EE2-ACA2-87C49CF1FC71}" EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Hcs.WebApp", "Hcs.WebApp\Hcs.WebApp.csproj", "{CD1B5236-648C-4656-89F1-6CE96A9E5FAF}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Any CPU = Debug|Any CPU @@ -21,6 +23,10 @@ Global {0EE8594D-D76E-4EE2-ACA2-87C49CF1FC71}.Debug|Any CPU.Build.0 = Debug|Any CPU {0EE8594D-D76E-4EE2-ACA2-87C49CF1FC71}.Release|Any CPU.ActiveCfg = Release|Any CPU {0EE8594D-D76E-4EE2-ACA2-87C49CF1FC71}.Release|Any CPU.Build.0 = Release|Any CPU + {CD1B5236-648C-4656-89F1-6CE96A9E5FAF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {CD1B5236-648C-4656-89F1-6CE96A9E5FAF}.Debug|Any CPU.Build.0 = Debug|Any CPU + {CD1B5236-648C-4656-89F1-6CE96A9E5FAF}.Release|Any CPU.ActiveCfg = Release|Any CPU + {CD1B5236-648C-4656-89F1-6CE96A9E5FAF}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE