First main page test prepared

This commit is contained in:
Jan Beníček 2025-01-16 18:54:15 +01:00
parent 906f2d6034
commit 4fe9bc7d87
7 changed files with 143 additions and 69 deletions

View file

@ -5,10 +5,6 @@
</div> </div>
<main> <main>
<div class="top-row px-4">
<a href="https://learn.microsoft.com/aspnet/core/" target="_blank">About</a>
</div>
<article class="content px-4"> <article class="content px-4">
@Body @Body
</article> </article>

View file

@ -1,6 +1,6 @@
<div class="top-row ps-3 navbar navbar-dark"> <div class="top-row ps-3 navbar navbar-dark">
<div class="container-fluid"> <div class="container-fluid">
<a class="navbar-brand" href="">TestingRoom_NN_Kajk_UI</a> <a class="navbar-brand" href="">NN - Kajk</a>
<button title="Navigation menu" class="navbar-toggler" @onclick="ToggleNavMenu"> <button title="Navigation menu" class="navbar-toggler" @onclick="ToggleNavMenu">
<span class="navbar-toggler-icon"></span> <span class="navbar-toggler-icon"></span>
</button> </button>
@ -11,12 +11,12 @@
<nav class="nav flex-column"> <nav class="nav flex-column">
<div class="nav-item px-3"> <div class="nav-item px-3">
<NavLink class="nav-link" href="" Match="NavLinkMatch.All"> <NavLink class="nav-link" href="" Match="NavLinkMatch.All">
<span class="bi bi-house-door-fill-nav-menu" aria-hidden="true"></span> Home <span class="bi bi-house-door-fill-nav-menu" aria-hidden="true"></span> Control
</NavLink> </NavLink>
</div> </div>
<div class="nav-item px-3"> <div class="nav-item px-3">
<NavLink class="nav-link" href="counter"> <NavLink class="nav-link" href="variables">
<span class="bi bi-plus-square-fill-nav-menu" aria-hidden="true"></span> Counter <span class="bi bi-plus-square-fill-nav-menu" aria-hidden="true"></span> Variables
</NavLink> </NavLink>
</div> </div>
</nav> </nav>

View file

@ -0,0 +1,12 @@
using System.Text.Json.Serialization;
namespace TestingRoom_NN_Kajk_UI.Models
{
public class VariablePostModel
{
public string data { get; set; }
[JsonPropertyName("default")]
public bool Isdefault { get; set; }
}
}

View file

@ -1,4 +1,4 @@
@page "/counter" @page "/variables"
<PageTitle>Counter</PageTitle> <PageTitle>Counter</PageTitle>

View file

