Added chatting

This commit is contained in:
BOT Alex 2023-05-26 04:23:26 +02:00
parent 2b8cc84053
commit f6956dfaa0
7 changed files with 106 additions and 23 deletions

View File

@ -11,11 +11,22 @@
</NotFound> </NotFound>
</Router> </Router>
@*<MudThemeProvider @bind-IsDarkMode="@_isDarkMode" Theme="MyCustomTheme" />*@
<MudThemeProvider @bind-IsDarkMode="@_isDarkMode" /> <MudThemeProvider @bind-IsDarkMode="@_isDarkMode" />
<MudDialogProvider /> <MudDialogProvider />
<MudSnackbarProvider /> <MudSnackbarProvider />
@code { @code {
private MudTheme _theme = new(); //public static MudTheme MyCustomTheme = new MudTheme()
// {
// PaletteDark = new PaletteDark()
// {
// Dark = Colors.Pink.Lighten3,
// Background = Colors.Pink.Lighten1,
// AppbarBackground = Colors.Pink.Darken4,
// DrawerBackground = Colors.Pink.Darken4,
// Surface = Colors.Pink.Lighten2,
// }
//};
private bool _isDarkMode = true; private bool _isDarkMode = true;
} }

View File

@ -8,7 +8,7 @@
<MudLayout Class="overflow-hidden"> <MudLayout Class="overflow-hidden">
<MudAppBar Elevation="1"> <MudAppBar Elevation="1">
<MudButton Variant="Variant.Filled" Color="Color.Primary" OnClick="RegisterAccount">Clear cookies</MudButton> <MudButton Variant="Variant.Filled" Color="Color.Primary" Disabled=true>Debug button</MudButton>
<MudSpacer /> <MudSpacer />
@if (!isLoggedIn) @if (!isLoggedIn)
{ {
@ -28,7 +28,6 @@
<MudNavMenu> <MudNavMenu>
<MudNavLink Match="NavLinkMatch.All" Href="/Posts" Icon="@Icons.Material.Filled.Image">Posts</MudNavLink> <MudNavLink Match="NavLinkMatch.All" Href="/Posts" Icon="@Icons.Material.Filled.Image">Posts</MudNavLink>
<MudNavLink Match="NavLinkMatch.All" Href="/Chatting" Icon="@Icons.Material.Filled.Chat">Chat</MudNavLink> <MudNavLink Match="NavLinkMatch.All" Href="/Chatting" Icon="@Icons.Material.Filled.Chat">Chat</MudNavLink>
<MudNavLink Match="NavLinkMatch.All" Icon="@Icons.Material.Filled.Group">Community</MudNavLink>
</MudNavMenu> </MudNavMenu>
</MudDrawer> </MudDrawer>
@ -37,7 +36,7 @@
{ {
<MudPaper Class="ma-2"> <MudPaper Class="ma-2">
<MudStack Spacing="0" Class="justify-center"> <MudStack Spacing="0" Class="justify-center">
<MudButton Class="ma-4" Variant="Variant.Outlined" Color="Color.Error" OnClick="Logout">Logout</MudButton> <MudButton Class="ma-4" Variant="Variant.Filled" Color="Color.Error" OnClick="Logout">Logout</MudButton>
</MudStack> </MudStack>
</MudPaper> </MudPaper>
} }
@ -45,8 +44,8 @@
{ {
<MudPaper Class="ma-2"> <MudPaper Class="ma-2">
<MudStack Spacing="0" Class="justify-center"> <MudStack Spacing="0" Class="justify-center">
<MudButton Class="ma-4" Variant="Variant.Outlined" Color="Color.Primary" OnClick="ShowLogIn">Sign-in</MudButton> <MudButton Class="ma-4" Variant="Variant.Filled" Color="Color.Primary" OnClick="ShowLogIn">Sign-in</MudButton>
<MudButton Class="ma-4" Variant="Variant.Outlined" Color="Color.Success" OnClick="ShowSignUp">Sign-up</MudButton> <MudButton Class="ma-4" Variant="Variant.Filled" Color="Color.Success" OnClick="ShowSignUp">Sign-up</MudButton>
</MudStack> </MudStack>
</MudPaper> </MudPaper>
} }
@ -245,6 +244,7 @@
protected override async Task OnInitializedAsync() protected override async Task OnInitializedAsync()
{ {
StateHasChanged();
CheckLoggedin(); CheckLoggedin();
} }
@ -253,10 +253,9 @@
string? name = await localStorage.GetItemAsStringAsync("User"); string? name = await localStorage.GetItemAsStringAsync("User");
if (name == null) return; if (name == null) return;
Snackbar.Add("Successfully logged in!", Severity.Success);
Program.LoggedInName = name; Program.LoggedInName = name;
isLoggedIn = true; isLoggedIn = true;
Snackbar.Add($"Successfully logged in as: {Program.LoggedInName}.", Severity.Success);
StateHasChanged(); StateHasChanged();
} }

