Basic WEB is working
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -70,7 +70,6 @@ project.fragment.lock.json
|
|||||||
_ReSharper*/
|
_ReSharper*/
|
||||||
*.resharper
|
*.resharper
|
||||||
*.dotCover
|
*.dotCover
|
||||||
.idea/
|
|
||||||
*.coverage
|
*.coverage
|
||||||
*.coveragejson
|
*.coveragejson
|
||||||
TestResult.xml
|
TestResult.xml
|
||||||
@@ -81,7 +80,6 @@ nunit-*.xml
|
|||||||
.DS_Store
|
.DS_Store
|
||||||
|
|
||||||
# Rider logs/cache
|
# Rider logs/cache
|
||||||
.idea/
|
|
||||||
.idea/.idea.*
|
.idea/.idea.*
|
||||||
.idea/*workspace*
|
.idea/*workspace*
|
||||||
.idea/httpRequests
|
.idea/httpRequests
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
using Microsoft.Extensions.Logging;
|
using Microsoft.Extensions.Logging;
|
||||||
|
using MudBlazor.Services;
|
||||||
|
|
||||||
namespace Bimix.UI.Mobile;
|
namespace Bimix.UI.Mobile;
|
||||||
|
|
||||||
@@ -18,6 +19,10 @@ public static class MauiProgram
|
|||||||
builder.Logging.AddDebug();
|
builder.Logging.AddDebug();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
builder.Services.AddMudBlazorDialog();
|
||||||
|
builder.Services.AddMudBlazorSnackbar();
|
||||||
|
builder.Services.AddMudBlazorResizeListener();
|
||||||
|
|
||||||
return builder.Build();
|
return builder.Build();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -13,11 +13,16 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="Microsoft.AspNetCore.Components.Web" Version="8.0.17" />
|
<PackageReference Include="Microsoft.AspNetCore.Components.Web" Version="8.0.17" />
|
||||||
|
<PackageReference Include="MudBlazor" Version="8.8.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\Bimix.Domain\Bimix.Domain.csproj" />
|
<ProjectReference Include="..\Bimix.Domain\Bimix.Domain.csproj" />
|
||||||
<ProjectReference Include="..\Bimix.Application\Bimix.Application.csproj" />
|
<ProjectReference Include="..\Bimix.Application\Bimix.Application.csproj" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<Folder Include="wwwroot\" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -1,3 +0,0 @@
|
|||||||
<div class="my-component">
|
|
||||||
This component is defined in the <strong>Bimix.UI.Shared</strong> library.
|
|
||||||
</div>
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
.my-component {
|
|
||||||
border: 2px dashed red;
|
|
||||||
padding: 1em;
|
|
||||||
margin: 1em 0;
|
|
||||||
background-image: url('background.png');
|
|
||||||
}
|
|
||||||
5
Bimix.UI.Shared/Components/Dashboard.razor
Normal file
5
Bimix.UI.Shared/Components/Dashboard.razor
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
@page "/dashboard"
|
||||||
|
@using MudBlazor
|
||||||
|
|
||||||
|
<MudText Typo="Typo.h4">Dashboard</MudText>
|
||||||
|
<p>Tutaj znajdzie się panel ogólny aplikacji</p>
|
||||||
15
Bimix.UI.Shared/Components/Index.razor
Normal file
15
Bimix.UI.Shared/Components/Index.razor
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
@page "/"
|
||||||
|
@inject NavigationManager Navigation
|
||||||
|
|
||||||
|
@code
|
||||||
|
{
|
||||||
|
protected override async Task OnAfterRenderAsync(bool firstRender)
|
||||||
|
{
|
||||||
|
if (firstRender)
|
||||||
|
{
|
||||||
|
Navigation.NavigateTo("/dashboard");
|
||||||
|
}
|
||||||
|
|
||||||
|
await base.OnAfterRenderAsync(firstRender);
|
||||||
|
}
|
||||||
|
}
|
||||||
10
Bimix.UI.Shared/Components/NavMenu.razor
Normal file
10
Bimix.UI.Shared/Components/NavMenu.razor
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
@using Microsoft.AspNetCore.Components.Routing
|
||||||
|
@using MudBlazor
|
||||||
|
<MudNavMenu>
|
||||||
|
<MudNavLink href="dashboard" Icon="@Icons.Material.Filled.Dashboard" Match="NavLinkMatch.All">
|
||||||
|
Dashboard
|
||||||
|
</MudNavLink>
|
||||||
|
<MudNavLink Href="products" Icon="@Icons.Material.Filled.List" Match="NavLinkMatch.All">
|
||||||
|
Produkty
|
||||||
|
</MudNavLink>
|
||||||
|
</MudNavMenu>
|
||||||
5
Bimix.UI.Shared/Components/ProductList.razor
Normal file
5
Bimix.UI.Shared/Components/ProductList.razor
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
@page "/products"
|
||||||
|
@using MudBlazor
|
||||||
|
|
||||||
|
<MudText Typo="Typo.h4">Produkty</MudText>
|
||||||
|
<p>Lista produktów zostanie tutaj zaimplementowana</p>
|
||||||
18
Bimix.UI.Shared/Components/Routes.razor
Normal file
18
Bimix.UI.Shared/Components/Routes.razor
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
@using Microsoft.AspNetCore.Components.Routing
|
||||||
|
@using MudBlazor
|
||||||
|
|
||||||
|
<Router AppAssembly="@typeof(Routes).Assembly">
|
||||||
|
<Found Context="routeData">
|
||||||
|
<RouteView RouteData="@routeData" DefaultLayout="@typeof(MainLayout)" />
|
||||||
|
<FocusOnNavigate RouteData="routeData" Selector="h1" />
|
||||||
|
</Found>
|
||||||
|
<NotFound>
|
||||||
|
<LayoutView Layout="@typeof(MainLayout)">
|
||||||
|
<MudCard Elevation="0">
|
||||||
|
<MudText Typo="Typo.h6">
|
||||||
|
Strona nieznaleziona.
|
||||||
|
</MudText>
|
||||||
|
</MudCard>
|
||||||
|
</LayoutView>
|
||||||
|
</NotFound>
|
||||||
|
</Router>
|
||||||
@@ -1,36 +0,0 @@
|
|||||||
using Microsoft.JSInterop;
|
|
||||||
|
|
||||||
namespace Bimix.UI.Shared;
|
|
||||||
|
|
||||||
// This class provides an example of how JavaScript functionality can be wrapped
|
|
||||||
// in a .NET class for easy consumption. The associated JavaScript module is
|
|
||||||
// loaded on demand when first needed.
|
|
||||||
//
|
|
||||||
// This class can be registered as scoped DI service and then injected into Blazor
|
|
||||||
// components for use.
|
|
||||||
|
|
||||||
public class ExampleJsInterop : IAsyncDisposable
|
|
||||||
{
|
|
||||||
private readonly Lazy<Task<IJSObjectReference>> moduleTask;
|
|
||||||
|
|
||||||
public ExampleJsInterop(IJSRuntime jsRuntime)
|
|
||||||
{
|
|
||||||
moduleTask = new (() => jsRuntime.InvokeAsync<IJSObjectReference>(
|
|
||||||
"import", "./_content/Bimix.UI.Shared/exampleJsInterop.js").AsTask());
|
|
||||||
}
|
|
||||||
|
|
||||||
public async ValueTask<string> Prompt(string message)
|
|
||||||
{
|
|
||||||
var module = await moduleTask.Value;
|
|
||||||
return await module.InvokeAsync<string>("showPrompt", message);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async ValueTask DisposeAsync()
|
|
||||||
{
|
|
||||||
if (moduleTask.IsValueCreated)
|
|
||||||
{
|
|
||||||
var module = await moduleTask.Value;
|
|
||||||
await module.DisposeAsync();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
66
Bimix.UI.Shared/MainLayout.razor
Normal file
66
Bimix.UI.Shared/MainLayout.razor
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
@using MudBlazor
|
||||||
|
@inherits LayoutComponentBase
|
||||||
|
|
||||||
|
<MudThemeProvider/>
|
||||||
|
<MudDialogProvider/>
|
||||||
|
<MudSnackbarProvider/>
|
||||||
|
|
||||||
|
<MudLayout>
|
||||||
|
<MudBreakpointProvider OnBreakpointChanged="OnBreakpointChanged"></MudBreakpointProvider>
|
||||||
|
<MudAppBar Elevation="0">
|
||||||
|
<MudIconButton
|
||||||
|
Icon="@Icons.Material.Filled.Menu"
|
||||||
|
Color="Color.Inherit"
|
||||||
|
Edge="Edge.Start"
|
||||||
|
OnClick="ToggleDrawer"
|
||||||
|
Class="mud-hidden-md-up"/>
|
||||||
|
<MudSpacer/>
|
||||||
|
<MudText Typo="Typo.h6">Bimix</MudText>
|
||||||
|
</MudAppBar>
|
||||||
|
|
||||||
|
<MudDrawer @bind-Open="_drawerOpen"
|
||||||
|
Anchor="Anchor.Start"
|
||||||
|
Variant="@_drawerVariant"
|
||||||
|
Elevation="1"
|
||||||
|
ClipMode="DrawerClipMode.Always"
|
||||||
|
Class="mud-width-250">
|
||||||
|
<MudNavMenu>
|
||||||
|
<MudNavLink Href="/dashboard" Icon="@Icons.Material.Filled.Dashboard">Dashboard</MudNavLink>
|
||||||
|
<MudNavLink Href="/products" Icon="@Icons.Material.Filled.Inventory">Products</MudNavLink>
|
||||||
|
</MudNavMenu>
|
||||||
|
</MudDrawer>
|
||||||
|
|
||||||
|
<MudMainContent>
|
||||||
|
<MudContainer MaxWidth="MaxWidth.ExtraLarge" Class="my-4">
|
||||||
|
@Body
|
||||||
|
</MudContainer>
|
||||||
|
</MudMainContent>
|
||||||
|
</MudLayout>
|
||||||
|
|
||||||
|
@code {
|
||||||
|
|
||||||
|
private bool _drawerOpen = true;
|
||||||
|
private DrawerVariant _drawerVariant = DrawerVariant.Persistent;
|
||||||
|
|
||||||
|
void ToggleDrawer()
|
||||||
|
{
|
||||||
|
Console.WriteLine($"ToogleDrawer clickkk {DateTime.Now}");
|
||||||
|
_drawerOpen = !_drawerOpen;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnBreakpointChanged(Breakpoint breakpoint)
|
||||||
|
{
|
||||||
|
if (breakpoint < Breakpoint.Md)
|
||||||
|
{
|
||||||
|
_drawerVariant = DrawerVariant.Temporary;
|
||||||
|
_drawerOpen = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_drawerVariant = DrawerVariant.Persistent;
|
||||||
|
_drawerOpen = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
StateHasChanged();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1 +1,11 @@
|
|||||||
@using Microsoft.AspNetCore.Components.Web
|
@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 Bimix.UI.Shared
|
||||||
|
@using Bimix.UI.Shared.Components
|
||||||
|
@using MudBlazor
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 378 B |
@@ -1,6 +0,0 @@
|
|||||||
// This is a JavaScript module that is loaded on demand. It can export any number of
|
|
||||||
// functions, and may import other JavaScript modules if required.
|
|
||||||
|
|
||||||
export function showPrompt(message) {
|
|
||||||
return prompt(message, 'Type anything here');
|
|
||||||
}
|
|
||||||
@@ -10,4 +10,8 @@
|
|||||||
<ProjectReference Include="..\Bimix.UI.Shared\Bimix.UI.Shared.csproj" />
|
<ProjectReference Include="..\Bimix.UI.Shared\Bimix.UI.Shared.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<Folder Include="wwwroot\" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -2,17 +2,34 @@
|
|||||||
<html lang="en">
|
<html lang="en">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8"/>
|
<meta charset="utf-8" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
<base href="/"/>
|
<base href="/" />
|
||||||
<link rel="stylesheet" href="app.css"/>
|
<link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap" rel="stylesheet" />
|
||||||
<link rel="stylesheet" href="Bimix.UI.Web.styles.css"/>
|
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet" />
|
||||||
<HeadOutlet/>
|
<link href="_content/MudBlazor/MudBlazor.min.css" rel="stylesheet" />
|
||||||
|
<link href="Bimix.UI.Web.styles.css" rel="stylesheet" />
|
||||||
|
|
||||||
|
<HeadOutlet />
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<Routes/>
|
<Bimix.UI.Shared.Components.Routes @rendermode="InteractiveServer" />
|
||||||
|
|
||||||
|
|
||||||
|
<div id="blazor-error-ui">
|
||||||
|
<environment include="Staging,Production">
|
||||||
|
An error has occurred. This application may no longer respond until reloaded.
|
||||||
|
</environment>
|
||||||
|
<environment include="Development">
|
||||||
|
An unhandled exception has occurred. See browser dev tools for details.
|
||||||
|
</environment>
|
||||||
|
<a href="" class="reload">Reload</a>
|
||||||
|
<a class="dismiss">🗙</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
<script src="_framework/blazor.web.js"></script>
|
<script src="_framework/blazor.web.js"></script>
|
||||||
|
<script src="_content/MudBlazor/MudBlazor.min.js"></script>
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
@page "/"
|
|
||||||
|
|
||||||
<PageTitle>Home</PageTitle>
|
|
||||||
|
|
||||||
<h1>Hello, world!</h1>
|
|
||||||
|
|
||||||
Welcome to your new app.
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
<Router AppAssembly="typeof(Program).Assembly">
|
|
||||||
<Found Context="routeData">
|
|
||||||
<RouteView RouteData="routeData" DefaultLayout="typeof(Layout.MainLayout)"/>
|
|
||||||
<FocusOnNavigate RouteData="routeData" Selector="h1"/>
|
|
||||||
</Found>
|
|
||||||
</Router>
|
|
||||||
@@ -7,4 +7,7 @@
|
|||||||
@using Microsoft.AspNetCore.Components.Web.Virtualization
|
@using Microsoft.AspNetCore.Components.Web.Virtualization
|
||||||
@using Microsoft.JSInterop
|
@using Microsoft.JSInterop
|
||||||
@using Bimix.UI.Web
|
@using Bimix.UI.Web
|
||||||
@using Bimix.UI.Web.Components
|
@using Bimix.UI.Web.Components
|
||||||
|
@using Bimix.UI.Shared
|
||||||
|
@using Bimix.UI.Shared.Components
|
||||||
|
@using MudBlazor
|
||||||
@@ -1,27 +1,31 @@
|
|||||||
|
using Bimix.UI.Shared;
|
||||||
using Bimix.UI.Web.Components;
|
using Bimix.UI.Web.Components;
|
||||||
|
using MudBlazor.Services;
|
||||||
|
|
||||||
var builder = WebApplication.CreateBuilder(args);
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
// Add services to the container.
|
|
||||||
builder.Services.AddRazorComponents()
|
builder.Services.AddRazorComponents()
|
||||||
.AddInteractiveServerComponents();
|
.AddInteractiveServerComponents();
|
||||||
|
builder.Services.AddMudServices();
|
||||||
|
builder.Services.AddHttpClient("BimixAPI", client =>
|
||||||
|
{
|
||||||
|
client.BaseAddress = new Uri("https://localhost:7071");
|
||||||
|
});
|
||||||
|
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
// Configure the HTTP request pipeline.
|
|
||||||
if (!app.Environment.IsDevelopment())
|
if (!app.Environment.IsDevelopment())
|
||||||
{
|
{
|
||||||
app.UseExceptionHandler("/Error", createScopeForErrors: true);
|
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.UseHsts();
|
||||||
}
|
}
|
||||||
|
|
||||||
app.UseHttpsRedirection();
|
app.UseHttpsRedirection();
|
||||||
|
|
||||||
app.UseStaticFiles();
|
app.UseStaticFiles();
|
||||||
app.UseAntiforgery();
|
app.UseAntiforgery();
|
||||||
|
|
||||||
app.MapRazorComponents<App>()
|
app.MapRazorComponents<App>()
|
||||||
.AddInteractiveServerRenderMode();
|
.AddInteractiveServerRenderMode()
|
||||||
|
.AddAdditionalAssemblies(typeof(MainLayout).Assembly);
|
||||||
|
|
||||||
app.Run();
|
app.Run();
|
||||||
@@ -1,29 +0,0 @@
|
|||||||
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() 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;
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user