@ -1,7 +1,126 @@
@page "/" @page "/"
<PageTitle>Home</PageTitle> @using TestingRoom_NN_Kajk_UI.Models
@inject HttpClient HttpClient
<h1>Hello, world!</h1> <PageTitle>Control</PageTitle>
Welcome to your new app. <div class="row align-content-center text-center align-items-center">
<div class="col-sm-12 col-xl-6 col-xxl-4">
<h2><b>Otáčky: @RPM_Actual RPM</b></h2>
<div class="progress" role="progressbar" aria-label="Basic example" aria-valuenow="@RPM_Actual" aria-valuemin="0" aria-valuemax="@RPM_Max">
<div class="progress-bar" style="width: @($"{Math.Round((RPM_Actual / RPM_Max), 2) * 100}%")"></div>
</div>
<h3/>
</div>
<div class="col-sm-12 col-xl-6 col-xxl-4">
<div class="align-content-center">
<h4><b>Žádané otáčky:</b></h4>
<div class="input-group mb-3">
<input class="form-control text-center" type="number" min="0" max="@RPM_Max" value="@RPM_Requested" @onchange="(x) => SetRPMRequested(int.Parse(x.Value.ToString()))" />
</div>
<div>
<button class="btn btn-primary" @onclick="() => AddRPMRequested(-1)">-1</button>
<button class="btn btn-primary" @onclick="() => AddRPMRequested(+1)">+1</button>
<button class="btn btn-primary" @onclick="() => AddRPMRequested(-10)">-10</button>
<button class="btn btn-primary" @onclick="() => AddRPMRequested(+10)">+10</button>
<button class="btn btn-primary" @onclick="() => AddRPMRequested(-100)">-100</button>
<button class="btn btn-primary" @onclick="() => AddRPMRequested(100)">+100</button>
</div>
<h6/>
<div>
@foreach (int i in RPM_Presets)
{
<button class="btn btn-primary" @onclick="() => SetRPMRequested(i)">@i RPM</button>
}
</div>
</div>
<h3/>
</div>
</div>
@code{
string RPM_Actual_Variable_Name = "actual_rpm";
string RPM_Requested_Variable_Name = "requested_rpm";
string RPM_Max_Variable_Name = "max_rpm";
float RPM_Actual = 0;
float RPM_Max = 1900;
float RPM_Requested = 0;
List<int> RPM_Presets = new() { 0, 1500, 1800 };
private System.Timers.Timer RPM_Actual_Timer = new System.Timers.Timer(500); //actual RPM reader timer
private System.Timers.Timer RPM_Requested_Timer = new System.Timers.Timer(5000); //requested RPM reader timer
protected override void OnInitialized()
{
base.OnInitialized();
//actual RPM request timer
RPM_Actual_Timer.AutoReset = true;
RPM_Actual_Timer.Elapsed += RequestActualRPM;
RPM_Actual_Timer.Start();
//requested RPM request timer
RPM_Requested_Timer.AutoReset = true;
RPM_Requested_Timer.Elapsed += RequestRequestedRPM;
RPM_Requested_Timer.Start();
}
private void SetRPMRequested(int rpm)
{
RPM_Requested_Timer.Stop();
RPM_Requested = rpm;
SetRPMRequested();
RPM_Requested_Timer.Start();
}
private void AddRPMRequested(int add)
{
RPM_Requested_Timer.Stop();
RPM_Requested += add;
if (RPM_Requested < 0)
RPM_Requested = 0;
if (RPM_Requested > RPM_Max)
RPM_Requested = RPM_Max;
SetRPMRequested();
RPM_Requested_Timer.Start();
}
private async void RequestActualRPM(object? sender, System.Timers.ElapsedEventArgs e)
{
//RPM_Actual = float.Parse(await HttpClient.GetStringAsync($"/api/variables/{RPM_Actual_Variable_Name}"));
await InvokeAsync(StateHasChanged);
}
private async void RequestRequestedRPM(object? sender, System.Timers.ElapsedEventArgs e)
{
//RPM_Requested = int.Parse(await HttpClient.GetStringAsync($"/api/variables/{RPM_Requested_Variable_Name}"));
await InvokeAsync(StateHasChanged);
}
private async void SetRPMRequested()
{
//await HttpClient.PostAsJsonAsync($"/api/variables/{RPM_Requested_Variable_Name}", new VariablePostModel { data = RPM_Requested.ToString(), Isdefault = false });
}
private async void GetRPMMax()
{
//RPM_Max = int.Parse(await HttpClient.GetStringAsync($"/api/variables/{RPM_Requested_Variable_Name}"));
await InvokeAsync(StateHasChanged);
}
}

View file

@ -1,57 +0,0 @@
@page "/weather"
@inject HttpClient Http
<PageTitle>Weather</PageTitle>
<h1>Weather</h1>
<p>This component demonstrates fetching data from the server.</p>
@if (forecasts == null)
{
<p><em>Loading...</em></p>
}
else
{
<table class="table">
<thead>
<tr>
<th>Date</th>
<th aria-label="Temperature in Celsius">Temp. (C)</th>
<th aria-label="Temperature in Farenheit">Temp. (F)</th>
<th>Summary</th>
</tr>
</thead>
<tbody>
@foreach (var forecast in forecasts)
{
<tr>
<td>@forecast.Date.ToShortDateString()</td>
<td>@forecast.TemperatureC</td>
<td>@forecast.TemperatureF</td>
<td>@forecast.Summary</td>
</tr>
}
</tbody>
</table>
}
@code {
private WeatherForecast[]? forecasts;
protected override async Task OnInitializedAsync()
{
forecasts = await Http.GetFromJsonAsync<WeatherForecast[]>("sample-data/weather.json");
}
public 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);
}
}

View file

@ -16,4 +16,8 @@
<ServiceWorker Include="wwwroot\service-worker.js" PublishedContent="wwwroot\service-worker.published.js" /> <ServiceWorker Include="wwwroot\service-worker.js" PublishedContent="wwwroot\service-worker.published.js" />
</ItemGroup> </ItemGroup>
<ItemGroup>
<Folder Include="Services\" />
</ItemGroup>
</Project> </Project>