View File

@ -3,6 +3,8 @@
@inject NavigationManager NavManager @inject NavigationManager NavManager
@inject HttpClient Http @inject HttpClient Http
@inject IJSRuntime JSRuntime @inject IJSRuntime JSRuntime
@inject ISnackbar Snackbar
@inject MessageService messageService
<style> <style>
.bottom-start { .bottom-start {
@ -23,7 +25,7 @@
{ {
Message message = messages[i]; Message message = messages[i];
if ("dumb zhen" == message.Name) if (Program.LoggedInName != null && Program.LoggedInName == message.Name)
{ {
<MudStack Class="px-4 py-2 d-flex" Justify="Justify.FlexEnd" Row="true" AlignItems="AlignItems.End"> <MudStack Class="px-4 py-2 d-flex" Justify="Justify.FlexEnd" Row="true" AlignItems="AlignItems.End">
<MudStack> <MudStack>
@ -31,7 +33,7 @@
<MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText> <MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText>
<MudText Class="pa-1 pr-2" Align="Align.End" Style="font-size: 10px;">@("@" + message.Name)</MudText> <MudText Class="pa-1 pr-2" Align="Align.End" Style="font-size: 10px;">@("@" + message.Name)</MudText>
</MudPaper> </MudPaper>
<MudText Class="mt-n3" Align="Align.End" Style="font-size: 10px;">@(DateTime.Now.ToString("dd/MM/yyyy HH:mm", danishCulture))</MudText> <MudText Class="mt-n3" Align="Align.End" Style="font-size: 10px;">@(DateTimeOffset.FromUnixTimeSeconds(message.DatePosted).ToString("dd/MM HH:mm", danishCulture))</MudText>
</MudStack> </MudStack>
</MudStack> </MudStack>
} }
@ -43,7 +45,7 @@
<MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText> <MudText Typo="Typo.body1" Class="px-2 pt-2" Style="max-width: 320px;">@message.Content</MudText>
<MudText Class="pa-1" Style="font-size: 10px;">@("@" + message.Name)</MudText> <MudText Class="pa-1" Style="font-size: 10px;">@("@" + message.Name)</MudText>
</MudPaper> </MudPaper>
<MudText Class="mt-n3 pl-1" Style="font-size: 10px;">@(DateTime.Now.ToString("dd/MM HH:mm", danishCulture))</MudText> <MudText Class="mt-n3 pl-1" Style="font-size: 10px;">@(DateTimeOffset.FromUnixTimeSeconds(message.DatePosted).ToString("dd/MM HH:mm", danishCulture))</MudText>
</MudStack> </MudStack>
</MudStack> </MudStack>
} }
@ -51,9 +53,9 @@
} }
</MudPaper> </MudPaper>
<MudContainer Class="d-flex pa-0"> <MudContainer Class="d-flex pa-0 mb-n1">
<MudTextField Class="my-1" @bind-Value="TextValue" Label="Filled" Variant="Variant.Filled" Margin="Margin.Dense"></MudTextField> <MudTextField Class="my-1" HelperText="Messages cannot be deleted!" HelperTextOnFocus=true Counter="25" @bind-Value="TextValue" MaxLength="32" Immediate="true" Validation="@(new Func<string, IEnumerable<string>>(MaxCharacters))" Disabled="@(Program.LoggedInName == null)" Label="@((Program.LoggedInName == null) ? "Sign-in to send messages" : "Message")" Variant="Variant.Filled" AdornmentColor="@Color.Primary" Margin="Margin.Dense"></MudTextField>
<MudButton Class="my-1" Variant="Variant.Filled" Color="Color.Primary" Disabled="isSending" OnClick="SendMessage"> <MudButton Class="mt-1 mb-7" Variant="Variant.Filled" Color="Color.Primary" Disabled="@(Program.LoggedInName == null || isSending)" OnClick="SendMessage">
@if (isSending) @if (isSending)
{ {
<MudProgressCircular Class="ms-n1 mr-2" Size="Size.Small" Indeterminate="true" /> <MudProgressCircular Class="ms-n1 mr-2" Size="Size.Small" Indeterminate="true" />
@ -78,17 +80,39 @@
isSending = true; isSending = true;
StateHasChanged(); StateHasChanged();
await Task.Delay(3000); await Task.Delay(3000);
//isSending = false;
messages = null; if (string.IsNullOrWhiteSpace(TextValue))
{
Snackbar.Add("Missing input text?", Severity.Error);
return;
}
var message = new Message
{
Content = TextValue,
DatePosted = DateTimeOffset.Now.ToUnixTimeSeconds(),
Name = Program.LoggedInName
};
await messageService.AddMessage(message);
TextValue = string.Empty;
messages = await messageService.GetMessages();
isSending = false;
NavManager.NavigateTo("/"); NavManager.NavigateTo("/");
NavManager.NavigateTo("/Chatting"); NavManager.NavigateTo("/Chatting");
} }
private IEnumerable<string> MaxCharacters(string ch)
{
if (!string.IsNullOrEmpty(ch) && 32 < ch?.Length)
yield return "Max 32 characters";
}
Message[]? messages; Message[]? messages;
protected override async Task OnInitializedAsync() protected override async Task OnInitializedAsync()
{ {
messages = (await Http.GetFromJsonAsync<Message[]>("https://globalchat-4a89f-default-rtdb.europe-west1.firebasedatabase.app/Database/Messages.json")); messages = await messageService.GetMessages();
StartLoop(); StartLoop();
} }
@ -103,9 +127,10 @@
while (isLooping) while (isLooping)
{ {
messages = (await Http.GetFromJsonAsync<Message[]>("https://globalchat-4a89f-default-rtdb.europe-west1.firebasedatabase.app/Database/Messages.json")); messages = await messageService.GetMessages();
Console.WriteLine("Chat updated!");
await Task.Delay(100000); // Delay for 1 second before the next iteration await Task.Delay(10000);
} }
} }

View File

@ -24,6 +24,8 @@ internal class Program
builder.Services.AddBlazoredLocalStorage(config => builder.Services.AddBlazoredLocalStorage(config =>
config.JsonSerializerOptions.WriteIndented = true); // local storage config.JsonSerializerOptions.WriteIndented = true); // local storage
builder.Services.AddScoped<MessageService>();
await builder.Build().RunAsync(); await builder.Build().RunAsync();
} }
} }

View File

@ -0,0 +1,48 @@
using System;
using System.Net.Http;
using System.Net.Http.Json;
using System.Threading.Tasks;
using static Otakians.Pages.Chatting;
public class MessageService
{
private readonly HttpClient _httpClient;
private const string ApiUrl = "https://globalchat-4a89f-default-rtdb.europe-west1.firebasedatabase.app/Database.json";
public MessageService(HttpClient httpClient)
{
_httpClient = httpClient;
}
public async Task<Message[]?> GetMessages()
{
try
{
var rawMaybe = await _httpClient.GetFromJsonAsync<Dictionary<string, Message>>(ApiUrl);
if (rawMaybe == null) return null;
Message[] messages = rawMaybe.Values.ToArray();
Array.Reverse(messages);
return messages;
}
catch (Exception ex)
{
// Handle exception appropriately (e.g., log, display an error message)
throw ex;
}
}
public async Task AddMessage(Message message)
{
try
{
await _httpClient.PostAsJsonAsync(ApiUrl, message);
}
catch (Exception ex)
{
// Handle exception appropriately (e.g., log, display an error message)
throw ex;
}
}
}

View File

@ -9,8 +9,6 @@
<link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap" rel="stylesheet" /> <link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap" rel="stylesheet" />
<link href="_content/MudBlazor/MudBlazor.min.css" rel="stylesheet" /> <link href="_content/MudBlazor/MudBlazor.min.css" rel="stylesheet" />
<link href="css/MudBlazor.min.css" rel="stylesheet" /> <link href="css/MudBlazor.min.css" rel="stylesheet" />
<!-- If you add any scoped CSS files, uncomment the following to load them <!-- If you add any scoped CSS files, uncomment the following to load them
<link href="Otakians.styles.css" rel="stylesheet" /> --> <link href="Otakians.styles.css" rel="stylesheet" /> -->
</head> </head>